stepper: Add a get_name() method to PrinterStepper
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
d0590ccb0e
commit
544f8c1e85
|
@ -83,7 +83,7 @@ class ZTilt:
|
||||||
positions.append((stepper_offset, s))
|
positions.append((stepper_offset, s))
|
||||||
# Report on movements
|
# Report on movements
|
||||||
msg = "Making the following Z tilt adjustments:\n%s\nz_offset = %.6f" % (
|
msg = "Making the following Z tilt adjustments:\n%s\nz_offset = %.6f" % (
|
||||||
"\n".join(["%s = %.6f" % (s.name, so) for so, s in positions]),
|
"\n".join(["%s = %.6f" % (s.get_name(), so) for so, s in positions]),
|
||||||
z_adjust - z_offset)
|
z_adjust - z_offset)
|
||||||
logging.info(msg)
|
logging.info(msg)
|
||||||
self.gcode.respond_info(msg)
|
self.gcode.respond_info(msg)
|
||||||
|
|
|
@ -599,10 +599,11 @@ class GCodeParser:
|
||||||
return
|
return
|
||||||
kin = self.toolhead.get_kinematics()
|
kin = self.toolhead.get_kinematics()
|
||||||
steppers = kin.get_steppers()
|
steppers = kin.get_steppers()
|
||||||
mcu_pos = " ".join(["%s:%d" % (s.name, s.mcu_stepper.get_mcu_position())
|
mcu_pos = " ".join(["%s:%d" % (s.get_name(),
|
||||||
|
s.mcu_stepper.get_mcu_position())
|
||||||
for s in steppers])
|
for s in steppers])
|
||||||
stepper_pos = " ".join(
|
stepper_pos = " ".join(
|
||||||
["%s:%.6f" % (s.name, s.mcu_stepper.get_commanded_position())
|
["%s:%.6f" % (s.get_name(), s.mcu_stepper.get_commanded_position())
|
||||||
for s in steppers])
|
for s in steppers])
|
||||||
kinematic_pos = " ".join(["%s:%.6f" % (a, v)
|
kinematic_pos = " ".join(["%s:%.6f" % (a, v)
|
||||||
for a, v in zip("XYZE", kin.get_position())])
|
for a, v in zip("XYZE", kin.get_position())])
|
||||||
|
|
|
@ -37,8 +37,6 @@ class PrinterStepper:
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
printer = config.get_printer()
|
printer = config.get_printer()
|
||||||
self.name = config.get_name()
|
self.name = config.get_name()
|
||||||
if self.name.startswith('stepper_'):
|
|
||||||
self.name = self.name[8:]
|
|
||||||
self.need_motor_enable = True
|
self.need_motor_enable = True
|
||||||
# Stepper definition
|
# Stepper definition
|
||||||
ppins = printer.lookup_object('pins')
|
ppins = printer.lookup_object('pins')
|
||||||
|
@ -53,6 +51,10 @@ class PrinterStepper:
|
||||||
# Register STEPPER_BUZZ command
|
# Register STEPPER_BUZZ command
|
||||||
stepper_buzz = printer.try_load_module(config, 'stepper_buzz')
|
stepper_buzz = printer.try_load_module(config, 'stepper_buzz')
|
||||||
stepper_buzz.register_stepper(self, config.get_name())
|
stepper_buzz.register_stepper(self, config.get_name())
|
||||||
|
def get_name(self, short=False):
|
||||||
|
if short and self.name.startswith('stepper_'):
|
||||||
|
return self.name[8:]
|
||||||
|
return self.name
|
||||||
def _dist_to_time(self, dist, start_velocity, accel):
|
def _dist_to_time(self, dist, start_velocity, accel):
|
||||||
# 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
|
||||||
|
@ -136,8 +138,8 @@ class PrinterHomingStepper(PrinterStepper):
|
||||||
+ phase_offset)
|
+ phase_offset)
|
||||||
if es_pos != self.position_endstop:
|
if es_pos != self.position_endstop:
|
||||||
logging.info("Changing %s endstop position to %.3f"
|
logging.info("Changing %s endstop position to %.3f"
|
||||||
" (from %.3f)", self.name, es_pos,
|
" (from %.3f)", self.get_name(short=True),
|
||||||
self.position_endstop)
|
es_pos, self.position_endstop)
|
||||||
self.position_endstop = es_pos
|
self.position_endstop = es_pos
|
||||||
if endstop_accuracy is None:
|
if endstop_accuracy is None:
|
||||||
self.homing_endstop_accuracy = self.homing_stepper_phases//2 - 1
|
self.homing_endstop_accuracy = self.homing_stepper_phases//2 - 1
|
||||||
|
@ -149,7 +151,7 @@ class PrinterHomingStepper(PrinterStepper):
|
||||||
endstop_accuracy / self.step_dist))
|
endstop_accuracy / self.step_dist))
|
||||||
if self.homing_endstop_accuracy >= self.homing_stepper_phases // 2:
|
if self.homing_endstop_accuracy >= self.homing_stepper_phases // 2:
|
||||||
logging.info("Endstop for %s is not accurate enough for stepper"
|
logging.info("Endstop for %s is not accurate enough for stepper"
|
||||||
" phase adjustment", self.name)
|
" phase adjustment", self.get_name(short=True))
|
||||||
self.homing_stepper_phases = None
|
self.homing_stepper_phases = None
|
||||||
if self.mcu_endstop.get_mcu().is_fileoutput():
|
if self.mcu_endstop.get_mcu().is_fileoutput():
|
||||||
self.homing_endstop_accuracy = self.homing_stepper_phases
|
self.homing_endstop_accuracy = self.homing_stepper_phases
|
||||||
|
@ -158,14 +160,15 @@ class PrinterHomingStepper(PrinterStepper):
|
||||||
self.setup_itersolve(ffi_main.gc(
|
self.setup_itersolve(ffi_main.gc(
|
||||||
ffi_lib.cartesian_stepper_alloc(axis), ffi_lib.free))
|
ffi_lib.cartesian_stepper_alloc(axis), ffi_lib.free))
|
||||||
def get_endstops(self):
|
def get_endstops(self):
|
||||||
return [(self.mcu_endstop, self.name)]
|
return [(self.mcu_endstop, self.get_name(short=True))]
|
||||||
def get_homed_offset(self):
|
def get_homed_offset(self):
|
||||||
if not self.homing_stepper_phases or self.need_motor_enable:
|
if not self.homing_stepper_phases or self.need_motor_enable:
|
||||||
return 0.
|
return 0.
|
||||||
pos = self.mcu_stepper.get_mcu_position()
|
pos = self.mcu_stepper.get_mcu_position()
|
||||||
pos %= self.homing_stepper_phases
|
pos %= self.homing_stepper_phases
|
||||||
if self.homing_endstop_phase is None:
|
if self.homing_endstop_phase is None:
|
||||||
logging.info("Setting %s endstop phase to %d", self.name, pos)
|
logging.info("Setting %s endstop phase to %d",
|
||||||
|
self.get_name(short=True), pos)
|
||||||
self.homing_endstop_phase = pos
|
self.homing_endstop_phase = pos
|
||||||
return 0.
|
return 0.
|
||||||
delta = (pos - self.homing_endstop_phase) % self.homing_stepper_phases
|
delta = (pos - self.homing_endstop_phase) % self.homing_stepper_phases
|
||||||
|
@ -174,7 +177,7 @@ class PrinterHomingStepper(PrinterStepper):
|
||||||
elif delta > self.homing_endstop_accuracy:
|
elif delta > self.homing_endstop_accuracy:
|
||||||
raise homing.EndstopError(
|
raise homing.EndstopError(
|
||||||
"Endstop %s incorrect phase (got %d vs %d)" % (
|
"Endstop %s incorrect phase (got %d vs %d)" % (
|
||||||
self.name, pos, self.homing_endstop_phase))
|
self.get_name(short=True), pos, self.homing_endstop_phase))
|
||||||
return delta * self.step_dist
|
return delta * self.step_dist
|
||||||
|
|
||||||
# Wrapper for dual stepper motor support
|
# Wrapper for dual stepper motor support
|
||||||
|
@ -196,7 +199,7 @@ class PrinterMultiStepper(PrinterHomingStepper):
|
||||||
ppins = config.get_printer().lookup_object('pins')
|
ppins = config.get_printer().lookup_object('pins')
|
||||||
mcu_endstop = ppins.setup_pin('endstop', extraendstop)
|
mcu_endstop = ppins.setup_pin('endstop', extraendstop)
|
||||||
mcu_endstop.add_stepper(extra.mcu_stepper)
|
mcu_endstop.add_stepper(extra.mcu_stepper)
|
||||||
self.endstops.append((mcu_endstop, extra.name))
|
self.endstops.append((mcu_endstop, extra.get_name(short=True)))
|
||||||
else:
|
else:
|
||||||
self.mcu_endstop.add_stepper(extra.mcu_stepper)
|
self.mcu_endstop.add_stepper(extra.mcu_stepper)
|
||||||
self.step_itersolve = self.step_multi_itersolve
|
self.step_itersolve = self.step_multi_itersolve
|
||||||
|
|
Loading…
Reference in New Issue