Replace some float division with multiplication
This commit is contained in:
parent
ddde785b37
commit
d8f2876753
5 changed files with 20 additions and 18 deletions
|
@ -1332,7 +1332,7 @@ inline bool code_value_bool() { return code_value_byte() > 0; }
|
||||||
case TEMPUNIT_C:
|
case TEMPUNIT_C:
|
||||||
return code_value_float();
|
return code_value_float();
|
||||||
case TEMPUNIT_F:
|
case TEMPUNIT_F:
|
||||||
return (code_value_float() - 32) / 1.8;
|
return (code_value_float() - 32) * 0.5555555556;
|
||||||
case TEMPUNIT_K:
|
case TEMPUNIT_K:
|
||||||
return code_value_float() - 272.15;
|
return code_value_float() - 272.15;
|
||||||
default:
|
default:
|
||||||
|
@ -1346,7 +1346,7 @@ inline bool code_value_bool() { return code_value_byte() > 0; }
|
||||||
case TEMPUNIT_K:
|
case TEMPUNIT_K:
|
||||||
return code_value_float();
|
return code_value_float();
|
||||||
case TEMPUNIT_F:
|
case TEMPUNIT_F:
|
||||||
return code_value_float() / 1.8;
|
return code_value_float() * 0.5555555556;
|
||||||
default:
|
default:
|
||||||
return code_value_float();
|
return code_value_float();
|
||||||
}
|
}
|
||||||
|
@ -6141,7 +6141,7 @@ inline void gcode_M428() {
|
||||||
bool err = false;
|
bool err = false;
|
||||||
LOOP_XYZ(i) {
|
LOOP_XYZ(i) {
|
||||||
if (axis_homed[i]) {
|
if (axis_homed[i]) {
|
||||||
float base = (current_position[i] > (sw_endstop_min[i] + sw_endstop_max[i]) / 2) ? base_home_pos(i) : 0,
|
float base = (current_position[i] > (sw_endstop_min[i] + sw_endstop_max[i]) * 0.5) ? base_home_pos(i) : 0,
|
||||||
diff = current_position[i] - LOGICAL_POSITION(base, i);
|
diff = current_position[i] - LOGICAL_POSITION(base, i);
|
||||||
if (diff > -20 && diff < 20) {
|
if (diff > -20 && diff < 20) {
|
||||||
set_home_offset((AxisEnum)i, home_offset[i] - diff);
|
set_home_offset((AxisEnum)i, home_offset[i] - diff);
|
||||||
|
|
|
@ -814,7 +814,7 @@ void Planner::check_axes_activity() {
|
||||||
delta_mm[Z_AXIS] = dz * steps_to_mm[Z_AXIS];
|
delta_mm[Z_AXIS] = dz * steps_to_mm[Z_AXIS];
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
delta_mm[E_AXIS] = (de * steps_to_mm[E_AXIS]) * volumetric_multiplier[extruder] * extruder_multiplier[extruder] / 100.0;
|
delta_mm[E_AXIS] = 0.01 * (de * steps_to_mm[E_AXIS]) * volumetric_multiplier[extruder] * extruder_multiplier[extruder];
|
||||||
|
|
||||||
if (block->steps[X_AXIS] <= dropsegments && block->steps[Y_AXIS] <= dropsegments && block->steps[Z_AXIS] <= dropsegments) {
|
if (block->steps[X_AXIS] <= dropsegments && block->steps[Y_AXIS] <= dropsegments && block->steps[Z_AXIS] <= dropsegments) {
|
||||||
block->millimeters = fabs(delta_mm[E_AXIS]);
|
block->millimeters = fabs(delta_mm[E_AXIS]);
|
||||||
|
@ -888,7 +888,7 @@ void Planner::check_axes_activity() {
|
||||||
while (filwidth_delay_dist >= MMD_MM) filwidth_delay_dist -= MMD_MM;
|
while (filwidth_delay_dist >= MMD_MM) filwidth_delay_dist -= MMD_MM;
|
||||||
|
|
||||||
// Convert into an index into the measurement array
|
// Convert into an index into the measurement array
|
||||||
filwidth_delay_index1 = (int)(filwidth_delay_dist / 10.0 + 0.0001);
|
filwidth_delay_index1 = (int)(filwidth_delay_dist * 0.1 + 0.0001);
|
||||||
|
|
||||||
// If the index has changed (must have gone forward)...
|
// If the index has changed (must have gone forward)...
|
||||||
if (filwidth_delay_index1 != filwidth_delay_index2) {
|
if (filwidth_delay_index1 != filwidth_delay_index2) {
|
||||||
|
@ -975,7 +975,7 @@ void Planner::check_axes_activity() {
|
||||||
block->acceleration_steps_per_s2 = (max_acceleration_steps_per_s2[E_AXIS] * block->step_event_count) / block->steps[E_AXIS];
|
block->acceleration_steps_per_s2 = (max_acceleration_steps_per_s2[E_AXIS] * block->step_event_count) / block->steps[E_AXIS];
|
||||||
}
|
}
|
||||||
block->acceleration = block->acceleration_steps_per_s2 / steps_per_mm;
|
block->acceleration = block->acceleration_steps_per_s2 / steps_per_mm;
|
||||||
block->acceleration_rate = (long)(block->acceleration_steps_per_s2 * 16777216.0 / ((F_CPU) / 8.0));
|
block->acceleration_rate = (long)(block->acceleration_steps_per_s2 * 16777216.0 / ((F_CPU) * 0.125));
|
||||||
|
|
||||||
#if 0 // Use old jerk for now
|
#if 0 // Use old jerk for now
|
||||||
|
|
||||||
|
@ -1021,10 +1021,12 @@ void Planner::check_axes_activity() {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Start with a safe speed
|
// Start with a safe speed
|
||||||
float vmax_junction = max_xy_jerk / 2;
|
float vmax_junction = max_xy_jerk * 0.5,
|
||||||
float vmax_junction_factor = 1.0;
|
vmax_junction_factor = 1.0,
|
||||||
float mz2 = max_z_jerk / 2, me2 = max_e_jerk / 2;
|
mz2 = max_z_jerk * 0.5,
|
||||||
float csz = current_speed[Z_AXIS], cse = current_speed[E_AXIS];
|
me2 = max_e_jerk * 0.5,
|
||||||
|
csz = current_speed[Z_AXIS],
|
||||||
|
cse = current_speed[E_AXIS];
|
||||||
if (fabs(csz) > mz2) vmax_junction = min(vmax_junction, mz2);
|
if (fabs(csz) > mz2) vmax_junction = min(vmax_junction, mz2);
|
||||||
if (fabs(cse) > me2) vmax_junction = min(vmax_junction, me2);
|
if (fabs(cse) > me2) vmax_junction = min(vmax_junction, me2);
|
||||||
vmax_junction = min(vmax_junction, block->nominal_speed);
|
vmax_junction = min(vmax_junction, block->nominal_speed);
|
||||||
|
|
|
@ -944,7 +944,7 @@ float Stepper::get_axis_position_mm(AxisEnum axis) {
|
||||||
CRITICAL_SECTION_END;
|
CRITICAL_SECTION_END;
|
||||||
// ((a1+a2)+(a1-a2))/2 -> (a1+a2+a1-a2)/2 -> (a1+a1)/2 -> a1
|
// ((a1+a2)+(a1-a2))/2 -> (a1+a2+a1-a2)/2 -> (a1+a1)/2 -> a1
|
||||||
// ((a1+a2)-(a1-a2))/2 -> (a1+a2-a1+a2)/2 -> (a2+a2)/2 -> a2
|
// ((a1+a2)-(a1-a2))/2 -> (a1+a2-a1+a2)/2 -> (a2+a2)/2 -> a2
|
||||||
axis_steps = (pos1 + ((axis == CORE_AXIS_1) ? pos2 : -pos2)) / 2.0f;
|
axis_steps = (pos1 + ((axis == CORE_AXIS_1) ? pos2 : -pos2)) * 0.5f;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
axis_steps = position(axis);
|
axis_steps = position(axis);
|
||||||
|
@ -973,9 +973,9 @@ void Stepper::endstop_triggered(AxisEnum axis) {
|
||||||
|
|
||||||
float axis_pos = count_position[axis];
|
float axis_pos = count_position[axis];
|
||||||
if (axis == CORE_AXIS_1)
|
if (axis == CORE_AXIS_1)
|
||||||
axis_pos = (axis_pos + count_position[CORE_AXIS_2]) / 2;
|
axis_pos = (axis_pos + count_position[CORE_AXIS_2]) * 0.5;
|
||||||
else if (axis == CORE_AXIS_2)
|
else if (axis == CORE_AXIS_2)
|
||||||
axis_pos = (count_position[CORE_AXIS_1] - axis_pos) / 2;
|
axis_pos = (count_position[CORE_AXIS_1] - axis_pos) * 0.5;
|
||||||
endstops_trigsteps[axis] = axis_pos;
|
endstops_trigsteps[axis] = axis_pos;
|
||||||
|
|
||||||
#else // !COREXY && !COREXZ && !COREYZ
|
#else // !COREXY && !COREXZ && !COREYZ
|
||||||
|
|
|
@ -319,13 +319,13 @@ unsigned char Temperature::soft_pwm[HOTENDS];
|
||||||
SERIAL_PROTOCOLPAIR(MSG_T_MIN, min);
|
SERIAL_PROTOCOLPAIR(MSG_T_MIN, min);
|
||||||
SERIAL_PROTOCOLPAIR(MSG_T_MAX, max);
|
SERIAL_PROTOCOLPAIR(MSG_T_MAX, max);
|
||||||
if (cycles > 2) {
|
if (cycles > 2) {
|
||||||
Ku = (4.0 * d) / (3.14159265 * (max - min) / 2.0);
|
Ku = (4.0 * d) / (3.14159265 * (max - min) * 0.5);
|
||||||
Tu = ((float)(t_low + t_high) / 1000.0);
|
Tu = ((float)(t_low + t_high) * 0.001);
|
||||||
SERIAL_PROTOCOLPAIR(MSG_KU, Ku);
|
SERIAL_PROTOCOLPAIR(MSG_KU, Ku);
|
||||||
SERIAL_PROTOCOLPAIR(MSG_TU, Tu);
|
SERIAL_PROTOCOLPAIR(MSG_TU, Tu);
|
||||||
workKp = 0.6 * Ku;
|
workKp = 0.6 * Ku;
|
||||||
workKi = 2 * workKp / Tu;
|
workKi = 2 * workKp / Tu;
|
||||||
workKd = workKp * Tu / 8;
|
workKd = workKp * Tu * 0.125;
|
||||||
SERIAL_PROTOCOLLNPGM(MSG_CLASSIC_PID);
|
SERIAL_PROTOCOLLNPGM(MSG_CLASSIC_PID);
|
||||||
SERIAL_PROTOCOLPAIR(MSG_KP, workKp);
|
SERIAL_PROTOCOLPAIR(MSG_KP, workKp);
|
||||||
SERIAL_PROTOCOLPAIR(MSG_KI, workKi);
|
SERIAL_PROTOCOLPAIR(MSG_KI, workKi);
|
||||||
|
@ -753,7 +753,7 @@ void Temperature::manage_heater() {
|
||||||
// Get the delayed info and add 100 to reconstitute to a percent of
|
// Get the delayed info and add 100 to reconstitute to a percent of
|
||||||
// the nominal filament diameter then square it to get an area
|
// the nominal filament diameter then square it to get an area
|
||||||
meas_shift_index = constrain(meas_shift_index, 0, MAX_MEASUREMENT_DELAY);
|
meas_shift_index = constrain(meas_shift_index, 0, MAX_MEASUREMENT_DELAY);
|
||||||
float vm = pow((measurement_delay[meas_shift_index] + 100.0) / 100.0, 2);
|
float vm = pow((measurement_delay[meas_shift_index] + 100.0) * 0.01, 2);
|
||||||
NOLESS(vm, 0.01);
|
NOLESS(vm, 0.01);
|
||||||
volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM] = vm;
|
volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM] = vm;
|
||||||
}
|
}
|
||||||
|
|
|
@ -385,7 +385,7 @@ static void lcd_implementation_status_screen() {
|
||||||
// SD Card Progress bar and clock
|
// SD Card Progress bar and clock
|
||||||
if (IS_SD_PRINTING) {
|
if (IS_SD_PRINTING) {
|
||||||
// Progress bar solid part
|
// Progress bar solid part
|
||||||
u8g.drawBox(55, 50, (unsigned int)(71.f * card.percentDone() / 100.f), 2 - (TALL_FONT_CORRECTION));
|
u8g.drawBox(55, 50, (unsigned int)(71 * card.percentDone() * 0.01), 2 - (TALL_FONT_CORRECTION));
|
||||||
}
|
}
|
||||||
|
|
||||||
u8g.setPrintPos(80,48);
|
u8g.setPrintPos(80,48);
|
||||||
|
|
Reference in a new issue