Browse Source
M303 Starts autotune. Wait till the Kp Ki and Kd constants are printed. Put these values in Configuration.hpull/1/head
Erik van der Zalm
13 years ago
5 changed files with 274 additions and 169 deletions
@ -1,162 +1,165 @@ |
|||||
/*
|
/*
|
||||
temperature.h - temperature controller |
temperature.h - temperature controller |
||||
Part of Marlin |
Part of Marlin |
||||
|
|
||||
Copyright (c) 2011 Erik van der Zalm |
Copyright (c) 2011 Erik van der Zalm |
||||
|
|
||||
Grbl is free software: you can redistribute it and/or modify |
Grbl is free software: you can redistribute it and/or modify |
||||
it under the terms of the GNU General Public License as published by |
it under the terms of the GNU General Public License as published by |
||||
the Free Software Foundation, either version 3 of the License, or |
the Free Software Foundation, either version 3 of the License, or |
||||
(at your option) any later version. |
(at your option) any later version. |
||||
|
|
||||
Grbl is distributed in the hope that it will be useful, |
Grbl is distributed in the hope that it will be useful, |
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
GNU General Public License for more details. |
GNU General Public License for more details. |
||||
|
|
||||
You should have received a copy of the GNU General Public License |
You should have received a copy of the GNU General Public License |
||||
along with Grbl. If not, see <http://www.gnu.org/licenses/>.
|
along with Grbl. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/ |
*/ |
||||
|
|
||||
#ifndef temperature_h |
#ifndef temperature_h |
||||
#define temperature_h |
#define temperature_h |
||||
|
|
||||
#include "Marlin.h" |
#include "Marlin.h" |
||||
#include "planner.h" |
#include "planner.h" |
||||
#ifdef PID_ADD_EXTRUSION_RATE |
#ifdef PID_ADD_EXTRUSION_RATE |
||||
#include "stepper.h" |
#include "stepper.h" |
||||
#endif |
#endif |
||||
|
|
||||
// public functions
|
// public functions
|
||||
void tp_init(); //initialise the heating
|
void tp_init(); //initialise the heating
|
||||
void manage_heater(); //it is critical that this is called periodically.
|
void manage_heater(); //it is critical that this is called periodically.
|
||||
|
|
||||
//low leven conversion routines
|
//low leven conversion routines
|
||||
// do not use this routines and variables outsie of temperature.cpp
|
// do not use this routines and variables outsie of temperature.cpp
|
||||
int temp2analog(int celsius, uint8_t e); |
int temp2analog(int celsius, uint8_t e); |
||||
int temp2analogBed(int celsius); |
int temp2analogBed(int celsius); |
||||
float analog2temp(int raw, uint8_t e); |
float analog2temp(int raw, uint8_t e); |
||||
float analog2tempBed(int raw); |
float analog2tempBed(int raw); |
||||
extern int target_raw[EXTRUDERS]; |
extern int target_raw[EXTRUDERS]; |
||||
extern int heatingtarget_raw[EXTRUDERS]; |
extern int heatingtarget_raw[EXTRUDERS]; |
||||
extern int current_raw[EXTRUDERS]; |
extern int current_raw[EXTRUDERS]; |
||||
extern int target_raw_bed; |
extern int target_raw_bed; |
||||
extern int current_raw_bed; |
extern int current_raw_bed; |
||||
#ifdef BED_LIMIT_SWITCHING |
#ifdef BED_LIMIT_SWITCHING |
||||
extern int target_bed_low_temp ; |
extern int target_bed_low_temp ; |
||||
extern int target_bed_high_temp ; |
extern int target_bed_high_temp ; |
||||
#endif |
#endif |
||||
extern float Kp,Ki,Kd,Kc; |
extern float Kp,Ki,Kd,Kc; |
||||
|
|
||||
#ifdef PIDTEMP |
#ifdef PIDTEMP |
||||
extern float pid_setpoint[EXTRUDERS]; |
extern float pid_setpoint[EXTRUDERS]; |
||||
#endif |
#endif |
||||
|
|
||||
// #ifdef WATCHPERIOD
|
// #ifdef WATCHPERIOD
|
||||
extern int watch_raw[EXTRUDERS] ; |
extern int watch_raw[EXTRUDERS] ; |
||||
// extern unsigned long watchmillis;
|
// extern unsigned long watchmillis;
|
||||
// #endif
|
// #endif
|
||||
|
|
||||
|
|
||||
//high level conversion routines, for use outside of temperature.cpp
|
//high level conversion routines, for use outside of temperature.cpp
|
||||
//inline so that there is no performance decrease.
|
//inline so that there is no performance decrease.
|
||||
//deg=degreeCelsius
|
//deg=degreeCelsius
|
||||
|
|
||||
FORCE_INLINE float degHotend(uint8_t extruder) { |
FORCE_INLINE float degHotend(uint8_t extruder) { |
||||
return analog2temp(current_raw[extruder], extruder); |
return analog2temp(current_raw[extruder], extruder); |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE float degBed() { |
FORCE_INLINE float degBed() { |
||||
return analog2tempBed(current_raw_bed); |
return analog2tempBed(current_raw_bed); |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE float degTargetHotend(uint8_t extruder) { |
FORCE_INLINE float degTargetHotend(uint8_t extruder) { |
||||
return analog2temp(target_raw[extruder], extruder); |
return analog2temp(target_raw[extruder], extruder); |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE float degTargetBed() { |
FORCE_INLINE float degTargetBed() { |
||||
return analog2tempBed(target_raw_bed); |
return analog2tempBed(target_raw_bed); |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE void setTargetHotend(const float &celsius, uint8_t extruder) { |
FORCE_INLINE void setTargetHotend(const float &celsius, uint8_t extruder) { |
||||
target_raw[extruder] = temp2analog(celsius, extruder); |
target_raw[extruder] = temp2analog(celsius, extruder); |
||||
#ifdef PIDTEMP |
#ifdef PIDTEMP |
||||
pid_setpoint[extruder] = celsius; |
pid_setpoint[extruder] = celsius; |
||||
#endif //PIDTEMP
|
#endif //PIDTEMP
|
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE void setTargetBed(const float &celsius) { |
FORCE_INLINE void setTargetBed(const float &celsius) { |
||||
|
|
||||
target_raw_bed = temp2analogBed(celsius); |
target_raw_bed = temp2analogBed(celsius); |
||||
#ifdef BED_LIMIT_SWITCHING |
#ifdef BED_LIMIT_SWITCHING |
||||
if(celsius>BED_HYSTERESIS) |
if(celsius>BED_HYSTERESIS) |
||||
{ |
{ |
||||
target_bed_low_temp= temp2analogBed(celsius-BED_HYSTERESIS); |
target_bed_low_temp= temp2analogBed(celsius-BED_HYSTERESIS); |
||||
target_bed_high_temp= temp2analogBed(celsius+BED_HYSTERESIS); |
target_bed_high_temp= temp2analogBed(celsius+BED_HYSTERESIS); |
||||
} |
} |
||||
else |
else |
||||
{ |
{ |
||||
target_bed_low_temp=0; |
target_bed_low_temp=0; |
||||
target_bed_high_temp=0; |
target_bed_high_temp=0; |
||||
} |
} |
||||
#endif |
#endif |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE bool isHeatingHotend(uint8_t extruder){ |
FORCE_INLINE bool isHeatingHotend(uint8_t extruder){ |
||||
return target_raw[extruder] > current_raw[extruder]; |
return target_raw[extruder] > current_raw[extruder]; |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE bool isHeatingBed() { |
FORCE_INLINE bool isHeatingBed() { |
||||
return target_raw_bed > current_raw_bed; |
return target_raw_bed > current_raw_bed; |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE bool isCoolingHotend(uint8_t extruder) { |
FORCE_INLINE bool isCoolingHotend(uint8_t extruder) { |
||||
return target_raw[extruder] < current_raw[extruder]; |
return target_raw[extruder] < current_raw[extruder]; |
||||
}; |
}; |
||||
|
|
||||
FORCE_INLINE bool isCoolingBed() { |
FORCE_INLINE bool isCoolingBed() { |
||||
return target_raw_bed < current_raw_bed; |
return target_raw_bed < current_raw_bed; |
||||
}; |
}; |
||||
|
|
||||
#define degHotend0() degHotend(0) |
#define degHotend0() degHotend(0) |
||||
#define degTargetHotend0() degTargetHotend(0) |
#define degTargetHotend0() degTargetHotend(0) |
||||
#define setTargetHotend0(_celsius) setTargetHotend((_celsius), 0) |
#define setTargetHotend0(_celsius) setTargetHotend((_celsius), 0) |
||||
#define isHeatingHotend0() isHeatingHotend(0) |
#define isHeatingHotend0() isHeatingHotend(0) |
||||
#define isCoolingHotend0() isCoolingHotend(0) |
#define isCoolingHotend0() isCoolingHotend(0) |
||||
#if EXTRUDERS > 1 |
#if EXTRUDERS > 1 |
||||
#define degHotend1() degHotend(1) |
#define degHotend1() degHotend(1) |
||||
#define degTargetHotend1() degTargetHotend(1) |
#define degTargetHotend1() degTargetHotend(1) |
||||
#define setTargetHotend1(_celsius) setTargetHotend((_celsius), 1) |
#define setTargetHotend1(_celsius) setTargetHotend((_celsius), 1) |
||||
#define isHeatingHotend1() isHeatingHotend(1) |
#define isHeatingHotend1() isHeatingHotend(1) |
||||
#define isCoolingHotend1() isCoolingHotend(1) |
#define isCoolingHotend1() isCoolingHotend(1) |
||||
#endif |
#endif |
||||
#if EXTRUDERS > 2 |
#if EXTRUDERS > 2 |
||||
#define degHotend2() degHotend(2) |
#define degHotend2() degHotend(2) |
||||
#define degTargetHotend2() degTargetHotend(2) |
#define degTargetHotend2() degTargetHotend(2) |
||||
#define setTargetHotend2(_celsius) setTargetHotend((_celsius), 2) |
#define setTargetHotend2(_celsius) setTargetHotend((_celsius), 2) |
||||
#define isHeatingHotend2() isHeatingHotend(2) |
#define isHeatingHotend2() isHeatingHotend(2) |
||||
#define isCoolingHotend2() isCoolingHotend(2) |
#define isCoolingHotend2() isCoolingHotend(2) |
||||
#endif |
#endif |
||||
#if EXTRUDERS > 3 |
#if EXTRUDERS > 3 |
||||
#error Invalid number of extruders |
#error Invalid number of extruders |
||||
#endif |
#endif |
||||
|
|
||||
|
|
||||
|
|
||||
int getHeaterPower(int heater); |
int getHeaterPower(int heater); |
||||
void disable_heater(); |
void disable_heater(); |
||||
void setWatch(); |
void setWatch(); |
||||
void updatePID(); |
void updatePID(); |
||||
|
|
||||
FORCE_INLINE void autotempShutdown(){ |
FORCE_INLINE void autotempShutdown(){ |
||||
#ifdef AUTOTEMP |
#ifdef AUTOTEMP |
||||
if(autotemp_enabled) |
if(autotemp_enabled) |
||||
{ |
{ |
||||
autotemp_enabled=false; |
autotemp_enabled=false; |
||||
if(degTargetHotend(ACTIVE_EXTRUDER)>autotemp_min) |
if(degTargetHotend(ACTIVE_EXTRUDER)>autotemp_min) |
||||
setTargetHotend(0,ACTIVE_EXTRUDER); |
setTargetHotend(0,ACTIVE_EXTRUDER); |
||||
} |
} |
||||
#endif |
#endif |
||||
} |
} |
||||
#endif |
|
||||
|
void PID_autotune(float temp); |
||||
|
|
||||
|
#endif |
||||
|
|
||||
|
Loading…
Reference in new issue