hall_filament_width_sensor: Added width logging (#2981)

Signed-off-by: Denis Ignatenko deniss979@gmail.com
This commit is contained in:
Denis Ignatenko 2020-06-16 20:36:49 +03:00 committed by GitHub
parent 4c571ea9ac
commit b3298d8992
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 32 additions and 0 deletions

View File

@ -2035,6 +2035,9 @@
#measurement_interval: 10 #measurement_interval: 10
# The approximate distance (in mm) between sensor readings. The # The approximate distance (in mm) between sensor readings. The
# default is 10mm. # default is 10mm.
#logging: False
# Out diameter to terminal and klipper.log
# can be turn on|of by command
#Virtual filament_switch_sensor support. Create sensor named hall_filament_width_sensor. #Virtual filament_switch_sensor support. Create sensor named hall_filament_width_sensor.
#min_diameter:1.0 #min_diameter:1.0
#Minimal diameter for trigger virtual filament_switch_sensor. #Minimal diameter for trigger virtual filament_switch_sensor.

View File

@ -48,6 +48,10 @@ Sensor generates two analog output based on calculated filament width. Sum of ou
# measurement_interval:10 # measurement_interval:10
# Sensor readings done with 10 mm intervals by default. If necessary you are free to change this setting # Sensor readings done with 10 mm intervals by default. If necessary you are free to change this setting
#logging: False
# Out diameter to terminal and klipper.log
# can be turn on|of by command
#Virtual filament_switch_sensor suppurt. Create sensor named hall_filament_width_sensor. #Virtual filament_switch_sensor suppurt. Create sensor named hall_filament_width_sensor.
# #
#min_diameter:1.0 #min_diameter:1.0
@ -75,6 +79,10 @@ Sensor generates two analog output based on calculated filament width. Sum of ou
**QUERY_RAW_FILAMENT_WIDTH** Return the current ADC channel values and RAW sensor value for calibration points **QUERY_RAW_FILAMENT_WIDTH** Return the current ADC channel values and RAW sensor value for calibration points
**ENABLE_FILAMENT_WIDTH_LOG** - Turn on diameter logging
**DISABLE_FILAMENT_WIDTH_LOG** - Turn off diameter logging
## Menu variables ## Menu variables
**hall_filament_width_sensor.Diameter** current measured filament width in mm **hall_filament_width_sensor.Diameter** current measured filament width in mm
@ -117,3 +125,7 @@ Save raw values in config
## How to enable sensor ## How to enable sensor
After power on by default sensor disabled. After power on by default sensor disabled.
Enable sensor in start g-code by command **ENABLE_FILAMENT_WIDTH_SENSOR** or change enable parameter in config Enable sensor in start g-code by command **ENABLE_FILAMENT_WIDTH_SENSOR** or change enable parameter in config
## Logging
After power on by default diameter Logging disabled.
Data to log added on every measurement interval (10 mm by default)

View File

@ -31,6 +31,7 @@ class HallFilamentWidthSensor:
self.diameter =self.nominal_filament_dia self.diameter =self.nominal_filament_dia
self.is_active =config.getboolean('enable', False) self.is_active =config.getboolean('enable', False)
self.runout_dia=config.getfloat('min_diameter', 1.0) self.runout_dia=config.getfloat('min_diameter', 1.0)
self.is_log =config.getboolean('logging', False)
# Use the current diameter instead of nominal while the first # Use the current diameter instead of nominal while the first
# measurement isn't in place # measurement isn't in place
self.use_current_dia_while_delay = config.getboolean( self.use_current_dia_while_delay = config.getboolean(
@ -63,6 +64,11 @@ class HallFilamentWidthSensor:
self.cmd_M405) self.cmd_M405)
self.gcode.register_command('QUERY_RAW_FILAMENT_WIDTH', self.gcode.register_command('QUERY_RAW_FILAMENT_WIDTH',
self.cmd_Get_Raw_Values) self.cmd_Get_Raw_Values)
self.gcode.register_command('ENABLE_FILAMENT_WIDTH_LOG',
self.cmd_log_enable)
self.gcode.register_command('DISABLE_FILAMENT_WIDTH_LOG',
self.cmd_log_disable)
self.runout_helper = filament_switch_sensor.RunoutHelper(config) self.runout_helper = filament_switch_sensor.RunoutHelper(config)
# Initialization # Initialization
def handle_ready(self): def handle_ready(self):
@ -97,6 +103,10 @@ class HallFilamentWidthSensor:
if next_reading_position <= (last_epos + self.measurement_delay): if next_reading_position <= (last_epos + self.measurement_delay):
self.filament_array.append([last_epos + self.measurement_delay, self.filament_array.append([last_epos + self.measurement_delay,
self.diameter]) self.diameter])
if self.is_log:
self.gcode.respond_info("Filament width:%.3f" %
( self.diameter ))
else: else:
# add first item to array # add first item to array
self.filament_array.append([self.measurement_delay + last_epos, self.filament_array.append([self.measurement_delay + last_epos,
@ -190,6 +200,13 @@ class HallFilamentWidthSensor:
'Raw':(self.lastFilamentWidthReading+ 'Raw':(self.lastFilamentWidthReading+
self.lastFilamentWidthReading2), self.lastFilamentWidthReading2),
'is_active':self.is_active} 'is_active':self.is_active}
def cmd_log_enable(self, gcmd):
self.is_log = True
gcmd.respond_info("Filament width logging Turned On")
def cmd_log_disable(self, gcmd):
self.is_log = False
gcmd.respond_info("Filament width logging Turned Off")
def load_config(config): def load_config(config):
return HallFilamentWidthSensor(config) return HallFilamentWidthSensor(config)