43 lines
1.0 KiB
C++
43 lines
1.0 KiB
C++
|
#include "redundant_sensor.h"
|
||
|
|
||
|
#include "efilib.h"
|
||
|
|
||
|
RedundantSensor::RedundantSensor(SensorType outputType, SensorType first, SensorType second)
|
||
|
: Sensor(outputType)
|
||
|
, m_first(first)
|
||
|
, m_second(second)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
void RedundantSensor::configure(float maxDifference, bool ignoreSecondSensor) {
|
||
|
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) {
|
||
|
return { false, 0 };
|
||
|
}
|
||
|
|
||
|
// If both are valid, check that they're near one another
|
||
|
float delta = absF(result1.Value - result2.Value);
|
||
|
if (delta > m_maxDifference) {
|
||
|
return { false, 0 };
|
||
|
}
|
||
|
|
||
|
// Both sensors are valid, and their readings are close. All is well.
|
||
|
// Return the average
|
||
|
float avg = (result1.Value + result2.Value) / 2;
|
||
|
return { true, avg };
|
||
|
}
|