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 {
|
2024-06-03 11:34:37 -07:00
|
|
|
auto sensor1 = Sensor::get(m_first);
|
2020-04-02 05:55:21 -07:00
|
|
|
|
|
|
|
// If we're set to disable redundancy, just pass thru the first sensor
|
|
|
|
if (m_ignoreSecond) {
|
2024-06-03 11:34:37 -07:00
|
|
|
return sensor1;
|
2020-04-02 05:55:21 -07:00
|
|
|
}
|
|
|
|
|
2024-06-03 11:34:37 -07:00
|
|
|
auto sensor2 = Sensor::get(m_second);
|
2020-04-02 05:55:21 -07:00
|
|
|
|
|
|
|
// If either result is invalid, return invalid.
|
2024-06-03 11:34:37 -07:00
|
|
|
if (!sensor1.Valid || !sensor2.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
|
2024-06-03 11:34:37 -07:00
|
|
|
float delta = absF(sensor1.Value - sensor2.Value);
|
2020-04-02 05:55:21 -07:00
|
|
|
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
|
2024-06-03 11:34:37 -07:00
|
|
|
return (sensor1.Value + sensor2.Value) / 2;
|
2020-04-02 05:55:21 -07:00
|
|
|
}
|