2021-08-01 20:21:53 -07:00
|
|
|
#include "sensor_converter_func.h"
|
|
|
|
#include "biquad.h"
|
|
|
|
|
|
|
|
|
|
|
|
class FlexConverter : public SensorConverter {
|
|
|
|
public:
|
|
|
|
FlexConverter() {
|
|
|
|
// Update rate is 50-150hz, so this actually filters at 0.5-1.5hz -3db depending on E%, which is ok
|
|
|
|
m_filter.configureLowpass(100, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
SensorResult convert(float frequency) const override {
|
|
|
|
// Sensor should only report 50-150hz, significantly outside that range indicates a problem
|
|
|
|
// it changes to 200hz+ to indicate methanol "contamination"
|
2022-07-28 00:04:28 -07:00
|
|
|
if (frequency < 45) {
|
|
|
|
return UnexpectedCode::Low;
|
|
|
|
}
|
2021-08-01 20:21:53 -07:00
|
|
|
|
2022-07-28 00:04:28 -07:00
|
|
|
if (frequency > 155) {
|
|
|
|
return UnexpectedCode::High;
|
2021-08-01 20:21:53 -07:00
|
|
|
}
|
2022-07-28 00:04:28 -07:00
|
|
|
|
|
|
|
float flexPct = clampF(0, frequency - 50, 100);
|
|
|
|
|
|
|
|
return m_filter.filter(flexPct);
|
2021-08-01 20:21:53 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
mutable Biquad m_filter;
|
|
|
|
};
|