diff options
author | Kevin O'Connor <kevin@koconnor.net> | 2019-01-21 20:14:49 -0500 |
---|---|---|
committer | Kevin O'Connor <kevin@koconnor.net> | 2019-01-21 21:28:25 -0500 |
commit | 7327394c50cc52ba2363959b0647370860f18d9f (patch) | |
tree | 1615cc50ba2f25ba6ac11cdb5587ce48596f76df /klippy/extras/adc_temperature.py | |
parent | fc946c796c72c83a5c9c753a3ca69fce3b8a88da (diff) | |
download | kutter-7327394c50cc52ba2363959b0647370860f18d9f.tar.gz kutter-7327394c50cc52ba2363959b0647370860f18d9f.tar.xz kutter-7327394c50cc52ba2363959b0647370860f18d9f.zip |
adc_temperature: Add support for linear interpolation of resistances
Add support for performing linear interpolation between a set of
measured temperature/resistance pairs.
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'klippy/extras/adc_temperature.py')
-rw-r--r-- | klippy/extras/adc_temperature.py | 51 |
1 files changed, 49 insertions, 2 deletions
diff --git a/klippy/extras/adc_temperature.py b/klippy/extras/adc_temperature.py index cb7b0e28..086f2858 100644 --- a/klippy/extras/adc_temperature.py +++ b/klippy/extras/adc_temperature.py @@ -119,6 +119,50 @@ class CustomLinearVoltage: lv = LinearVoltage(config, self.params) return PrinterADCtoTemperature(config, lv) + +###################################################################### +# Linear resistance to temperature converter +###################################################################### + +# Linear resistance calibrated with two temp measurements +class LinearResistance: + def __init__(self, config, samples): + self.pullup = config.getfloat('pullup_resistor', 4700., above=0.) + try: + self.li = LinearInterpolate(samples) + except ValueError as e: + raise config.error("adc_temperature %s in heater %s" % ( + str(e), config.get_name())) + def calc_temp(self, adc): + # Calculate temperature from adc + adc = max(.00001, min(.99999, adc)) + r = self.pullup * adc / (1.0 - adc) + return self.li.interpolate(r) + def calc_adc(self, temp): + # Calculate adc reading from a temperature + r = self.li.reverse_interpolate(temp) + return r / (self.pullup + r) + +# Custom defined sensors from the config file +class CustomLinearResistance: + def __init__(self, config): + self.name = " ".join(config.get_name().split()[1:]) + self.samples = [] + for i in range(1, 1000): + t = config.getfloat("temperature%d" % (i,), None) + if t is None: + break + r = config.getfloat("resistance%d" % (i,)) + self.samples.append((r, t)) + def create(self, config): + lr = LinearResistance(config, self.samples) + return PrinterADCtoTemperature(config, lr) + + +###################################################################### +# Default sensors +###################################################################### + AD595 = [ (0., .0027), (10., .101), (20., .200), (25., .250), (30., .300), (40., .401), (50., .503), (60., .605), (80., .810), (100., 1.015), @@ -150,6 +194,9 @@ def load_config(config): pheater.add_sensor(sensor_type, func) def load_config_prefix(config): - linear = CustomLinearVoltage(config) + if config.get("resistance1", None) is None: + custom_sensor = CustomLinearVoltage(config) + else: + custom_sensor = CustomLinearResistance(config) pheater = config.get_printer().lookup_object("heater") - pheater.add_sensor(linear.name, linear.create) + pheater.add_sensor(custom_sensor.name, custom_sensor.create) |