diff options
Diffstat (limited to 'klippy/kinematics/hybrid_corexy.py')
-rw-r--r-- | klippy/kinematics/hybrid_corexy.py | 88 |
1 files changed, 56 insertions, 32 deletions
diff --git a/klippy/kinematics/hybrid_corexy.py b/klippy/kinematics/hybrid_corexy.py index fd2621d5..2562ba33 100644 --- a/klippy/kinematics/hybrid_corexy.py +++ b/klippy/kinematics/hybrid_corexy.py @@ -7,61 +7,75 @@ import logging import stepper from . import idex_modes + # The hybrid-corexy kinematic is also known as Markforged kinematics class HybridCoreXYKinematics: def __init__(self, toolhead, config): self.printer = config.get_printer() # itersolve parameters - self.rails = [ stepper.LookupRail(config.getsection('stepper_x')), - stepper.LookupMultiRail(config.getsection('stepper_y')), - stepper.LookupMultiRail(config.getsection('stepper_z'))] - self.rails[1].get_endstops()[0][0].add_stepper( - self.rails[0].get_steppers()[0]) - self.rails[0].setup_itersolve('corexy_stepper_alloc', b'-') - self.rails[1].setup_itersolve('cartesian_stepper_alloc', b'y') - self.rails[2].setup_itersolve('cartesian_stepper_alloc', b'z') + self.rails = [ + stepper.LookupRail(config.getsection("stepper_x")), + stepper.LookupMultiRail(config.getsection("stepper_y")), + stepper.LookupMultiRail(config.getsection("stepper_z")), + ] + self.rails[1].get_endstops()[0][0].add_stepper(self.rails[0].get_steppers()[0]) + self.rails[0].setup_itersolve("corexy_stepper_alloc", b"-") + self.rails[1].setup_itersolve("cartesian_stepper_alloc", b"y") + self.rails[2].setup_itersolve("cartesian_stepper_alloc", b"z") ranges = [r.get_range() for r in self.rails] - 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_min = toolhead.Coord(*[r[0] for r in ranges], e=0.0) + self.axes_max = toolhead.Coord(*[r[1] for r in ranges], e=0.0) self.dc_module = None - if config.has_section('dual_carriage'): - dc_config = config.getsection('dual_carriage') + if config.has_section("dual_carriage"): + dc_config = config.getsection("dual_carriage") # dummy for cartesian config users - dc_config.getchoice('axis', ['x'], default='x') + dc_config.getchoice("axis", ["x"], default="x") # setup second dual carriage rail self.rails.append(stepper.LookupRail(dc_config)) self.rails[1].get_endstops()[0][0].add_stepper( - self.rails[3].get_steppers()[0]) - self.rails[3].setup_itersolve('corexy_stepper_alloc', b'+') + self.rails[3].get_steppers()[0] + ) + self.rails[3].setup_itersolve("corexy_stepper_alloc", b"+") self.dc_module = idex_modes.DualCarriages( - self.printer, [self.rails[0]], [self.rails[3]], axes=[0], - safe_dist=dc_config.getfloat( - 'safe_distance', None, minval=0.)) + self.printer, + [self.rails[0]], + [self.rails[3]], + axes=[0], + safe_dist=dc_config.getfloat("safe_distance", None, minval=0.0), + ) for s in self.get_steppers(): s.set_trapq(toolhead.get_trapq()) toolhead.register_step_generator(s.generate_steps) # Setup boundary checks max_velocity, max_accel = toolhead.get_max_velocity() self.max_z_velocity = config.getfloat( - 'max_z_velocity', max_velocity, above=0., maxval=max_velocity) + "max_z_velocity", max_velocity, above=0.0, maxval=max_velocity + ) self.max_z_accel = config.getfloat( - 'max_z_accel', max_accel, above=0., maxval=max_accel) + "max_z_accel", max_accel, above=0.0, maxval=max_accel + ) self.limits = [(1.0, -1.0)] * 3 + def get_steppers(self): return [s for rail in self.rails for s in rail.get_steppers()] + def calc_position(self, stepper_positions): pos = [stepper_positions[rail.get_name()] for rail in self.rails] - if (self.dc_module is not None and 'PRIMARY' == \ - self.dc_module.get_status()['carriage_1']): + if ( + self.dc_module is not None + and "PRIMARY" == self.dc_module.get_status()["carriage_1"] + ): return [pos[3] - pos[1], pos[1], pos[2]] else: return [pos[0] + pos[1], pos[1], pos[2]] + def update_limits(self, i, range): l, h = self.limits[i] # Only update limits if this axis was already homed, # otherwise leave in un-homed state. if l <= h: self.limits[i] = range + def set_position(self, newpos, homing_axes): for i, rail in enumerate(self.rails): rail.set_position(newpos) @@ -72,10 +86,12 @@ class HybridCoreXYKinematics: else: rail = self.rails[axis] self.limits[axis] = rail.get_range() + def clear_homing_state(self, clear_axes): for axis, axis_name in enumerate("xyz"): if axis_name in clear_axes: self.limits[axis] = (1.0, -1.0) + def home_axis(self, homing_state, axis, rail): position_min, position_max = rail.get_range() hi = rail.get_homing_info() @@ -88,26 +104,33 @@ class HybridCoreXYKinematics: forcepos[axis] += 1.5 * (position_max - hi.position_endstop) # Perform homing homing_state.home_rails([rail], forcepos, homepos) + def home(self, homing_state): for axis in homing_state.get_axes(): if self.dc_module is not None and axis == 0: self.dc_module.home(homing_state, axis) else: self.home_axis(homing_state, axis, self.rails[axis]) + def _check_endstops(self, move): end_pos = move.end_pos for i in (0, 1, 2): - if (move.axes_d[i] - and (end_pos[i] < self.limits[i][0] - or end_pos[i] > self.limits[i][1])): + if move.axes_d[i] and ( + end_pos[i] < self.limits[i][0] or end_pos[i] > self.limits[i][1] + ): if self.limits[i][0] > self.limits[i][1]: raise move.move_error("Must home axis first") raise move.move_error() + def check_move(self, move): limits = self.limits xpos, ypos = move.end_pos[:2] - if (xpos < limits[0][0] or xpos > limits[0][1] - or ypos < limits[1][0] or ypos > limits[1][1]): + if ( + xpos < limits[0][0] + or xpos > limits[0][1] + or ypos < limits[1][0] + or ypos > limits[1][1] + ): self._check_endstops(move) if not move.axes_d[2]: # Normal XY move - use defaults @@ -115,15 +138,16 @@ class HybridCoreXYKinematics: # Move with Z - update velocity and accel for slower Z axis self._check_endstops(move) z_ratio = move.move_d / abs(move.axes_d[2]) - move.limit_speed( - self.max_z_velocity * z_ratio, self.max_z_accel * z_ratio) + move.limit_speed(self.max_z_velocity * z_ratio, self.max_z_accel * z_ratio) + def get_status(self, eventtime): axes = [a for a, (l, h) in zip("xyz", self.limits) if l <= h] return { - 'homed_axes': "".join(axes), - 'axis_minimum': self.axes_min, - 'axis_maximum': self.axes_max + "homed_axes": "".join(axes), + "axis_minimum": self.axes_min, + "axis_maximum": self.axes_max, } + def load_kinematics(toolhead, config): return HybridCoreXYKinematics(toolhead, config) |