Browse Source
Soft PWM. (Sanguinololu can also have PID temperature control) Interrupt save WRITE for addresses > 0x0FFpull/1/head
11 changed files with 5525 additions and 5413 deletions
File diff suppressed because it is too large
File diff suppressed because it is too large
@ -1,143 +1,144 @@ |
|||||
/*
|
/*
|
||||
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 "fastio.h" |
#include "fastio.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; |
||||
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); |
||||
}; |
}; |
||||
|
|
||||
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 |
||||
|
|
||||
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 |
||||
} |
} |
||||
|
|
||||
void disable_heater(); |
int getHeaterPower(int heater); |
||||
void setWatch(); |
void disable_heater(); |
||||
void updatePID(); |
void setWatch(); |
||||
|
void updatePID(); |
||||
#endif |
|
||||
|
#endif |
||||
|
|
||||
|
File diff suppressed because it is too large
Loading…
Reference in new issue