| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 | /*  temperature.h - temperature controller  Part of Marlin  Copyright (c) 2011 Erik van der Zalm  Grbl is free software: you can redistribute it and/or modify  it under the terms of the GNU General Public License as published by  the Free Software Foundation, either version 3 of the License, or  (at your option) any later version.  Grbl is distributed in the hope that it will be useful,  but WITHOUT ANY WARRANTY; without even the implied warranty of  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  GNU General Public License for more details.  You should have received a copy of the GNU General Public License  along with Grbl.  If not, see <http://www.gnu.org/licenses/>.*/#ifndef temperature_h#define temperature_h #include "Marlin.h"#include "config.h"// public functionsvoid soft_pwm_init(); //initialize the soft pwm isrvoid temp_mgr_init(); //initialize the temperature handlervoid manage_heater(); //it is critical that this is called periodically.bool get_temp_error(); //return true if any thermal error is setextern bool checkAllHotends(void);// low level conversion routines// do not use these routines and variables outside of temperature.cppextern int target_temperature[EXTRUDERS];  extern float current_temperature[EXTRUDERS];#ifdef SHOW_TEMP_ADC_VALUES  extern int current_temperature_raw[EXTRUDERS];  extern int current_temperature_bed_raw;#endifextern int target_temperature_bed;extern float current_temperature_bed;#ifdef PINDA_THERMISTORextern uint16_t current_temperature_raw_pinda;extern float current_temperature_pinda;bool has_temperature_compensation();#endif#ifdef AMBIENT_THERMISTORextern int current_temperature_raw_ambient;extern float current_temperature_ambient;#endif#ifdef VOLT_PWR_PINextern int current_voltage_raw_pwr;#endif#ifdef VOLT_BED_PINextern int current_voltage_raw_bed;#endif#ifdef IR_SENSOR_ANALOGextern uint16_t current_voltage_raw_IR;#endif //IR_SENSOR_ANALOGextern bool bedPWMDisabled;#ifdef PIDTEMP  extern int pid_cycle, pid_number_of_cycles;  extern float _Kp,_Ki,_Kd;  float scalePID_i(float i);  float scalePID_d(float d);  float unscalePID_i(float i);  float unscalePID_d(float d);  bool pidTuningRunning(); // returns true if PID tuning is still running  void preparePidTuning(); // non-blocking call to set "pidTuningRunning" to true immediately#endif#ifdef BABYSTEPPINGextern volatile int babystepsTodo[3];inline void babystepsTodoZadd(int n){    if (n != 0) {        CRITICAL_SECTION_START        babystepsTodo[Z_AXIS] += n;        CRITICAL_SECTION_END    }}#endifvoid resetPID(uint8_t extruder);//high level conversion routines, for use outside of temperature.cpp//inline so that there is no performance decrease.//deg=degreeCelsius// Doesn't save FLASH when FORCE_INLINE removed.FORCE_INLINE float degHotend(uint8_t extruder) {    return current_temperature[extruder];};#ifdef SHOW_TEMP_ADC_VALUES  FORCE_INLINE float rawHotendTemp(uint8_t extruder) {      return current_temperature_raw[extruder];  };  FORCE_INLINE float rawBedTemp() {      return current_temperature_bed_raw;  };#endifFORCE_INLINE float degBed() {  return current_temperature_bed;};// Doesn't save FLASH when FORCE_INLINE removed.FORCE_INLINE float degTargetHotend(uint8_t extruder) {    return target_temperature[extruder];};FORCE_INLINE float degTargetBed() {     return target_temperature_bed;};// Doesn't save FLASH when FORCE_INLINE removed.FORCE_INLINE void setTargetHotend(const float &celsius, uint8_t extruder) {    target_temperature[extruder] = celsius;  resetPID(extruder);};// Doesn't save FLASH when not inlined.static inline void setTargetHotendSafe(const float &celsius, uint8_t extruder){    if (extruder<EXTRUDERS) {        setTargetHotend(celsius, extruder);    }}// Doesn't save FLASH when not inlined.static inline void setAllTargetHotends(const float &celsius){    for(uint8_t i = 0; i < EXTRUDERS; i++) setTargetHotend(celsius, i);}FORCE_INLINE void setTargetBed(const float &celsius) {    target_temperature_bed = celsius;};FORCE_INLINE bool isHeatingHotend(uint8_t extruder){    return target_temperature[extruder] > current_temperature[extruder];};FORCE_INLINE bool isHeatingBed() {  return target_temperature_bed > current_temperature_bed;};FORCE_INLINE bool isCoolingHotend(uint8_t extruder) {    return target_temperature[extruder] < current_temperature[extruder];};FORCE_INLINE bool isCoolingBed() {  return target_temperature_bed < current_temperature_bed;};#define degHotend0() degHotend(0)#define degTargetHotend0() degTargetHotend(0)#define setTargetHotend0(_celsius) setTargetHotend((_celsius), 0)#define isHeatingHotend0() isHeatingHotend(0)#define isCoolingHotend0() isCoolingHotend(0)#if EXTRUDERS > 1#define degHotend1() degHotend(1)#define degTargetHotend1() degTargetHotend(1)#define setTargetHotend1(_celsius) setTargetHotend((_celsius), 1)#define isHeatingHotend1() isHeatingHotend(1)#define isCoolingHotend1() isCoolingHotend(1)#else#define setTargetHotend1(_celsius) do{}while(0)#endif#if EXTRUDERS > 2#define degHotend2() degHotend(2)#define degTargetHotend2() degTargetHotend(2)#define setTargetHotend2(_celsius) setTargetHotend((_celsius), 2)#define isHeatingHotend2() isHeatingHotend(2)#define isCoolingHotend2() isCoolingHotend(2)#else#define setTargetHotend2(_celsius) do{}while(0)#endif#if EXTRUDERS > 3#error Invalid number of extruders#endif// return "false", if all heaters are 'off' (ie. "true", if any heater is 'on')#define CHECK_ALL_HEATERS (checkAllHotends()||(target_temperature_bed!=0))int getHeaterPower(int heater);void disable_heater(); // Disable all heaters *instantaneously*void updatePID();FORCE_INLINE void autotempShutdown(){ #ifdef AUTOTEMP if(autotemp_enabled) {  autotemp_enabled=false;  if(degTargetHotend(active_extruder)>autotemp_min)    setTargetHotend(0,active_extruder); } #endif}void PID_autotune(float temp, int extruder, int ncycles);#ifdef TEMP_MODELvoid temp_model_set_enabled(bool enabled);bool temp_model_valid();void temp_model_set_warn_beep(bool enabled);void temp_model_set_params(float C = NAN, float P = NAN, float Ta_corr = NAN, float warn = NAN, float err = NAN);void temp_model_set_resistance(uint8_t index, float R);void temp_model_report_settings();void temp_model_reset_settings();void temp_model_load_settings();void temp_model_save_settings();void temp_model_autotune(int16_t temp = 0, bool selftest = false);#ifdef TEMP_MODEL_DEBUGvoid temp_model_log_enable(bool enable);#endif#endif#ifdef FAN_SOFT_PWMextern unsigned char fanSpeedSoftPwm;#endifextern uint8_t fanSpeedBckp;#endif
 |