Merge pull request #1344 from grob6000/independent_pid
Independent PID parameters for each extruder
This commit is contained in:
@ -38,7 +38,7 @@ void _EEPROM_readData(int &pos, uint8_t* value, uint8_t size)
|
||||
// wrong data being written to the variables.
|
||||
// ALSO: always make sure the variables in the Store and retrieve sections are in the same order.
|
||||
|
||||
#define EEPROM_VERSION "V13"
|
||||
#define EEPROM_VERSION "V14"
|
||||
|
||||
#ifdef EEPROM_SETTINGS
|
||||
void Config_StoreSettings()
|
||||
@ -63,11 +63,11 @@ void Config_StoreSettings()
|
||||
EEPROM_WRITE_VAR(i,delta_radius);
|
||||
EEPROM_WRITE_VAR(i,delta_diagonal_rod);
|
||||
EEPROM_WRITE_VAR(i,delta_segments_per_second);
|
||||
#endif
|
||||
#endif//DELTA
|
||||
#ifndef ULTIPANEL
|
||||
int plaPreheatHotendTemp = PLA_PREHEAT_HOTEND_TEMP, plaPreheatHPBTemp = PLA_PREHEAT_HPB_TEMP, plaPreheatFanSpeed = PLA_PREHEAT_FAN_SPEED;
|
||||
int absPreheatHotendTemp = ABS_PREHEAT_HOTEND_TEMP, absPreheatHPBTemp = ABS_PREHEAT_HPB_TEMP, absPreheatFanSpeed = ABS_PREHEAT_FAN_SPEED;
|
||||
#endif
|
||||
#endif//ULTIPANEL
|
||||
EEPROM_WRITE_VAR(i,plaPreheatHotendTemp);
|
||||
EEPROM_WRITE_VAR(i,plaPreheatHPBTemp);
|
||||
EEPROM_WRITE_VAR(i,plaPreheatFanSpeed);
|
||||
@ -76,37 +76,58 @@ void Config_StoreSettings()
|
||||
EEPROM_WRITE_VAR(i,absPreheatFanSpeed);
|
||||
EEPROM_WRITE_VAR(i,zprobe_zoffset);
|
||||
#ifdef PIDTEMP
|
||||
EEPROM_WRITE_VAR(i,Kp);
|
||||
EEPROM_WRITE_VAR(i,Ki);
|
||||
EEPROM_WRITE_VAR(i,Kd);
|
||||
#else
|
||||
float dummy = 0.0f;
|
||||
for (int e = 0; e < 3; e++)
|
||||
{
|
||||
if (e < EXTRUDERS)
|
||||
{
|
||||
EEPROM_WRITE_VAR(i,PID_PARAM(Kp,e));
|
||||
EEPROM_WRITE_VAR(i,PID_PARAM(Ki,e));
|
||||
EEPROM_WRITE_VAR(i,PID_PARAM(Kd,e));
|
||||
#ifdef PID_ADD_EXTRUSION_RATE
|
||||
EEPROM_WRITE_VAR(i,PID_PARAM(Kc,e));
|
||||
#else//PID_ADD_EXTRUSION_RATE
|
||||
dummy = 1.0f; // 1.0 = default kc
|
||||
EEPROM_WRITE_VAR(dummmy);
|
||||
#endif//PID_ADD_EXTRUSION_RATE
|
||||
}
|
||||
else
|
||||
{
|
||||
dummy = 3000.0f;
|
||||
EEPROM_WRITE_VAR(i, dummy);
|
||||
dummy = 0.0f;
|
||||
EEPROM_WRITE_VAR(i,dummy);
|
||||
EEPROM_WRITE_VAR(i,dummy);
|
||||
}
|
||||
}
|
||||
#else//PIDTEMP
|
||||
float dummy = 3000.0f;
|
||||
EEPROM_WRITE_VAR(i,dummy);
|
||||
dummy = 0.0f;
|
||||
EEPROM_WRITE_VAR(i,dummy);
|
||||
EEPROM_WRITE_VAR(i,dummy);
|
||||
#endif
|
||||
#endif//PIDTEMP
|
||||
#ifndef DOGLCD
|
||||
int lcd_contrast = 32;
|
||||
#endif
|
||||
#endif//DOGLCD
|
||||
EEPROM_WRITE_VAR(i,lcd_contrast);
|
||||
#ifdef SCARA
|
||||
EEPROM_WRITE_VAR(i,axis_scaling); // Add scaling for SCARA
|
||||
#endif
|
||||
#endif//SCARA
|
||||
#ifdef FWRETRACT
|
||||
EEPROM_WRITE_VAR(i,autoretract_enabled);
|
||||
EEPROM_WRITE_VAR(i,retract_length);
|
||||
#if EXTRUDERS > 1
|
||||
EEPROM_WRITE_VAR(i,retract_length_swap);
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
EEPROM_WRITE_VAR(i,retract_feedrate);
|
||||
EEPROM_WRITE_VAR(i,retract_zlift);
|
||||
EEPROM_WRITE_VAR(i,retract_recover_length);
|
||||
#if EXTRUDERS > 1
|
||||
EEPROM_WRITE_VAR(i,retract_recover_length_swap);
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
EEPROM_WRITE_VAR(i,retract_recover_feedrate);
|
||||
#endif
|
||||
#endif//FWRETRACT
|
||||
|
||||
// Save filament sizes
|
||||
EEPROM_WRITE_VAR(i, volumetric_enabled);
|
||||
@ -115,8 +136,8 @@ void Config_StoreSettings()
|
||||
EEPROM_WRITE_VAR(i, filament_size[1]);
|
||||
#if EXTRUDERS > 2
|
||||
EEPROM_WRITE_VAR(i, filament_size[2]);
|
||||
#endif
|
||||
#endif
|
||||
#endif//EXTRUDERS > 2
|
||||
#endif//EXTRUDERS > 1
|
||||
|
||||
char ver2[4]=EEPROM_VERSION;
|
||||
i=EEPROM_OFFSET;
|
||||
@ -149,7 +170,7 @@ SERIAL_ECHOLNPGM("Scaling factors:");
|
||||
SERIAL_ECHOLN("");
|
||||
|
||||
SERIAL_ECHO_START;
|
||||
#endif
|
||||
#endif//SCARA
|
||||
SERIAL_ECHOLNPGM("Maximum feedrates (mm/s):");
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOPAIR(" M203 X", max_feedrate[X_AXIS]);
|
||||
@ -206,16 +227,16 @@ SERIAL_ECHOLNPGM("Scaling factors:");
|
||||
SERIAL_ECHOPAIR(" R" ,delta_radius );
|
||||
SERIAL_ECHOPAIR(" S" ,delta_segments_per_second );
|
||||
SERIAL_ECHOLN("");
|
||||
#endif
|
||||
#endif//DELTA
|
||||
#ifdef PIDTEMP
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOLNPGM("PID settings:");
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOPAIR(" M301 P",Kp);
|
||||
SERIAL_ECHOPAIR(" I" ,unscalePID_i(Ki));
|
||||
SERIAL_ECHOPAIR(" D" ,unscalePID_d(Kd));
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOPAIR(" M301 P", PID_PARAM(Kp,0)); // for compatibility with hosts, only echos values for E0
|
||||
SERIAL_ECHOPAIR(" I", unscalePID_i(PID_PARAM(Ki, 0)));
|
||||
SERIAL_ECHOPAIR(" D", unscalePID_d(PID_PARAM(Kd, 0)));
|
||||
SERIAL_ECHOLN("");
|
||||
#endif
|
||||
#endif//PIDTEMP
|
||||
#ifdef FWRETRACT
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOLNPGM("Retract: S=Length (mm) F:Speed (mm/m) Z: ZLift (mm)");
|
||||
@ -244,7 +265,7 @@ SERIAL_ECHOLNPGM("Scaling factors:");
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOPAIR(" Swap rec. addl. length (mm): ", retract_recover_length_swap);
|
||||
SERIAL_ECHOLN("");
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
SERIAL_ECHO_START;
|
||||
if (volumetric_enabled) {
|
||||
SERIAL_ECHOLNPGM("Filament settings:");
|
||||
@ -259,14 +280,14 @@ SERIAL_ECHOLNPGM("Scaling factors:");
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOPAIR(" M200 T2 D", filament_size[2]);
|
||||
SERIAL_ECHOLN("");
|
||||
#endif
|
||||
#endif
|
||||
#endif//EXTRUDERS > 2
|
||||
#endif//EXTRUDERS > 1
|
||||
} else {
|
||||
SERIAL_ECHOLNPGM("Filament settings: Disabled");
|
||||
}
|
||||
#endif
|
||||
#endif//FWRETRACT
|
||||
}
|
||||
#endif
|
||||
#endif//DISABLE_M503
|
||||
|
||||
|
||||
#ifdef EEPROM_SETTINGS
|
||||
@ -301,11 +322,11 @@ void Config_RetrieveSettings()
|
||||
EEPROM_READ_VAR(i,delta_radius);
|
||||
EEPROM_READ_VAR(i,delta_diagonal_rod);
|
||||
EEPROM_READ_VAR(i,delta_segments_per_second);
|
||||
#endif
|
||||
#endif//DELTA
|
||||
#ifndef ULTIPANEL
|
||||
int plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed;
|
||||
int absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed;
|
||||
#endif
|
||||
#endif//ULTIPANEL
|
||||
EEPROM_READ_VAR(i,plaPreheatHotendTemp);
|
||||
EEPROM_READ_VAR(i,plaPreheatHPBTemp);
|
||||
EEPROM_READ_VAR(i,plaPreheatFanSpeed);
|
||||
@ -313,35 +334,68 @@ void Config_RetrieveSettings()
|
||||
EEPROM_READ_VAR(i,absPreheatHPBTemp);
|
||||
EEPROM_READ_VAR(i,absPreheatFanSpeed);
|
||||
EEPROM_READ_VAR(i,zprobe_zoffset);
|
||||
#ifndef PIDTEMP
|
||||
float Kp,Ki,Kd;
|
||||
#endif
|
||||
// do not need to scale PID values as the values in EEPROM are already scaled
|
||||
EEPROM_READ_VAR(i,Kp);
|
||||
EEPROM_READ_VAR(i,Ki);
|
||||
EEPROM_READ_VAR(i,Kd);
|
||||
#ifdef PIDTEMP
|
||||
float dummy = 0.0f;
|
||||
for (int e = 0; e < 3; e++) // 3 = max extruders supported by marlin
|
||||
{
|
||||
if (e < EXTRUDERS)
|
||||
{
|
||||
// do not need to scale PID values as the values in EEPROM are already scaled
|
||||
EEPROM_READ_VAR(i,PID_PARAM(Kp,e));
|
||||
EEPROM_READ_VAR(i,PID_PARAM(Ki,e));
|
||||
EEPROM_READ_VAR(i,PID_PARAM(Kd,e));
|
||||
#ifdef PID_ADD_EXTRUSION_RATE
|
||||
EEPROM_READ_VAR(i,PID_PARAM(Kc,e));
|
||||
#else//PID_ADD_EXTRUSION_RATE
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
#endif//PID_ADD_EXTRUSION_RATE
|
||||
}
|
||||
else
|
||||
{
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
}
|
||||
}
|
||||
#else//PIDTEMP
|
||||
// 4 x 3 = 12 slots for PID parameters
|
||||
float dummy = 0.0f;
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
EEPROM_READ_VAR(i,dummy);
|
||||
#endif//PIDTEMP
|
||||
#ifndef DOGLCD
|
||||
int lcd_contrast;
|
||||
#endif
|
||||
#endif//DOGLCD
|
||||
EEPROM_READ_VAR(i,lcd_contrast);
|
||||
#ifdef SCARA
|
||||
EEPROM_READ_VAR(i,axis_scaling);
|
||||
#endif
|
||||
#endif//SCARA
|
||||
|
||||
#ifdef FWRETRACT
|
||||
EEPROM_READ_VAR(i,autoretract_enabled);
|
||||
EEPROM_READ_VAR(i,retract_length);
|
||||
#if EXTRUDERS > 1
|
||||
EEPROM_READ_VAR(i,retract_length_swap);
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
EEPROM_READ_VAR(i,retract_feedrate);
|
||||
EEPROM_READ_VAR(i,retract_zlift);
|
||||
EEPROM_READ_VAR(i,retract_recover_length);
|
||||
#if EXTRUDERS > 1
|
||||
EEPROM_READ_VAR(i,retract_recover_length_swap);
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
EEPROM_READ_VAR(i,retract_recover_feedrate);
|
||||
#endif
|
||||
#endif//FWRETRACT
|
||||
|
||||
EEPROM_READ_VAR(i, volumetric_enabled);
|
||||
EEPROM_READ_VAR(i, filament_size[0]);
|
||||
@ -349,8 +403,8 @@ void Config_RetrieveSettings()
|
||||
EEPROM_READ_VAR(i, filament_size[1]);
|
||||
#if EXTRUDERS > 2
|
||||
EEPROM_READ_VAR(i, filament_size[2]);
|
||||
#endif
|
||||
#endif
|
||||
#endif//EXTRUDERS > 2
|
||||
#endif//EXTRUDERS > 1
|
||||
calculate_volumetric_multipliers();
|
||||
// Call updatePID (similar to when we have processed M301)
|
||||
updatePID();
|
||||
@ -363,9 +417,9 @@ void Config_RetrieveSettings()
|
||||
}
|
||||
#ifdef EEPROM_CHITCHAT
|
||||
Config_PrintSettings();
|
||||
#endif
|
||||
#endif//EEPROM_CHITCHAT
|
||||
}
|
||||
#endif
|
||||
#endif//EEPROM_SETTINGS
|
||||
|
||||
void Config_ResetDefault()
|
||||
{
|
||||
@ -379,7 +433,7 @@ void Config_ResetDefault()
|
||||
max_acceleration_units_per_sq_second[i]=pgm_read_float(&tmp3[i]);
|
||||
#ifdef SCARA
|
||||
axis_scaling[i]=1;
|
||||
#endif
|
||||
#endif//SCARA
|
||||
}
|
||||
|
||||
// steps per sq second need to be updated to agree with the units per sq second
|
||||
@ -400,7 +454,7 @@ void Config_ResetDefault()
|
||||
delta_diagonal_rod= DELTA_DIAGONAL_ROD;
|
||||
delta_segments_per_second= DELTA_SEGMENTS_PER_SECOND;
|
||||
recalc_delta_settings(delta_radius, delta_diagonal_rod);
|
||||
#endif
|
||||
#endif//DELTA
|
||||
#ifdef ULTIPANEL
|
||||
plaPreheatHotendTemp = PLA_PREHEAT_HOTEND_TEMP;
|
||||
plaPreheatHPBTemp = PLA_PREHEAT_HPB_TEMP;
|
||||
@ -408,24 +462,29 @@ void Config_ResetDefault()
|
||||
absPreheatHotendTemp = ABS_PREHEAT_HOTEND_TEMP;
|
||||
absPreheatHPBTemp = ABS_PREHEAT_HPB_TEMP;
|
||||
absPreheatFanSpeed = ABS_PREHEAT_FAN_SPEED;
|
||||
#endif
|
||||
#endif//ULTIPANEL
|
||||
#ifdef ENABLE_AUTO_BED_LEVELING
|
||||
zprobe_zoffset = -Z_PROBE_OFFSET_FROM_EXTRUDER;
|
||||
#endif
|
||||
#endif//ENABLE_AUTO_BED_LEVELING
|
||||
#ifdef DOGLCD
|
||||
lcd_contrast = DEFAULT_LCD_CONTRAST;
|
||||
#endif
|
||||
#endif//DOGLCD
|
||||
#ifdef PIDTEMP
|
||||
Kp = DEFAULT_Kp;
|
||||
Ki = scalePID_i(DEFAULT_Ki);
|
||||
Kd = scalePID_d(DEFAULT_Kd);
|
||||
|
||||
#ifdef PID_PARAMS_PER_EXTRUDER
|
||||
for (int e = 0; e < EXTRUDERS; e++)
|
||||
#else // PID_PARAMS_PER_EXTRUDER
|
||||
int e = 0; // only need to write once
|
||||
#endif // PID_PARAMS_PER_EXTRUDER
|
||||
{
|
||||
PID_PARAM(Kp,e) = DEFAULT_Kp;
|
||||
PID_PARAM(Ki,e) = scalePID_i(DEFAULT_Ki);
|
||||
PID_PARAM(Kd,e) = scalePID_d(DEFAULT_Kd);
|
||||
#ifdef PID_ADD_EXTRUSION_RATE
|
||||
PID_PARAM(Kc,e) = DEFAULT_Kc;
|
||||
#endif//PID_ADD_EXTRUSION_RATE
|
||||
}
|
||||
// call updatePID (similar to when we have processed M301)
|
||||
updatePID();
|
||||
|
||||
#ifdef PID_ADD_EXTRUSION_RATE
|
||||
Kc = DEFAULT_Kc;
|
||||
#endif//PID_ADD_EXTRUSION_RATE
|
||||
#endif//PIDTEMP
|
||||
|
||||
#ifdef FWRETRACT
|
||||
@ -433,15 +492,15 @@ void Config_ResetDefault()
|
||||
retract_length = RETRACT_LENGTH;
|
||||
#if EXTRUDERS > 1
|
||||
retract_length_swap = RETRACT_LENGTH_SWAP;
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
retract_feedrate = RETRACT_FEEDRATE;
|
||||
retract_zlift = RETRACT_ZLIFT;
|
||||
retract_recover_length = RETRACT_RECOVER_LENGTH;
|
||||
#if EXTRUDERS > 1
|
||||
retract_recover_length_swap = RETRACT_RECOVER_LENGTH_SWAP;
|
||||
#endif
|
||||
#endif//EXTRUDERS > 1
|
||||
retract_recover_feedrate = RETRACT_RECOVER_FEEDRATE;
|
||||
#endif
|
||||
#endif//FWRETRACT
|
||||
|
||||
volumetric_enabled = false;
|
||||
filament_size[0] = DEFAULT_NOMINAL_FILAMENT_DIA;
|
||||
@ -449,11 +508,11 @@ void Config_ResetDefault()
|
||||
filament_size[1] = DEFAULT_NOMINAL_FILAMENT_DIA;
|
||||
#if EXTRUDERS > 2
|
||||
filament_size[2] = DEFAULT_NOMINAL_FILAMENT_DIA;
|
||||
#endif
|
||||
#endif
|
||||
#endif//EXTRUDERS > 2
|
||||
#endif//EXTRUDERS > 1
|
||||
calculate_volumetric_multipliers();
|
||||
|
||||
SERIAL_ECHO_START;
|
||||
SERIAL_ECHOLNPGM("Hardcoded Default Settings Loaded");
|
||||
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user