|
|
@ -88,6 +88,10 @@
|
|
|
|
#include "../feature/pause.h"
|
|
|
|
#include "../feature/pause.h"
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
|
|
|
|
#define LPQ_LEN thermalManager.lpq_len
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#pragma pack(push, 1) // No padding between variables
|
|
|
|
#pragma pack(push, 1) // No padding between variables
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct PID { float Kp, Ki, Kd; } PID;
|
|
|
|
typedef struct PID { float Kp, Ki, Kd; } PID;
|
|
|
@ -198,7 +202,7 @@ typedef struct SettingsDataStruct {
|
|
|
|
//
|
|
|
|
//
|
|
|
|
PIDC hotendPID[MAX_EXTRUDERS]; // M301 En PIDC / M303 En U
|
|
|
|
PIDC hotendPID[MAX_EXTRUDERS]; // M301 En PIDC / M303 En U
|
|
|
|
|
|
|
|
|
|
|
|
int lpq_len; // M301 L
|
|
|
|
int16_t lpq_len; // M301 L
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// PIDTEMPBED
|
|
|
|
// PIDTEMPBED
|
|
|
@ -594,9 +598,9 @@ void MarlinSettings::postprocess() {
|
|
|
|
_FIELD_TEST(lpq_len);
|
|
|
|
_FIELD_TEST(lpq_len);
|
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(PID_EXTRUSION_SCALING)
|
|
|
|
#if DISABLED(PID_EXTRUSION_SCALING)
|
|
|
|
int lpq_len = 20;
|
|
|
|
const int16_t LPQ_LEN = 20;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
EEPROM_WRITE(lpq_len);
|
|
|
|
EEPROM_WRITE(LPQ_LEN);
|
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(PIDTEMPBED)
|
|
|
|
#if DISABLED(PIDTEMPBED)
|
|
|
|
dummy = DUMMY_PID_VALUE;
|
|
|
|
dummy = DUMMY_PID_VALUE;
|
|
|
@ -1199,9 +1203,9 @@ void MarlinSettings::postprocess() {
|
|
|
|
_FIELD_TEST(lpq_len);
|
|
|
|
_FIELD_TEST(lpq_len);
|
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(PID_EXTRUSION_SCALING)
|
|
|
|
#if DISABLED(PID_EXTRUSION_SCALING)
|
|
|
|
int lpq_len;
|
|
|
|
int16_t LPQ_LEN;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
EEPROM_READ(lpq_len);
|
|
|
|
EEPROM_READ(LPQ_LEN);
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// Heated Bed PID
|
|
|
|
// Heated Bed PID
|
|
|
@ -1812,7 +1816,7 @@ void MarlinSettings::reset(PORTARG_SOLO) {
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
lpq_len = 20; // default last-position-queue size
|
|
|
|
thermalManager.lpq_len = 20; // default last-position-queue size
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#endif // PIDTEMP
|
|
|
|
#endif // PIDTEMP
|
|
|
|
|
|
|
|
|
|
|
@ -2288,7 +2292,7 @@ void MarlinSettings::reset(PORTARG_SOLO) {
|
|
|
|
SERIAL_ECHOPAIR_P(port, " D", unscalePID_d(PID_PARAM(Kd, e)));
|
|
|
|
SERIAL_ECHOPAIR_P(port, " D", unscalePID_d(PID_PARAM(Kd, e)));
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
SERIAL_ECHOPAIR_P(port, " C", PID_PARAM(Kc, e));
|
|
|
|
SERIAL_ECHOPAIR_P(port, " C", PID_PARAM(Kc, e));
|
|
|
|
if (e == 0) SERIAL_ECHOPAIR_P(port, " L", lpq_len);
|
|
|
|
if (e == 0) SERIAL_ECHOPAIR_P(port, " L", thermalManager.lpq_len);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
SERIAL_EOL_P(port);
|
|
|
|
SERIAL_EOL_P(port);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -2303,7 +2307,7 @@ void MarlinSettings::reset(PORTARG_SOLO) {
|
|
|
|
SERIAL_ECHOPAIR_P(port, " D", unscalePID_d(PID_PARAM(Kd, 0)));
|
|
|
|
SERIAL_ECHOPAIR_P(port, " D", unscalePID_d(PID_PARAM(Kd, 0)));
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
#if ENABLED(PID_EXTRUSION_SCALING)
|
|
|
|
SERIAL_ECHOPAIR_P(port, " C", PID_PARAM(Kc, 0));
|
|
|
|
SERIAL_ECHOPAIR_P(port, " C", PID_PARAM(Kc, 0));
|
|
|
|
SERIAL_ECHOPAIR_P(port, " L", lpq_len);
|
|
|
|
SERIAL_ECHOPAIR_P(port, " L", thermalManager.lpq_len);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
SERIAL_EOL_P(port);
|
|
|
|
SERIAL_EOL_P(port);
|
|
|
|
}
|
|
|
|
}
|
|
|
|