stepper: Do not set min_stop_interval in micro-controller
The min_stop_interval safety check is fragile and leads to a notable amount of complexity. Avoid these issues by not programming this safety check. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
d1946fb6ed
commit
5a5ecd88e2
|
@ -12,7 +12,6 @@ class ExtruderStepper:
|
||||||
stepper_name = config.get_name().split()[1]
|
stepper_name = config.get_name().split()[1]
|
||||||
self.extruder_name = config.get('extruder', 'extruder')
|
self.extruder_name = config.get('extruder', 'extruder')
|
||||||
self.stepper = stepper.PrinterStepper(config)
|
self.stepper = stepper.PrinterStepper(config)
|
||||||
self.stepper.set_max_jerk(9999999.9, 9999999.9)
|
|
||||||
self.stepper.setup_itersolve('extruder_stepper_alloc')
|
self.stepper.setup_itersolve('extruder_stepper_alloc')
|
||||||
self.printer.register_event_handler("klippy:connect",
|
self.printer.register_event_handler("klippy:connect",
|
||||||
self.handle_connect)
|
self.handle_connect)
|
||||||
|
|
|
@ -28,7 +28,6 @@ class ManualStepper:
|
||||||
self.trapq_free_moves = ffi_lib.trapq_free_moves
|
self.trapq_free_moves = ffi_lib.trapq_free_moves
|
||||||
self.rail.setup_itersolve('cartesian_stepper_alloc', 'x')
|
self.rail.setup_itersolve('cartesian_stepper_alloc', 'x')
|
||||||
self.rail.set_trapq(self.trapq)
|
self.rail.set_trapq(self.trapq)
|
||||||
self.rail.set_max_jerk(9999999.9, 9999999.9)
|
|
||||||
# Register commands
|
# Register commands
|
||||||
stepper_name = config.get_name().split()[1]
|
stepper_name = config.get_name().split()[1]
|
||||||
gcode = self.printer.lookup_object('gcode')
|
gcode = self.printer.lookup_object('gcode')
|
||||||
|
|
|
@ -31,12 +31,6 @@ class CartKinematics:
|
||||||
ranges = [r.get_range() for r in self.rails]
|
ranges = [r.get_range() for r in self.rails]
|
||||||
self.axes_min = toolhead.Coord(*[r[0] for r in ranges], e=0.)
|
self.axes_min = toolhead.Coord(*[r[0] for r in ranges], e=0.)
|
||||||
self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.)
|
self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.)
|
||||||
# Setup stepper max halt velocity
|
|
||||||
max_halt_velocity = toolhead.get_max_axis_halt()
|
|
||||||
self.rails[0].set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
self.rails[1].set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
self.rails[2].set_max_jerk(min(max_halt_velocity, self.max_z_velocity),
|
|
||||||
max_accel)
|
|
||||||
# Check for dual carriage support
|
# Check for dual carriage support
|
||||||
if config.has_section('dual_carriage'):
|
if config.has_section('dual_carriage'):
|
||||||
dc_config = config.getsection('dual_carriage')
|
dc_config = config.getsection('dual_carriage')
|
||||||
|
@ -46,7 +40,6 @@ class CartKinematics:
|
||||||
dc_rail.setup_itersolve('cartesian_stepper_alloc', dc_axis)
|
dc_rail.setup_itersolve('cartesian_stepper_alloc', dc_axis)
|
||||||
for s in dc_rail.get_steppers():
|
for s in dc_rail.get_steppers():
|
||||||
toolhead.register_step_generator(s.generate_steps)
|
toolhead.register_step_generator(s.generate_steps)
|
||||||
dc_rail.set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
self.dual_carriage_rails = [
|
self.dual_carriage_rails = [
|
||||||
self.rails[self.dual_carriage_axis], dc_rail]
|
self.rails[self.dual_carriage_axis], dc_rail]
|
||||||
self.printer.lookup_object('gcode').register_command(
|
self.printer.lookup_object('gcode').register_command(
|
||||||
|
|
|
@ -34,14 +34,6 @@ class CoreXYKinematics:
|
||||||
ranges = [r.get_range() for r in self.rails]
|
ranges = [r.get_range() for r in self.rails]
|
||||||
self.axes_min = toolhead.Coord(*[r[0] for r in ranges], e=0.)
|
self.axes_min = toolhead.Coord(*[r[0] for r in ranges], e=0.)
|
||||||
self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.)
|
self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.)
|
||||||
# Setup stepper max halt velocity
|
|
||||||
max_halt_velocity = toolhead.get_max_axis_halt()
|
|
||||||
max_xy_halt_velocity = max_halt_velocity * math.sqrt(2.)
|
|
||||||
max_xy_accel = max_accel * math.sqrt(2.)
|
|
||||||
self.rails[0].set_max_jerk(max_xy_halt_velocity, max_xy_accel)
|
|
||||||
self.rails[1].set_max_jerk(max_xy_halt_velocity, max_xy_accel)
|
|
||||||
self.rails[2].set_max_jerk(
|
|
||||||
min(max_halt_velocity, self.max_z_velocity), self.max_z_accel)
|
|
||||||
def get_steppers(self):
|
def get_steppers(self):
|
||||||
return [s for rail in self.rails for s in rail.get_steppers()]
|
return [s for rail in self.rails for s in rail.get_steppers()]
|
||||||
def calc_tag_position(self):
|
def calc_tag_position(self):
|
||||||
|
|
|
@ -34,13 +34,6 @@ class CoreXZKinematics:
|
||||||
ranges = [r.get_range() for r in self.rails]
|
ranges = [r.get_range() for r in self.rails]
|
||||||
self.axes_min = toolhead.Coord(*[r[0] for r in ranges], e=0.)
|
self.axes_min = toolhead.Coord(*[r[0] for r in ranges], e=0.)
|
||||||
self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.)
|
self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.)
|
||||||
# Setup stepper max halt velocity
|
|
||||||
max_halt_velocity = toolhead.get_max_axis_halt()
|
|
||||||
max_xy_halt_velocity = max_halt_velocity * math.sqrt(2.)
|
|
||||||
max_xy_accel = max_accel * math.sqrt(2.)
|
|
||||||
self.rails[0].set_max_jerk(max_xy_halt_velocity, max_xy_accel)
|
|
||||||
self.rails[1].set_max_jerk(max_xy_halt_velocity, max_xy_accel)
|
|
||||||
self.rails[2].set_max_jerk(max_xy_halt_velocity, max_xy_accel)
|
|
||||||
def get_steppers(self):
|
def get_steppers(self):
|
||||||
return [s for rail in self.rails for s in rail.get_steppers()]
|
return [s for rail in self.rails for s in rail.get_steppers()]
|
||||||
def calc_tag_position(self):
|
def calc_tag_position(self):
|
||||||
|
|
|
@ -25,15 +25,11 @@ class DeltaKinematics:
|
||||||
self.rails = [rail_a, rail_b, rail_c]
|
self.rails = [rail_a, rail_b, rail_c]
|
||||||
config.get_printer().register_event_handler("stepper_enable:motor_off",
|
config.get_printer().register_event_handler("stepper_enable:motor_off",
|
||||||
self._motor_off)
|
self._motor_off)
|
||||||
# Setup stepper max halt velocity
|
# Setup max velocity
|
||||||
self.max_velocity, self.max_accel = toolhead.get_max_velocity()
|
self.max_velocity, self.max_accel = toolhead.get_max_velocity()
|
||||||
self.max_z_velocity = config.getfloat(
|
self.max_z_velocity = config.getfloat(
|
||||||
'max_z_velocity', self.max_velocity,
|
'max_z_velocity', self.max_velocity,
|
||||||
above=0., maxval=self.max_velocity)
|
above=0., maxval=self.max_velocity)
|
||||||
max_halt_velocity = toolhead.get_max_axis_halt() * SLOW_RATIO
|
|
||||||
max_halt_accel = self.max_accel * SLOW_RATIO
|
|
||||||
for rail in self.rails:
|
|
||||||
rail.set_max_jerk(max_halt_velocity, max_halt_accel)
|
|
||||||
# Read radius and arm lengths
|
# Read radius and arm lengths
|
||||||
self.radius = radius = config.getfloat('delta_radius', above=0.)
|
self.radius = radius = config.getfloat('delta_radius', above=0.)
|
||||||
print_radius = config.getfloat('print_radius', radius, above=0.)
|
print_radius = config.getfloat('print_radius', radius, above=0.)
|
||||||
|
|
|
@ -36,7 +36,6 @@ class PrinterExtruder:
|
||||||
self.max_e_accel = config.getfloat(
|
self.max_e_accel = config.getfloat(
|
||||||
'max_extrude_only_accel', max_accel * def_max_extrude_ratio
|
'max_extrude_only_accel', max_accel * def_max_extrude_ratio
|
||||||
, above=0.)
|
, above=0.)
|
||||||
self.stepper.set_max_jerk(9999999.9, 9999999.9)
|
|
||||||
self.max_e_dist = config.getfloat(
|
self.max_e_dist = config.getfloat(
|
||||||
'max_extrude_only_distance', 50., minval=0.)
|
'max_extrude_only_distance', 50., minval=0.)
|
||||||
self.instant_corner_v = config.getfloat(
|
self.instant_corner_v = config.getfloat(
|
||||||
|
|
|
@ -36,11 +36,6 @@ class PolarKinematics:
|
||||||
min_z, max_z = self.rails[1].get_range()
|
min_z, max_z = self.rails[1].get_range()
|
||||||
self.axes_min = toolhead.Coord(-max_xy, -max_xy, min_z, 0.)
|
self.axes_min = toolhead.Coord(-max_xy, -max_xy, min_z, 0.)
|
||||||
self.axes_max = toolhead.Coord(max_xy, max_xy, max_z, 0.)
|
self.axes_max = toolhead.Coord(max_xy, max_xy, max_z, 0.)
|
||||||
# Setup stepper max halt velocity
|
|
||||||
max_halt_velocity = toolhead.get_max_axis_halt()
|
|
||||||
stepper_bed.set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
rail_arm.set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
rail_z.set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
def get_steppers(self):
|
def get_steppers(self):
|
||||||
return list(self.steppers)
|
return list(self.steppers)
|
||||||
def calc_tag_position(self):
|
def calc_tag_position(self):
|
||||||
|
|
|
@ -23,13 +23,10 @@ class RotaryDeltaKinematics:
|
||||||
self.rails = [rail_a, rail_b, rail_c]
|
self.rails = [rail_a, rail_b, rail_c]
|
||||||
config.get_printer().register_event_handler("stepper_enable:motor_off",
|
config.get_printer().register_event_handler("stepper_enable:motor_off",
|
||||||
self._motor_off)
|
self._motor_off)
|
||||||
# Setup stepper max halt velocity
|
# Read config
|
||||||
max_velocity, max_accel = toolhead.get_max_velocity()
|
max_velocity, max_accel = toolhead.get_max_velocity()
|
||||||
self.max_z_velocity = config.getfloat('max_z_velocity', max_velocity,
|
self.max_z_velocity = config.getfloat('max_z_velocity', max_velocity,
|
||||||
above=0., maxval=max_velocity)
|
above=0., maxval=max_velocity)
|
||||||
for rail in self.rails:
|
|
||||||
rail.set_max_jerk(9999999.9, 9999999.9)
|
|
||||||
# Read config
|
|
||||||
shoulder_radius = config.getfloat('shoulder_radius', above=0.)
|
shoulder_radius = config.getfloat('shoulder_radius', above=0.)
|
||||||
shoulder_height = config.getfloat('shoulder_height', above=0.)
|
shoulder_height = config.getfloat('shoulder_height', above=0.)
|
||||||
a_upper_arm = stepper_configs[0].getfloat('upper_arm_length', above=0.)
|
a_upper_arm = stepper_configs[0].getfloat('upper_arm_length', above=0.)
|
||||||
|
|
|
@ -22,11 +22,6 @@ class WinchKinematics:
|
||||||
s.setup_itersolve('winch_stepper_alloc', *a)
|
s.setup_itersolve('winch_stepper_alloc', *a)
|
||||||
s.set_trapq(toolhead.get_trapq())
|
s.set_trapq(toolhead.get_trapq())
|
||||||
toolhead.register_step_generator(s.generate_steps)
|
toolhead.register_step_generator(s.generate_steps)
|
||||||
# Setup stepper max halt velocity
|
|
||||||
max_velocity, max_accel = toolhead.get_max_velocity()
|
|
||||||
max_halt_velocity = toolhead.get_max_axis_halt()
|
|
||||||
for s in self.steppers:
|
|
||||||
s.set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
# Setup boundary checks
|
# Setup boundary checks
|
||||||
acoords = list(zip(*self.anchors))
|
acoords = list(zip(*self.anchors))
|
||||||
self.axes_min = toolhead.Coord(*[min(a) for a in acoords], e=0.)
|
self.axes_min = toolhead.Coord(*[min(a) for a in acoords], e=0.)
|
||||||
|
|
|
@ -32,7 +32,6 @@ class MCU_stepper:
|
||||||
self._dir_pin = dir_pin_params['pin']
|
self._dir_pin = dir_pin_params['pin']
|
||||||
self._invert_dir = dir_pin_params['invert']
|
self._invert_dir = dir_pin_params['invert']
|
||||||
self._mcu_position_offset = self._tag_position = 0.
|
self._mcu_position_offset = self._tag_position = 0.
|
||||||
self._min_stop_interval = 0.
|
|
||||||
self._reset_cmd_tag = self._get_position_cmd = None
|
self._reset_cmd_tag = self._get_position_cmd = None
|
||||||
self._active_callbacks = []
|
self._active_callbacks = []
|
||||||
ffi_main, ffi_lib = chelper.get_ffi()
|
ffi_main, ffi_lib = chelper.get_ffi()
|
||||||
|
@ -56,26 +55,15 @@ class MCU_stepper:
|
||||||
# Calculate the time it takes to travel a distance with constant accel
|
# Calculate the time it takes to travel a distance with constant accel
|
||||||
time_offset = start_velocity / accel
|
time_offset = start_velocity / accel
|
||||||
return math.sqrt(2. * dist / accel + time_offset**2) - time_offset
|
return math.sqrt(2. * dist / accel + time_offset**2) - time_offset
|
||||||
def set_max_jerk(self, max_halt_velocity, max_accel):
|
|
||||||
# Calculate the firmware's maximum halt interval time
|
|
||||||
last_step_time = self._dist_to_time(self._step_dist,
|
|
||||||
max_halt_velocity, max_accel)
|
|
||||||
second_last_step_time = self._dist_to_time(2. * self._step_dist,
|
|
||||||
max_halt_velocity, max_accel)
|
|
||||||
self._min_stop_interval = second_last_step_time - last_step_time
|
|
||||||
def setup_itersolve(self, alloc_func, *params):
|
def setup_itersolve(self, alloc_func, *params):
|
||||||
ffi_main, ffi_lib = chelper.get_ffi()
|
ffi_main, ffi_lib = chelper.get_ffi()
|
||||||
sk = ffi_main.gc(getattr(ffi_lib, alloc_func)(*params), ffi_lib.free)
|
sk = ffi_main.gc(getattr(ffi_lib, alloc_func)(*params), ffi_lib.free)
|
||||||
self.set_stepper_kinematics(sk)
|
self.set_stepper_kinematics(sk)
|
||||||
def _build_config(self):
|
def _build_config(self):
|
||||||
max_error = self._mcu.get_max_stepper_error()
|
|
||||||
min_stop_interval = max(0., self._min_stop_interval - max_error)
|
|
||||||
self._mcu.add_config_cmd(
|
self._mcu.add_config_cmd(
|
||||||
"config_stepper oid=%d step_pin=%s dir_pin=%s"
|
"config_stepper oid=%d step_pin=%s dir_pin=%s"
|
||||||
" min_stop_interval=%d invert_step=%d" % (
|
" min_stop_interval=0 invert_step=%d" % (
|
||||||
self._oid, self._step_pin, self._dir_pin,
|
self._oid, self._step_pin, self._dir_pin, self._invert_step))
|
||||||
self._mcu.seconds_to_clock(min_stop_interval),
|
|
||||||
self._invert_step))
|
|
||||||
self._mcu.add_config_cmd("reset_step_clock oid=%d clock=0"
|
self._mcu.add_config_cmd("reset_step_clock oid=%d clock=0"
|
||||||
% (self._oid,), on_restart=True)
|
% (self._oid,), on_restart=True)
|
||||||
step_cmd_tag = self._mcu.lookup_command_tag(
|
step_cmd_tag = self._mcu.lookup_command_tag(
|
||||||
|
@ -87,6 +75,7 @@ class MCU_stepper:
|
||||||
self._get_position_cmd = self._mcu.lookup_query_command(
|
self._get_position_cmd = self._mcu.lookup_query_command(
|
||||||
"stepper_get_position oid=%c",
|
"stepper_get_position oid=%c",
|
||||||
"stepper_position oid=%c pos=%i", oid=self._oid)
|
"stepper_position oid=%c pos=%i", oid=self._oid)
|
||||||
|
max_error = self._mcu.get_max_stepper_error()
|
||||||
ffi_main, ffi_lib = chelper.get_ffi()
|
ffi_main, ffi_lib = chelper.get_ffi()
|
||||||
ffi_lib.stepcompress_fill(self._stepqueue,
|
ffi_lib.stepcompress_fill(self._stepqueue,
|
||||||
self._mcu.seconds_to_clock(max_error),
|
self._mcu.seconds_to_clock(max_error),
|
||||||
|
@ -360,9 +349,6 @@ class PrinterRail:
|
||||||
def set_trapq(self, trapq):
|
def set_trapq(self, trapq):
|
||||||
for stepper in self.steppers:
|
for stepper in self.steppers:
|
||||||
stepper.set_trapq(trapq)
|
stepper.set_trapq(trapq)
|
||||||
def set_max_jerk(self, max_halt_velocity, max_accel):
|
|
||||||
for stepper in self.steppers:
|
|
||||||
stepper.set_max_jerk(max_halt_velocity, max_accel)
|
|
||||||
def set_position(self, coord):
|
def set_position(self, coord):
|
||||||
for stepper in self.steppers:
|
for stepper in self.steppers:
|
||||||
stepper.set_position(coord)
|
stepper.set_position(coord)
|
||||||
|
|
|
@ -539,12 +539,6 @@ class ToolHead:
|
||||||
self.last_kin_move_time = max(self.last_kin_move_time, kin_time)
|
self.last_kin_move_time = max(self.last_kin_move_time, kin_time)
|
||||||
def get_max_velocity(self):
|
def get_max_velocity(self):
|
||||||
return self.max_velocity, self.max_accel
|
return self.max_velocity, self.max_accel
|
||||||
def get_max_axis_halt(self):
|
|
||||||
# Determine the maximum velocity a cartesian axis could halt
|
|
||||||
# at due to the junction_deviation setting. The 8.0 was
|
|
||||||
# determined experimentally.
|
|
||||||
return min(self.max_velocity,
|
|
||||||
math.sqrt(8. * self.junction_deviation * self.max_accel))
|
|
||||||
def _calc_junction_deviation(self):
|
def _calc_junction_deviation(self):
|
||||||
scv2 = self.square_corner_velocity**2
|
scv2 = self.square_corner_velocity**2
|
||||||
self.junction_deviation = scv2 * (math.sqrt(2.) - 1.) / self.max_accel
|
self.junction_deviation = scv2 * (math.sqrt(2.) - 1.) / self.max_accel
|
||||||
|
|
Loading…
Reference in New Issue