2021-08-04 16:30:52 -07:00
|
|
|
#include "pch.h"
|
2020-04-02 05:55:21 -07:00
|
|
|
|
2021-08-04 16:30:52 -07:00
|
|
|
#include "redundant_sensor.h"
|
2020-04-02 05:55:21 -07:00
|
|
|
|
|
|
|
RedundantSensor::RedundantSensor(SensorType outputType, SensorType first, SensorType second)
|
|
|
|
: Sensor(outputType)
|
|
|
|
, m_first(first)
|
|
|
|
, m_second(second)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2023-10-30 19:13:29 -07:00
|
|
|
void RedundantSensor::configure(float /*split threshold*/maxDifference, bool ignoreSecondSensor) {
|
2020-04-02 05:55:21 -07:00
|
|
|
m_maxDifference = maxDifference;
|
|
|
|
m_ignoreSecond = ignoreSecondSensor;
|
|
|
|
}
|
|
|
|
|
|
|
|
SensorResult RedundantSensor::get() const {
|
|
|
|
auto result1 = Sensor::get(m_first);
|
|
|
|
|
|
|
|
// If we're set to disable redundancy, just pass thru the first sensor
|
|
|
|
if (m_ignoreSecond) {
|
|
|
|
return result1;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto result2 = Sensor::get(m_second);
|
|
|
|
|
|
|
|
// If either result is invalid, return invalid.
|
|
|
|
if (!result1.Valid || !result2.Valid) {
|
2022-07-28 00:04:28 -07:00
|
|
|
return UnexpectedCode::Inconsistent;
|
2020-04-02 05:55:21 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// If both are valid, check that they're near one another
|
|
|
|
float delta = absF(result1.Value - result2.Value);
|
|
|
|
if (delta > m_maxDifference) {
|
2022-07-28 00:04:28 -07:00
|
|
|
return UnexpectedCode::Inconsistent;
|
2020-04-02 05:55:21 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Both sensors are valid, and their readings are close. All is well.
|
|
|
|
// Return the average
|
2020-04-19 05:37:43 -07:00
|
|
|
return (result1.Value + result2.Value) / 2;
|
2020-04-02 05:55:21 -07:00
|
|
|
}
|