Testing Fix for Arduino 1.6+ compiler issue #1523
This commit is contained in:
parent
08bc723a3c
commit
fb75a9272d
@ -215,7 +215,7 @@ Here are some standard links for getting your machine calibrated:
|
|||||||
// If your configuration is significantly different than this and you don't understand the issues involved, you probably
|
// If your configuration is significantly different than this and you don't understand the issues involved, you probably
|
||||||
// shouldn't use bed PID until someone else verifies your hardware works.
|
// shouldn't use bed PID until someone else verifies your hardware works.
|
||||||
// If this is enabled, find your own PID constants below.
|
// If this is enabled, find your own PID constants below.
|
||||||
//#define PIDTEMPBED
|
#define PIDTEMPBED
|
||||||
//
|
//
|
||||||
//#define BED_LIMIT_SWITCHING
|
//#define BED_LIMIT_SWITCHING
|
||||||
|
|
||||||
@ -226,17 +226,10 @@ Here are some standard links for getting your machine calibrated:
|
|||||||
#define MAX_BED_POWER 255 // limits duty cycle to bed; 255=full current
|
#define MAX_BED_POWER 255 // limits duty cycle to bed; 255=full current
|
||||||
|
|
||||||
#ifdef PIDTEMPBED
|
#ifdef PIDTEMPBED
|
||||||
//120v 250W silicone heater into 4mm borosilicate (MendelMax 1.5+)
|
// Felix Foil Heater
|
||||||
//from FOPDT model - kp=.39 Tp=405 Tdead=66, Tc set to 79.2, aggressive factor of .15 (vs .1, 1, 10)
|
#define DEFAULT_bedKp 103.37
|
||||||
#define DEFAULT_bedKp 10.00
|
#define DEFAULT_bedKi 2.79
|
||||||
#define DEFAULT_bedKi .023
|
#define DEFAULT_bedKd 956.94
|
||||||
#define DEFAULT_bedKd 305.4
|
|
||||||
|
|
||||||
//120v 250W silicone heater into 4mm borosilicate (MendelMax 1.5+)
|
|
||||||
//from pidautotune
|
|
||||||
// #define DEFAULT_bedKp 97.1
|
|
||||||
// #define DEFAULT_bedKi 1.41
|
|
||||||
// #define DEFAULT_bedKd 1675.16
|
|
||||||
|
|
||||||
// FIND YOUR OWN: "M303 E-1 C8 S90" to run autotune on the bed at 90 degreesC for 8 cycles.
|
// FIND YOUR OWN: "M303 E-1 C8 S90" to run autotune on the bed at 90 degreesC for 8 cycles.
|
||||||
#endif // PIDTEMPBED
|
#endif // PIDTEMPBED
|
||||||
@ -280,15 +273,15 @@ your extruder heater takes 2 minutes to hit the target on heating.
|
|||||||
// uncomment the 2 defines below:
|
// uncomment the 2 defines below:
|
||||||
|
|
||||||
// Parameters for all extruder heaters
|
// Parameters for all extruder heaters
|
||||||
//#define THERMAL_RUNAWAY_PROTECTION_PERIOD 40 //in seconds
|
#define THERMAL_RUNAWAY_PROTECTION_PERIOD 60 //in seconds
|
||||||
//#define THERMAL_RUNAWAY_PROTECTION_HYSTERESIS 4 // in degree Celsius
|
#define THERMAL_RUNAWAY_PROTECTION_HYSTERESIS 5 // in degree Celsius
|
||||||
|
|
||||||
// If you want to enable this feature for your bed heater,
|
// If you want to enable this feature for your bed heater,
|
||||||
// uncomment the 2 defines below:
|
// uncomment the 2 defines below:
|
||||||
|
|
||||||
// Parameters for the bed heater
|
// Parameters for the bed heater
|
||||||
//#define THERMAL_RUNAWAY_PROTECTION_BED_PERIOD 20 //in seconds
|
#define THERMAL_RUNAWAY_PROTECTION_BED_PERIOD 30 //in seconds
|
||||||
//#define THERMAL_RUNAWAY_PROTECTION_BED_HYSTERESIS 2 // in degree Celsius
|
#define THERMAL_RUNAWAY_PROTECTION_BED_HYSTERESIS 5// in degree Celsius
|
||||||
|
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -109,7 +109,7 @@ static volatile bool temp_meas_ready = false;
|
|||||||
static float temp_iState_min_bed;
|
static float temp_iState_min_bed;
|
||||||
static float temp_iState_max_bed;
|
static float temp_iState_max_bed;
|
||||||
#else //PIDTEMPBED
|
#else //PIDTEMPBED
|
||||||
static unsigned long previous_millis_bed_heater;
|
static unsigned long previous_millis_bed_heater;
|
||||||
#endif //PIDTEMPBED
|
#endif //PIDTEMPBED
|
||||||
static unsigned char soft_pwm[EXTRUDERS];
|
static unsigned char soft_pwm[EXTRUDERS];
|
||||||
|
|
||||||
@ -377,8 +377,8 @@ void updatePID()
|
|||||||
}
|
}
|
||||||
|
|
||||||
int getHeaterPower(int heater) {
|
int getHeaterPower(int heater) {
|
||||||
if (heater<0)
|
if (heater<0)
|
||||||
return soft_pwm_bed;
|
return soft_pwm_bed;
|
||||||
return soft_pwm[heater];
|
return soft_pwm[heater];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -527,12 +527,13 @@ void manage_heater()
|
|||||||
dTerm[e] = (PID_PARAM(Kd,e) * (pid_input - temp_dState[e]))*K2 + (K1 * dTerm[e]);
|
dTerm[e] = (PID_PARAM(Kd,e) * (pid_input - temp_dState[e]))*K2 + (K1 * dTerm[e]);
|
||||||
pid_output = pTerm[e] + iTerm[e] - dTerm[e];
|
pid_output = pTerm[e] + iTerm[e] - dTerm[e];
|
||||||
if (pid_output > PID_MAX) {
|
if (pid_output > PID_MAX) {
|
||||||
if (pid_error[e] > 0 ) temp_iState[e] -= pid_error[e]; // conditional un-integration
|
if (pid_error[e] > 0 ) temp_iState[e] -= pid_error[e];
|
||||||
pid_output=PID_MAX;
|
pid_output=PID_MAX;
|
||||||
} else if (pid_output < 0){
|
} else if (pid_output < 0){
|
||||||
if (pid_error[e] < 0 ) temp_iState[e] -= pid_error[e]; // conditional un-integration
|
if (pid_error[e] < 0 ) temp_iState[e] -= pid_error[e];
|
||||||
pid_output=0;
|
pid_output=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
temp_dState[e] = pid_input;
|
temp_dState[e] = pid_input;
|
||||||
#else
|
#else
|
||||||
@ -624,18 +625,18 @@ void manage_heater()
|
|||||||
pid_input = current_temperature_bed;
|
pid_input = current_temperature_bed;
|
||||||
|
|
||||||
#ifndef PID_OPENLOOP
|
#ifndef PID_OPENLOOP
|
||||||
pid_error_bed = target_temperature_bed - pid_input;
|
pid_error_bed = target_temperature_bed - pid_input;
|
||||||
pTerm_bed = bedKp * pid_error_bed;
|
pTerm_bed = bedKp * pid_error_bed;
|
||||||
temp_iState_bed += pid_error_bed;
|
temp_iState_bed += pid_error_bed;
|
||||||
temp_iState_bed = constrain(temp_iState_bed, temp_iState_min_bed, temp_iState_max_bed);
|
temp_iState_bed = constrain(temp_iState_bed, temp_iState_min_bed, temp_iState_max_bed);
|
||||||
iTerm_bed = bedKi * temp_iState_bed;
|
iTerm_bed = bedKi * temp_iState_bed;
|
||||||
|
|
||||||
//K1 defined in Configuration.h in the PID settings
|
//K1 defined in Configuration.h in the PID settings
|
||||||
#define K2 (1.0-K1)
|
#define K2 (1.0-K1)
|
||||||
dTerm_bed= (bedKd * (pid_input - temp_dState_bed))*K2 + (K1 * dTerm_bed);
|
dTerm_bed= (bedKd * (pid_input - temp_dState_bed))*K2 + (K1 * dTerm_bed);
|
||||||
temp_dState_bed = pid_input;
|
temp_dState_bed = pid_input;
|
||||||
|
|
||||||
pid_output = pTerm_bed + iTerm_bed - dTerm_bed;
|
pid_output = pTerm_bed + iTerm_bed - dTerm_bed;
|
||||||
if (pid_output > MAX_BED_POWER) {
|
if (pid_output > MAX_BED_POWER) {
|
||||||
if (pid_error_bed > 0 ) temp_iState_bed -= pid_error_bed; // conditional un-integration
|
if (pid_error_bed > 0 ) temp_iState_bed -= pid_error_bed; // conditional un-integration
|
||||||
pid_output=MAX_BED_POWER;
|
pid_output=MAX_BED_POWER;
|
||||||
@ -648,13 +649,13 @@ void manage_heater()
|
|||||||
pid_output = constrain(target_temperature_bed, 0, MAX_BED_POWER);
|
pid_output = constrain(target_temperature_bed, 0, MAX_BED_POWER);
|
||||||
#endif //PID_OPENLOOP
|
#endif //PID_OPENLOOP
|
||||||
|
|
||||||
if((current_temperature_bed > BED_MINTEMP) && (current_temperature_bed < BED_MAXTEMP))
|
if((current_temperature_bed > BED_MINTEMP) && (current_temperature_bed < BED_MAXTEMP))
|
||||||
{
|
{
|
||||||
soft_pwm_bed = (int)pid_output >> 1;
|
soft_pwm_bed = (int)pid_output >> 1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
soft_pwm_bed = 0;
|
soft_pwm_bed = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif !defined(BED_LIMIT_SWITCHING)
|
#elif !defined(BED_LIMIT_SWITCHING)
|
||||||
// Check if temperature is within the correct range
|
// Check if temperature is within the correct range
|
||||||
@ -698,23 +699,23 @@ void manage_heater()
|
|||||||
//code for controlling the extruder rate based on the width sensor
|
//code for controlling the extruder rate based on the width sensor
|
||||||
#ifdef FILAMENT_SENSOR
|
#ifdef FILAMENT_SENSOR
|
||||||
if(filament_sensor)
|
if(filament_sensor)
|
||||||
{
|
{
|
||||||
meas_shift_index=delay_index1-meas_delay_cm;
|
meas_shift_index=delay_index1-meas_delay_cm;
|
||||||
if(meas_shift_index<0)
|
if(meas_shift_index<0)
|
||||||
meas_shift_index = meas_shift_index + (MAX_MEASUREMENT_DELAY+1); //loop around buffer if needed
|
meas_shift_index = meas_shift_index + (MAX_MEASUREMENT_DELAY+1); //loop around buffer if needed
|
||||||
|
|
||||||
//get the delayed info and add 100 to reconstitute to a percent of the nominal filament diameter
|
//get the delayed info and add 100 to reconstitute to a percent of the nominal filament diameter
|
||||||
//then square it to get an area
|
//then square it to get an area
|
||||||
|
|
||||||
if(meas_shift_index<0)
|
if(meas_shift_index<0)
|
||||||
meas_shift_index=0;
|
meas_shift_index=0;
|
||||||
else if (meas_shift_index>MAX_MEASUREMENT_DELAY)
|
else if (meas_shift_index>MAX_MEASUREMENT_DELAY)
|
||||||
meas_shift_index=MAX_MEASUREMENT_DELAY;
|
meas_shift_index=MAX_MEASUREMENT_DELAY;
|
||||||
|
|
||||||
volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM] = pow((float)(100+measurement_delay[meas_shift_index])/100.0,2);
|
volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM] = pow((float)(100+measurement_delay[meas_shift_index])/100.0,2);
|
||||||
if (volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM] <0.01)
|
if (volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM] <0.01)
|
||||||
volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM]=0.01;
|
volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM]=0.01;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -838,9 +839,9 @@ float temp;
|
|||||||
|
|
||||||
temp=filament_width_meas;
|
temp=filament_width_meas;
|
||||||
if(filament_width_meas<MEASURED_LOWER_LIMIT)
|
if(filament_width_meas<MEASURED_LOWER_LIMIT)
|
||||||
temp=filament_width_nominal; //assume sensor cut out
|
temp=filament_width_nominal; //assume sensor cut out
|
||||||
else if (filament_width_meas>MEASURED_UPPER_LIMIT)
|
else if (filament_width_meas>MEASURED_UPPER_LIMIT)
|
||||||
temp= MEASURED_UPPER_LIMIT;
|
temp= MEASURED_UPPER_LIMIT;
|
||||||
|
|
||||||
|
|
||||||
return(filament_width_nominal/temp*100);
|
return(filament_width_nominal/temp*100);
|
||||||
@ -938,7 +939,7 @@ void tp_init()
|
|||||||
#if TEMP_1_PIN < 8
|
#if TEMP_1_PIN < 8
|
||||||
DIDR0 |= 1<<TEMP_1_PIN;
|
DIDR0 |= 1<<TEMP_1_PIN;
|
||||||
#else
|
#else
|
||||||
DIDR2 |= 1<<(TEMP_1_PIN - 8);
|
DIDR2 |= 1<<(TEMP_1_PIN - 8);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#if defined(TEMP_2_PIN) && (TEMP_2_PIN > -1)
|
#if defined(TEMP_2_PIN) && (TEMP_2_PIN > -1)
|
||||||
@ -1441,27 +1442,27 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (soft_pwm_0 > 0) {
|
if (soft_pwm_0 > 0) {
|
||||||
// turn ON heather only if the minimum time is up
|
// turn ON heather only if the minimum time is up
|
||||||
if (state_timer_heater_0 == 0) {
|
if (state_timer_heater_0 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_0 == 0) {
|
if (state_heater_0 == 0) {
|
||||||
state_timer_heater_0 = MIN_STATE_TIME;
|
state_timer_heater_0 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_0 = 1;
|
state_heater_0 = 1;
|
||||||
WRITE(HEATER_0_PIN, 1);
|
WRITE(HEATER_0_PIN, 1);
|
||||||
#ifdef HEATERS_PARALLEL
|
#ifdef HEATERS_PARALLEL
|
||||||
WRITE(HEATER_1_PIN, 1);
|
WRITE(HEATER_1_PIN, 1);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// turn OFF heather only if the minimum time is up
|
// turn OFF heather only if the minimum time is up
|
||||||
if (state_timer_heater_0 == 0) {
|
if (state_timer_heater_0 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_0 == 1) {
|
if (state_heater_0 == 1) {
|
||||||
state_timer_heater_0 = MIN_STATE_TIME;
|
state_timer_heater_0 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_0 = 0;
|
state_heater_0 = 0;
|
||||||
WRITE(HEATER_0_PIN, 0);
|
WRITE(HEATER_0_PIN, 0);
|
||||||
#ifdef HEATERS_PARALLEL
|
#ifdef HEATERS_PARALLEL
|
||||||
WRITE(HEATER_1_PIN, 0);
|
WRITE(HEATER_1_PIN, 0);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1472,22 +1473,22 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (soft_pwm_1 > 0) {
|
if (soft_pwm_1 > 0) {
|
||||||
// turn ON heather only if the minimum time is up
|
// turn ON heather only if the minimum time is up
|
||||||
if (state_timer_heater_1 == 0) {
|
if (state_timer_heater_1 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_1 == 0) {
|
if (state_heater_1 == 0) {
|
||||||
state_timer_heater_1 = MIN_STATE_TIME;
|
state_timer_heater_1 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_1 = 1;
|
state_heater_1 = 1;
|
||||||
WRITE(HEATER_1_PIN, 1);
|
WRITE(HEATER_1_PIN, 1);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// turn OFF heather only if the minimum time is up
|
// turn OFF heather only if the minimum time is up
|
||||||
if (state_timer_heater_1 == 0) {
|
if (state_timer_heater_1 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_1 == 1) {
|
if (state_heater_1 == 1) {
|
||||||
state_timer_heater_1 = MIN_STATE_TIME;
|
state_timer_heater_1 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_1 = 0;
|
state_heater_1 = 0;
|
||||||
WRITE(HEATER_1_PIN, 0);
|
WRITE(HEATER_1_PIN, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -1498,22 +1499,22 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (soft_pwm_2 > 0) {
|
if (soft_pwm_2 > 0) {
|
||||||
// turn ON heather only if the minimum time is up
|
// turn ON heather only if the minimum time is up
|
||||||
if (state_timer_heater_2 == 0) {
|
if (state_timer_heater_2 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_2 == 0) {
|
if (state_heater_2 == 0) {
|
||||||
state_timer_heater_2 = MIN_STATE_TIME;
|
state_timer_heater_2 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_2 = 1;
|
state_heater_2 = 1;
|
||||||
WRITE(HEATER_2_PIN, 1);
|
WRITE(HEATER_2_PIN, 1);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// turn OFF heather only if the minimum time is up
|
// turn OFF heather only if the minimum time is up
|
||||||
if (state_timer_heater_2 == 0) {
|
if (state_timer_heater_2 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_2 == 1) {
|
if (state_heater_2 == 1) {
|
||||||
state_timer_heater_2 = MIN_STATE_TIME;
|
state_timer_heater_2 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_2 = 0;
|
state_heater_2 = 0;
|
||||||
WRITE(HEATER_2_PIN, 0);
|
WRITE(HEATER_2_PIN, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -1524,22 +1525,22 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (soft_pwm_3 > 0) {
|
if (soft_pwm_3 > 0) {
|
||||||
// turn ON heather only if the minimum time is up
|
// turn ON heather only if the minimum time is up
|
||||||
if (state_timer_heater_3 == 0) {
|
if (state_timer_heater_3 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_3 == 0) {
|
if (state_heater_3 == 0) {
|
||||||
state_timer_heater_3 = MIN_STATE_TIME;
|
state_timer_heater_3 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_3 = 1;
|
state_heater_3 = 1;
|
||||||
WRITE(HEATER_3_PIN, 1);
|
WRITE(HEATER_3_PIN, 1);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// turn OFF heather only if the minimum time is up
|
// turn OFF heather only if the minimum time is up
|
||||||
if (state_timer_heater_3 == 0) {
|
if (state_timer_heater_3 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_3 == 1) {
|
if (state_heater_3 == 1) {
|
||||||
state_timer_heater_3 = MIN_STATE_TIME;
|
state_timer_heater_3 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_3 = 0;
|
state_heater_3 = 0;
|
||||||
WRITE(HEATER_3_PIN, 0);
|
WRITE(HEATER_3_PIN, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -1550,22 +1551,22 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (soft_pwm_b > 0) {
|
if (soft_pwm_b > 0) {
|
||||||
// turn ON heather only if the minimum time is up
|
// turn ON heather only if the minimum time is up
|
||||||
if (state_timer_heater_b == 0) {
|
if (state_timer_heater_b == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_b == 0) {
|
if (state_heater_b == 0) {
|
||||||
state_timer_heater_b = MIN_STATE_TIME;
|
state_timer_heater_b = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_b = 1;
|
state_heater_b = 1;
|
||||||
WRITE(HEATER_BED_PIN, 1);
|
WRITE(HEATER_BED_PIN, 1);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// turn OFF heather only if the minimum time is up
|
// turn OFF heather only if the minimum time is up
|
||||||
if (state_timer_heater_b == 0) {
|
if (state_timer_heater_b == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_b == 1) {
|
if (state_heater_b == 1) {
|
||||||
state_timer_heater_b = MIN_STATE_TIME;
|
state_timer_heater_b = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_b = 0;
|
state_heater_b = 0;
|
||||||
WRITE(HEATER_BED_PIN, 0);
|
WRITE(HEATER_BED_PIN, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -1577,7 +1578,7 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (state_timer_heater_0 == 0) {
|
if (state_timer_heater_0 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_0 == 1) {
|
if (state_heater_0 == 1) {
|
||||||
state_timer_heater_0 = MIN_STATE_TIME;
|
state_timer_heater_0 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_0 = 0;
|
state_heater_0 = 0;
|
||||||
WRITE(HEATER_0_PIN, 0);
|
WRITE(HEATER_0_PIN, 0);
|
||||||
@ -1594,7 +1595,7 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (state_timer_heater_1 == 0) {
|
if (state_timer_heater_1 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_1 == 1) {
|
if (state_heater_1 == 1) {
|
||||||
state_timer_heater_1 = MIN_STATE_TIME;
|
state_timer_heater_1 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_1 = 0;
|
state_heater_1 = 0;
|
||||||
WRITE(HEATER_1_PIN, 0);
|
WRITE(HEATER_1_PIN, 0);
|
||||||
@ -1609,7 +1610,7 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (state_timer_heater_2 == 0) {
|
if (state_timer_heater_2 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_2 == 1) {
|
if (state_heater_2 == 1) {
|
||||||
state_timer_heater_2 = MIN_STATE_TIME;
|
state_timer_heater_2 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_2 = 0;
|
state_heater_2 = 0;
|
||||||
WRITE(HEATER_2_PIN, 0);
|
WRITE(HEATER_2_PIN, 0);
|
||||||
@ -1624,7 +1625,7 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (state_timer_heater_3 == 0) {
|
if (state_timer_heater_3 == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_3 == 1) {
|
if (state_heater_3 == 1) {
|
||||||
state_timer_heater_3 = MIN_STATE_TIME;
|
state_timer_heater_3 = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_3 = 0;
|
state_heater_3 = 0;
|
||||||
WRITE(HEATER_3_PIN, 0);
|
WRITE(HEATER_3_PIN, 0);
|
||||||
@ -1639,7 +1640,7 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
if (state_timer_heater_b == 0) {
|
if (state_timer_heater_b == 0) {
|
||||||
// if change state set timer
|
// if change state set timer
|
||||||
if (state_heater_b == 1) {
|
if (state_heater_b == 1) {
|
||||||
state_timer_heater_b = MIN_STATE_TIME;
|
state_timer_heater_b = MIN_STATE_TIME;
|
||||||
}
|
}
|
||||||
state_heater_b = 0;
|
state_heater_b = 0;
|
||||||
WRITE(HEATER_BED_PIN, 0);
|
WRITE(HEATER_BED_PIN, 0);
|
||||||
@ -1809,7 +1810,7 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
//raw_filwidth_value += ADC; //remove to use an IIR filter approach
|
//raw_filwidth_value += ADC; //remove to use an IIR filter approach
|
||||||
if(ADC>102) //check that ADC is reading a voltage > 0.5 volts, otherwise don't take in the data.
|
if(ADC>102) //check that ADC is reading a voltage > 0.5 volts, otherwise don't take in the data.
|
||||||
{
|
{
|
||||||
raw_filwidth_value= raw_filwidth_value-(raw_filwidth_value>>7); //multipliy raw_filwidth_value by 127/128
|
raw_filwidth_value= raw_filwidth_value-(raw_filwidth_value>>7); //multipliy raw_filwidth_value by 127/128
|
||||||
|
|
||||||
raw_filwidth_value= raw_filwidth_value + ((unsigned long)ADC<<7); //add new ADC reading
|
raw_filwidth_value= raw_filwidth_value + ((unsigned long)ADC<<7); //add new ADC reading
|
||||||
}
|
}
|
||||||
@ -1974,12 +1975,12 @@ ISR(TIMER0_COMPB_vect)
|
|||||||
|
|
||||||
float scalePID_i(float i)
|
float scalePID_i(float i)
|
||||||
{
|
{
|
||||||
return i*PID_dT;
|
return i*PID_dT;
|
||||||
}
|
}
|
||||||
|
|
||||||
float unscalePID_i(float i)
|
float unscalePID_i(float i)
|
||||||
{
|
{
|
||||||
return i/PID_dT;
|
return i/PID_dT;
|
||||||
}
|
}
|
||||||
|
|
||||||
float scalePID_d(float d)
|
float scalePID_d(float d)
|
||||||
@ -1989,7 +1990,7 @@ float scalePID_d(float d)
|
|||||||
|
|
||||||
float unscalePID_d(float d)
|
float unscalePID_d(float d)
|
||||||
{
|
{
|
||||||
return d*PID_dT;
|
return d*PID_dT;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif //PIDTEMP
|
#endif //PIDTEMP
|
||||||
|
Loading…
x
Reference in New Issue
Block a user