2016-05-25 18:37:40 +03:00
|
|
|
# Printer fan support
|
|
|
|
#
|
2017-07-04 19:24:11 +03:00
|
|
|
# Copyright (C) 2016,2017 Kevin O'Connor <kevin@koconnor.net>
|
2016-05-25 18:37:40 +03:00
|
|
|
#
|
|
|
|
# This file may be distributed under the terms of the GNU GPLv3 license.
|
|
|
|
|
2017-07-04 19:24:11 +03:00
|
|
|
import extruder
|
|
|
|
|
2016-05-25 18:37:40 +03:00
|
|
|
FAN_MIN_TIME = 0.1
|
2017-03-09 04:00:27 +03:00
|
|
|
PWM_CYCLE_TIME = 0.010
|
2016-05-25 18:37:40 +03:00
|
|
|
|
|
|
|
class PrinterFan:
|
|
|
|
def __init__(self, printer, config):
|
2016-08-25 18:24:18 +03:00
|
|
|
self.last_fan_value = 0.
|
2016-08-24 22:16:02 +03:00
|
|
|
self.last_fan_time = 0.
|
2017-07-04 18:38:44 +03:00
|
|
|
self.max_power = config.getfloat('max_power', 1., above=0., maxval=1.)
|
2017-04-11 18:37:09 +03:00
|
|
|
self.kick_start_time = config.getfloat('kick_start_time', 0.1, minval=0.)
|
2017-03-13 05:43:05 +03:00
|
|
|
pin = config.get('pin')
|
|
|
|
hard_pwm = config.getint('hard_pwm', 0)
|
|
|
|
self.mcu_fan = printer.mcu.create_pwm(pin, PWM_CYCLE_TIME, hard_pwm, 0.)
|
2017-07-04 19:24:11 +03:00
|
|
|
def set_pwm(self, mcu_time, value):
|
2017-07-04 18:38:44 +03:00
|
|
|
value = max(0., min(self.max_power, value))
|
2016-05-25 18:37:40 +03:00
|
|
|
if value == self.last_fan_value:
|
|
|
|
return
|
2016-08-24 22:16:02 +03:00
|
|
|
mcu_time = max(self.last_fan_time + FAN_MIN_TIME, mcu_time)
|
2017-07-04 18:38:44 +03:00
|
|
|
if (value and value < self.max_power
|
2016-08-24 22:16:02 +03:00
|
|
|
and not self.last_fan_value and self.kick_start_time):
|
2016-05-25 18:37:40 +03:00
|
|
|
# Run fan at full speed for specified kick_start_time
|
2017-07-04 18:38:44 +03:00
|
|
|
self.mcu_fan.set_pwm(mcu_time, self.max_power)
|
2016-08-24 22:16:02 +03:00
|
|
|
mcu_time += self.kick_start_time
|
|
|
|
self.mcu_fan.set_pwm(mcu_time, value)
|
|
|
|
self.last_fan_time = mcu_time
|
2016-05-25 18:37:40 +03:00
|
|
|
self.last_fan_value = value
|
2017-07-04 19:24:11 +03:00
|
|
|
# External commands
|
|
|
|
def set_speed(self, print_time, value):
|
|
|
|
mcu_time = self.mcu_fan.print_to_mcu_time(print_time)
|
|
|
|
self.set_pwm(mcu_time, value)
|
|
|
|
|
|
|
|
class PrinterHeaterFan:
|
|
|
|
def __init__(self, printer, config):
|
|
|
|
self.fan = PrinterFan(printer, config)
|
|
|
|
heater = config.get("heater", "extruder0")
|
|
|
|
self.heater = extruder.get_printer_heater(printer, heater)
|
|
|
|
if self.heater is None:
|
|
|
|
raise config.error("Unknown heater '%s'" % (heater,))
|
|
|
|
self.heater_temp = config.getfloat("heater_temp", 50.0)
|
|
|
|
printer.reactor.register_timer(self.callback, printer.reactor.NOW)
|
|
|
|
def callback(self, eventtime):
|
|
|
|
current_temp, target_temp = self.heater.get_temp()
|
|
|
|
if not current_temp and not target_temp and not self.fan.last_fan_time:
|
|
|
|
# Printer still starting
|
|
|
|
return eventtime + 1.
|
|
|
|
power = 0.
|
|
|
|
if target_temp or current_temp > self.heater_temp:
|
|
|
|
power = 1.
|
|
|
|
mcu_time = self.fan.mcu_fan.system_to_mcu_time(eventtime + FAN_MIN_TIME)
|
|
|
|
self.fan.set_pwm(mcu_time, power)
|
|
|
|
return eventtime + 1.
|
2017-04-29 20:57:02 +03:00
|
|
|
|
|
|
|
def add_printer_objects(printer, config):
|
|
|
|
if config.has_section('fan'):
|
|
|
|
printer.add_object('fan', PrinterFan(printer, config.getsection('fan')))
|
2017-07-04 19:24:11 +03:00
|
|
|
for s in config.get_prefix_sections('heater_fan '):
|
|
|
|
printer.add_object(s.section, PrinterHeaterFan(printer, s))
|