|  |  | @ -76,13 +76,13 @@ class Temperature { | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     #if ENABLED(PIDTEMP) |  |  |  |     #if ENABLED(PIDTEMP) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       #if ENABLED(PID_PARAMS_PER_HOTEND) |  |  |  |       #if ENABLED(PID_PARAMS_PER_HOTEND) && HOTENDS > 1 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         static float Kp[HOTENDS], Ki[HOTENDS], Kd[HOTENDS]; |  |  |  |         static float Kp[HOTENDS], Ki[HOTENDS], Kd[HOTENDS]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         #if ENABLED(PID_ADD_EXTRUSION_RATE) |  |  |  |         #if ENABLED(PID_ADD_EXTRUSION_RATE) | 
			
		
	
		
		
			
				
					
					|  |  |  |           static float Kc[HOTENDS]; |  |  |  |           static float Kc[HOTENDS]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         #endif |  |  |  |         #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |         #define PID_PARAM(param, e) Temperature::param[e] |  |  |  |         #define PID_PARAM(param, h) Temperature::param[h] | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       #else |  |  |  |       #else | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -90,7 +90,7 @@ class Temperature { | 
			
		
	
		
		
			
				
					
					|  |  |  |         #if ENABLED(PID_ADD_EXTRUSION_RATE) |  |  |  |         #if ENABLED(PID_ADD_EXTRUSION_RATE) | 
			
		
	
		
		
			
				
					
					|  |  |  |           static float Kc; |  |  |  |           static float Kc; | 
			
		
	
		
		
			
				
					
					|  |  |  |         #endif |  |  |  |         #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |         #define PID_PARAM(param, e) Temperature::param |  |  |  |         #define PID_PARAM(param, h) Temperature::param | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       #endif // PID_PARAMS_PER_HOTEND
 |  |  |  |       #endif // PID_PARAMS_PER_HOTEND
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -150,7 +150,7 @@ class Temperature { | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       #if ENABLED(PID_ADD_EXTRUSION_RATE) |  |  |  |       #if ENABLED(PID_ADD_EXTRUSION_RATE) | 
			
		
	
		
		
			
				
					
					|  |  |  |         static float cTerm[HOTENDS]; |  |  |  |         static float cTerm[HOTENDS]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         static long last_position[HOTENDS]; |  |  |  |         static long last_e_position; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         static long lpq[LPQ_MAX_LEN]; |  |  |  |         static long lpq[LPQ_MAX_LEN]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         static int lpq_ptr; |  |  |  |         static int lpq_ptr; | 
			
		
	
		
		
			
				
					
					|  |  |  |       #endif |  |  |  |       #endif | 
			
		
	
	
		
		
			
				
					|  |  | @ -247,11 +247,24 @@ class Temperature { | 
			
		
	
		
		
			
				
					
					|  |  |  |      * Preheating hotends |  |  |  |      * Preheating hotends | 
			
		
	
		
		
			
				
					
					|  |  |  |      */ |  |  |  |      */ | 
			
		
	
		
		
			
				
					
					|  |  |  |     #ifdef MILLISECONDS_PREHEAT_TIME |  |  |  |     #ifdef MILLISECONDS_PREHEAT_TIME | 
			
		
	
		
		
			
				
					
					|  |  |  |       static bool is_preheating(uint8_t hotend) { |  |  |  |       static bool is_preheating(uint8_t e) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         return preheat_end_time[hotend] && PENDING(millis(), preheat_end_time[hotend]); |  |  |  |         #if HOTENDS == 1 | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           UNUSED(e); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         return preheat_end_time[HOTEND_INDEX] && PENDING(millis(), preheat_end_time[HOTEND_INDEX]); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       static void start_preheat_time(uint8_t e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         #if HOTENDS == 1 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           UNUSED(e); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         preheat_end_time[HOTEND_INDEX] = millis() + MILLISECONDS_PREHEAT_TIME; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       static void reset_preheat_time(uint8_t e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         #if HOTENDS == 1 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           UNUSED(e); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         preheat_end_time[HOTEND_INDEX] = 0; | 
			
		
	
		
		
			
				
					
					|  |  |  |       } |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |       static void start_preheat_time(uint8_t hotend) { preheat_end_time[hotend] = millis() + MILLISECONDS_PREHEAT_TIME; } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       static void reset_preheat_time(uint8_t hotend) { preheat_end_time[hotend] = 0; } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     #else |  |  |  |     #else | 
			
		
	
		
		
			
				
					
					|  |  |  |       #define is_preheating(n) (false) |  |  |  |       #define is_preheating(n) (false) | 
			
		
	
		
		
			
				
					
					|  |  |  |     #endif |  |  |  |     #endif | 
			
		
	
	
		
		
			
				
					|  |  | @ -306,9 +319,9 @@ class Temperature { | 
			
		
	
		
		
			
				
					
					|  |  |  |       #endif |  |  |  |       #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |       #ifdef MILLISECONDS_PREHEAT_TIME |  |  |  |       #ifdef MILLISECONDS_PREHEAT_TIME | 
			
		
	
		
		
			
				
					
					|  |  |  |         if (celsius == 0.0f) |  |  |  |         if (celsius == 0.0f) | 
			
		
	
		
		
			
				
					
					|  |  |  |           reset_preheat_time(hotend); |  |  |  |           reset_preheat_time(HOTEND_INDEX); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         else if (target_temperature[hotend] == 0.0f) |  |  |  |         else if (target_temperature[HOTEND_INDEX] == 0.0f) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |           start_preheat_time(hotend); |  |  |  |           start_preheat_time(HOTEND_INDEX); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       #endif |  |  |  |       #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |       target_temperature[HOTEND_INDEX] = celsius; |  |  |  |       target_temperature[HOTEND_INDEX] = celsius; | 
			
		
	
		
		
			
				
					
					|  |  |  |       #if ENABLED(THERMAL_PROTECTION_HOTENDS) && WATCH_TEMP_PERIOD > 0 |  |  |  |       #if ENABLED(THERMAL_PROTECTION_HOTENDS) && WATCH_TEMP_PERIOD > 0 | 
			
		
	
	
		
		
			
				
					|  |  | 
 |