heater: Merge ThermistorBeta class into Thermistor class
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
aed958eb5c
commit
7e78b2665e
|
@ -12,10 +12,16 @@ import math, logging, threading
|
||||||
|
|
||||||
KELVIN_TO_CELCIUS = -273.15
|
KELVIN_TO_CELCIUS = -273.15
|
||||||
|
|
||||||
# Thermistor calibrated with three temp measurements
|
# Analog voltage to temperature converter for thermistors
|
||||||
class Thermistor:
|
class Thermistor:
|
||||||
def __init__(self, config, params):
|
def __init__(self, config, params):
|
||||||
self.pullup = config.getfloat('pullup_resistor', 4700., above=0.)
|
self.pullup = config.getfloat('pullup_resistor', 4700., above=0.)
|
||||||
|
self.c1 = self.c2 = self.c3 = 0.
|
||||||
|
if 'beta' in params:
|
||||||
|
self.calc_coefficients_beta(params)
|
||||||
|
else:
|
||||||
|
self.calc_coefficients(params)
|
||||||
|
def calc_coefficients(self, params):
|
||||||
# Calculate Steinhart-Hart coefficents from temp measurements.
|
# Calculate Steinhart-Hart coefficents from temp measurements.
|
||||||
# Arrange samples as 3 linear equations and solve for c1, c2, and c3.
|
# Arrange samples as 3 linear equations and solve for c1, c2, and c3.
|
||||||
inv_t1 = 1. / (params['t1'] - KELVIN_TO_CELCIUS)
|
inv_t1 = 1. / (params['t1'] - KELVIN_TO_CELCIUS)
|
||||||
|
@ -34,6 +40,13 @@ class Thermistor:
|
||||||
/ (ln3_r12 - ln3_r13 * ln_r12 / ln_r13))
|
/ (ln3_r12 - ln3_r13 * ln_r12 / ln_r13))
|
||||||
self.c2 = (inv_t12 - self.c3 * ln3_r12) / ln_r12
|
self.c2 = (inv_t12 - self.c3 * ln3_r12) / ln_r12
|
||||||
self.c1 = inv_t1 - self.c2 * ln_r1 - self.c3 * ln3_r1
|
self.c1 = inv_t1 - self.c2 * ln_r1 - self.c3 * ln3_r1
|
||||||
|
def calc_coefficients_beta(self, params):
|
||||||
|
# Calculate equivalent Steinhart-Hart coefficents from beta
|
||||||
|
inv_t1 = 1. / (params['t1'] - KELVIN_TO_CELCIUS)
|
||||||
|
ln_r1 = math.log(params['r1'])
|
||||||
|
self.c3 = 0.
|
||||||
|
self.c2 = 1. / params['beta']
|
||||||
|
self.c1 = inv_t1 - self.c2 * ln_r1
|
||||||
def calc_temp(self, adc):
|
def calc_temp(self, adc):
|
||||||
adc = max(.00001, min(.99999, adc))
|
adc = max(.00001, min(.99999, adc))
|
||||||
r = self.pullup * adc / (1.0 - adc)
|
r = self.pullup * adc / (1.0 - adc)
|
||||||
|
@ -52,17 +65,6 @@ class Thermistor:
|
||||||
r = math.exp(ln_r)
|
r = math.exp(ln_r)
|
||||||
return r / (self.pullup + r)
|
return r / (self.pullup + r)
|
||||||
|
|
||||||
# Thermistor calibrated from one temp measurement and its beta
|
|
||||||
class ThermistorBeta(Thermistor):
|
|
||||||
def __init__(self, config, params):
|
|
||||||
self.pullup = config.getfloat('pullup_resistor', 4700., above=0.)
|
|
||||||
# Calculate Steinhart-Hart coefficents from beta
|
|
||||||
inv_t1 = 1. / (params['t1'] - KELVIN_TO_CELCIUS)
|
|
||||||
ln_r1 = math.log(params['r1'])
|
|
||||||
self.c3 = 0.
|
|
||||||
self.c2 = 1. / params['beta']
|
|
||||||
self.c1 = inv_t1 - self.c2 * ln_r1
|
|
||||||
|
|
||||||
# Linear style conversion chips calibrated with two temp measurements
|
# Linear style conversion chips calibrated with two temp measurements
|
||||||
class Linear:
|
class Linear:
|
||||||
def __init__(self, config, params):
|
def __init__(self, config, params):
|
||||||
|
@ -84,7 +86,7 @@ Sensors = {
|
||||||
'class': Thermistor, 't1': 20., 'r1': 126800.,
|
'class': Thermistor, 't1': 20., 'r1': 126800.,
|
||||||
't2': 150., 'r2': 1360., 't3': 300., 'r3': 80.65 },
|
't2': 150., 'r2': 1360., 't3': 300., 'r3': 80.65 },
|
||||||
"NTC 100K beta 3950": {
|
"NTC 100K beta 3950": {
|
||||||
'class': ThermistorBeta, 't1': 25., 'r1': 100000., 'beta': 3950. },
|
'class': Thermistor, 't1': 25., 'r1': 100000., 'beta': 3950. },
|
||||||
"AD595": { 'class': Linear, 't1': 25., 'v1': .25, 't2': 300., 'v2': 3.022 },
|
"AD595": { 'class': Linear, 't1': 25., 'v1': .25, 't2': 300., 'v2': 3.022 },
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue