2023-08-09 12:26:56 -07:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
2023-08-09 12:42:16 -07:00
|
|
|
#include "sampling.h"
|
2023-08-09 13:24:21 -07:00
|
|
|
#include "port.h"
|
|
|
|
|
|
|
|
SensorType GetSensorType()
|
|
|
|
{
|
|
|
|
return SensorType::LSU49;
|
|
|
|
}
|
|
|
|
|
|
|
|
int GetESRSupplyR()
|
|
|
|
{
|
|
|
|
// Nernst AC injection resistor value
|
|
|
|
return 22000;
|
|
|
|
}
|
2023-08-09 12:42:16 -07:00
|
|
|
|
2023-08-09 13:44:12 -07:00
|
|
|
TEST(Sampler, TestDc)
|
2023-08-09 12:26:56 -07:00
|
|
|
{
|
2023-08-09 12:42:16 -07:00
|
|
|
Sampler dut;
|
2023-08-09 13:36:48 -07:00
|
|
|
|
|
|
|
AnalogChannelResult data;
|
|
|
|
data.NernstVoltage = 0.45f;
|
|
|
|
data.PumpCurrentVoltage = 1.75f;
|
|
|
|
constexpr float virtualGroundVoltage = 1.65f;
|
|
|
|
|
2023-08-09 13:44:12 -07:00
|
|
|
for (size_t i = 0; i < 5000; i++)
|
2023-08-09 13:36:48 -07:00
|
|
|
{
|
|
|
|
dut.ApplySample(data, virtualGroundVoltage);
|
|
|
|
}
|
|
|
|
|
|
|
|
// not exactly 0 because of filtering
|
|
|
|
EXPECT_NEAR(0, dut.GetNernstAc(), 1e-3);
|
|
|
|
EXPECT_FLOAT_EQ(0.45f, dut.GetNernstDc());
|
2023-08-09 13:44:12 -07:00
|
|
|
EXPECT_NEAR(-0.1616, dut.GetPumpNominalCurrent(), 1e-3);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Sampler, TestAc)
|
|
|
|
{
|
|
|
|
Sampler dut;
|
|
|
|
|
|
|
|
AnalogChannelResult dataLow;
|
|
|
|
dataLow.NernstVoltage = 0.45f - 0.1f;
|
|
|
|
dataLow.PumpCurrentVoltage = 1.75f;
|
|
|
|
|
|
|
|
AnalogChannelResult dataHigh;
|
|
|
|
dataHigh.NernstVoltage = 0.45f + 0.1f;
|
|
|
|
dataHigh.PumpCurrentVoltage = 1.75f;
|
|
|
|
|
|
|
|
constexpr float virtualGroundVoltage = 1.65f;
|
|
|
|
|
|
|
|
for (size_t i = 0; i < 5000; i++)
|
|
|
|
{
|
|
|
|
dut.ApplySample(dataLow, virtualGroundVoltage);
|
|
|
|
dut.ApplySample(dataHigh, virtualGroundVoltage);
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_NEAR(0.2, dut.GetNernstAc(), 1e-3);
|
|
|
|
EXPECT_FLOAT_EQ(0.45f, dut.GetNernstDc());
|
|
|
|
EXPECT_NEAR(-0.1616, dut.GetPumpNominalCurrent(), 1e-3);
|
2023-08-09 12:26:56 -07:00
|
|
|
}
|