probe: Use new GCodeCommand wrappers

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-04-24 21:51:33 -04:00
parent 1746148a45
commit ff6c11e827
1 changed files with 45 additions and 53 deletions

View File

@ -98,10 +98,9 @@ class PrinterProbe:
if pin_params['invert'] or pin_params['pullup']: if pin_params['invert'] or pin_params['pullup']:
raise pins.error("Can not pullup/invert probe virtual endstop") raise pins.error("Can not pullup/invert probe virtual endstop")
return self.mcu_probe return self.mcu_probe
def get_lift_speed(self, params=None): def get_lift_speed(self, gcmd=None):
if params is not None: if gcmd is not None:
return self.gcode.get_float("LIFT_SPEED", params, return gcmd.get_float("LIFT_SPEED", self.lift_speed, above=0.)
self.lift_speed, above=0.)
return self.lift_speed return self.lift_speed
def get_offsets(self): def get_offsets(self):
return self.x_offset, self.y_offset, self.z_offset return self.x_offset, self.y_offset, self.z_offset
@ -121,8 +120,8 @@ class PrinterProbe:
reason += HINT_TIMEOUT reason += HINT_TIMEOUT
raise homing.CommandError(reason) raise homing.CommandError(reason)
pos = toolhead.get_position() pos = toolhead.get_position()
self.gcode.respond_info("probe at %.3f,%.3f is z=%.6f" % ( self.gcode.respond_info("probe at %.3f,%.3f is z=%.6f"
pos[0], pos[1], pos[2])) % (pos[0], pos[1], pos[2]))
self.gcode.reset_last_position() self.gcode.reset_last_position()
return pos[:3] return pos[:3]
def _move(self, coord, speed): def _move(self, coord, speed):
@ -145,20 +144,17 @@ class PrinterProbe:
return z_sorted[middle] return z_sorted[middle]
# even number of samples # even number of samples
return self._calc_mean(z_sorted[middle-1:middle+1]) return self._calc_mean(z_sorted[middle-1:middle+1])
def run_probe(self, params={}): def run_probe(self, gcmd):
speed = self.gcode.get_float( speed = gcmd.get_float("PROBE_SPEED", self.speed, above=0.)
"PROBE_SPEED", params, self.speed, above=0.) lift_speed = self.get_lift_speed(gcmd)
lift_speed = self.get_lift_speed(params) sample_count = gcmd.get_int("SAMPLES", self.sample_count, minval=1)
sample_count = self.gcode.get_int( sample_retract_dist = gcmd.get_float("SAMPLE_RETRACT_DIST",
"SAMPLES", params, self.sample_count, minval=1) self.sample_retract_dist, above=0.)
sample_retract_dist = self.gcode.get_float( samples_tolerance = gcmd.get_float("SAMPLES_TOLERANCE",
"SAMPLE_RETRACT_DIST", params, self.sample_retract_dist, above=0.) self.samples_tolerance, minval=0.)
samples_tolerance = self.gcode.get_float( samples_retries = gcmd.get_int("SAMPLES_TOLERANCE_RETRIES",
"SAMPLES_TOLERANCE", params, self.samples_tolerance, minval=0.) self.samples_retries, minval=0)
samples_retries = self.gcode.get_int( samples_result = gcmd.get("SAMPLES_RESULT", self.samples_result)
"SAMPLES_TOLERANCE_RETRIES", params, self.samples_retries, minval=0)
samples_result = self.gcode.get_str(
"SAMPLES_RESULT", params, self.samples_result)
must_notify_multi_probe = not self.multi_probe_pending must_notify_multi_probe = not self.multi_probe_pending
if must_notify_multi_probe: if must_notify_multi_probe:
self.multi_probe_begin() self.multi_probe_begin()
@ -174,8 +170,7 @@ class PrinterProbe:
if retries >= samples_retries: if retries >= samples_retries:
raise homing.CommandError( raise homing.CommandError(
"Probe samples exceed samples_tolerance") "Probe samples exceed samples_tolerance")
self.gcode.respond_info( gcmd.respond_info("Probe samples exceed tolerance. Retrying...")
"Probe samples exceed tolerance. Retrying...")
retries += 1 retries += 1
positions = [] positions = []
# Retract # Retract
@ -189,27 +184,25 @@ class PrinterProbe:
return self._calc_median(positions) return self._calc_median(positions)
return self._calc_mean(positions) return self._calc_mean(positions)
cmd_PROBE_help = "Probe Z-height at current XY position" cmd_PROBE_help = "Probe Z-height at current XY position"
def cmd_PROBE(self, params): def cmd_PROBE(self, gcmd):
pos = self.run_probe(params) pos = self.run_probe(gcmd)
self.gcode.respond_info("Result is z=%.6f" % (pos[2],)) gcmd.respond_info("Result is z=%.6f" % (pos[2],))
cmd_QUERY_PROBE_help = "Return the status of the z-probe" cmd_QUERY_PROBE_help = "Return the status of the z-probe"
def cmd_QUERY_PROBE(self, params): def cmd_QUERY_PROBE(self, gcmd):
toolhead = self.printer.lookup_object('toolhead') toolhead = self.printer.lookup_object('toolhead')
print_time = toolhead.get_last_move_time() print_time = toolhead.get_last_move_time()
res = self.mcu_probe.query_endstop(print_time) res = self.mcu_probe.query_endstop(print_time)
self.gcode.respond_info( gcmd.respond_info("probe: %s" % (["open", "TRIGGERED"][not not res],))
"probe: %s" % (["open", "TRIGGERED"][not not res],))
cmd_PROBE_ACCURACY_help = "Probe Z-height accuracy at current XY position" cmd_PROBE_ACCURACY_help = "Probe Z-height accuracy at current XY position"
def cmd_PROBE_ACCURACY(self, params): def cmd_PROBE_ACCURACY(self, gcmd):
speed = self.gcode.get_float("PROBE_SPEED", params, speed = gcmd.get_float("PROBE_SPEED", self.speed, above=0.)
self.speed, above=0.) lift_speed = self.get_lift_speed(gcmd)
lift_speed = self.get_lift_speed(params) sample_count = gcmd.get_int("SAMPLES", 10, minval=1)
sample_count = self.gcode.get_int("SAMPLES", params, 10, minval=1) sample_retract_dist = gcmd.get_float("SAMPLE_RETRACT_DIST",
sample_retract_dist = self.gcode.get_float( self.sample_retract_dist, above=0.)
"SAMPLE_RETRACT_DIST", params, self.sample_retract_dist, above=0.)
toolhead = self.printer.lookup_object('toolhead') toolhead = self.printer.lookup_object('toolhead')
pos = toolhead.get_position() pos = toolhead.get_position()
self.gcode.respond_info("PROBE_ACCURACY at X:%.3f Y:%.3f Z:%.3f" gcmd.respond_info("PROBE_ACCURACY at X:%.3f Y:%.3f Z:%.3f"
" (samples=%d retract=%.3f" " (samples=%d retract=%.3f"
" speed=%.1f lift_speed=%.1f)\n" " speed=%.1f lift_speed=%.1f)\n"
% (pos[0], pos[1], pos[2], % (pos[0], pos[1], pos[2],
@ -238,7 +231,7 @@ class PrinterProbe:
deviation_sum += pow(positions[i][2] - avg_value, 2.) deviation_sum += pow(positions[i][2] - avg_value, 2.)
sigma = (deviation_sum / len(positions)) ** 0.5 sigma = (deviation_sum / len(positions)) ** 0.5
# Show information # Show information
self.gcode.respond_info( gcmd.respond_info(
"probe accuracy results: maximum %.6f, minimum %.6f, range %.6f, " "probe accuracy results: maximum %.6f, minimum %.6f, range %.6f, "
"average %.6f, median %.6f, standard deviation %.6f" % ( "average %.6f, median %.6f, standard deviation %.6f" % (
max_value, min_value, range_value, avg_value, median, sigma)) max_value, min_value, range_value, avg_value, median, sigma))
@ -253,11 +246,11 @@ class PrinterProbe:
configfile = self.printer.lookup_object('configfile') configfile = self.printer.lookup_object('configfile')
configfile.set(self.name, 'z_offset', "%.3f" % (z_offset,)) configfile.set(self.name, 'z_offset', "%.3f" % (z_offset,))
cmd_PROBE_CALIBRATE_help = "Calibrate the probe's z_offset" cmd_PROBE_CALIBRATE_help = "Calibrate the probe's z_offset"
def cmd_PROBE_CALIBRATE(self, params): def cmd_PROBE_CALIBRATE(self, gcmd):
manual_probe.verify_no_manual_probe(self.printer) manual_probe.verify_no_manual_probe(self.printer)
# Perform initial probe # Perform initial probe
lift_speed = self.get_lift_speed(params) lift_speed = self.get_lift_speed(gcmd)
curpos = self.run_probe(params) curpos = self.run_probe(gcmd)
# Move away from the bed # Move away from the bed
self.probe_calibrate_z = curpos[2] self.probe_calibrate_z = curpos[2]
curpos[2] += 5. curpos[2] += 5.
@ -267,14 +260,13 @@ class PrinterProbe:
curpos[1] += self.y_offset curpos[1] += self.y_offset
self._move(curpos, self.speed) self._move(curpos, self.speed)
# Start manual probe # Start manual probe
manual_probe.ManualProbeHelper(self.printer, params, manual_probe.ManualProbeHelper(self.printer, gcmd,
self.probe_calibrate_finalize) self.probe_calibrate_finalize)
# Endstop wrapper that enables probe specific features # Endstop wrapper that enables probe specific features
class ProbeEndstopWrapper: class ProbeEndstopWrapper:
def __init__(self, config): def __init__(self, config):
self.printer = config.get_printer() self.printer = config.get_printer()
self.gcode = self.printer.lookup_object('gcode')
self.position_endstop = config.getfloat('z_offset') self.position_endstop = config.getfloat('z_offset')
gcode_macro = self.printer.try_load_module(config, 'gcode_macro') gcode_macro = self.printer.try_load_module(config, 'gcode_macro')
self.activate_gcode = gcode_macro.load_template( self.activate_gcode = gcode_macro.load_template(
@ -381,11 +373,11 @@ class ProbePointsHelper:
toolhead.move(curpos, self.speed) toolhead.move(curpos, self.speed)
self.gcode.reset_last_position() self.gcode.reset_last_position()
return False return False
def start_probe(self, params): def start_probe(self, gcmd):
manual_probe.verify_no_manual_probe(self.printer) manual_probe.verify_no_manual_probe(self.printer)
# Lookup objects # Lookup objects
probe = self.printer.lookup_object('probe', None) probe = self.printer.lookup_object('probe', None)
method = self.gcode.get_str('METHOD', params, 'automatic').lower() method = gcmd.get('METHOD', 'automatic').lower()
self.results = [] self.results = []
if probe is None or method != 'automatic': if probe is None or method != 'automatic':
# Manual probe # Manual probe
@ -394,17 +386,17 @@ class ProbePointsHelper:
self._manual_probe_start() self._manual_probe_start()
return return
# Perform automatic probing # Perform automatic probing
self.lift_speed = probe.get_lift_speed(params) self.lift_speed = probe.get_lift_speed(gcmd)
self.probe_offsets = probe.get_offsets() self.probe_offsets = probe.get_offsets()
if self.horizontal_move_z < self.probe_offsets[2]: if self.horizontal_move_z < self.probe_offsets[2]:
raise self.gcode.error("horizontal_move_z can't be less than" raise gcmd.error("horizontal_move_z can't be less than"
" probe's z_offset") " probe's z_offset")
probe.multi_probe_begin() probe.multi_probe_begin()
while 1: while 1:
done = self._move_next() done = self._move_next()
if done: if done:
break break
pos = probe.run_probe(params) pos = probe.run_probe(gcmd)
self.results.append(pos) self.results.append(pos)
probe.multi_probe_end() probe.multi_probe_end()
def _manual_probe_start(self): def _manual_probe_start(self):