rusefi/unit_tests/tests/sensor/resist_func.cpp

114 lines
2.3 KiB
C++
Raw Normal View History

/*
* @author Matthew Kennedy, (c) 2019
*/
#include "pch.h"
#include "resistance_func.h"
TEST(resistance, OutOfRange)
{
ResistanceFunc f;
2023-06-10 13:36:03 -07:00
f.configure(5, 10000, false);
// Something in the middle should be valid
{
auto r = f.convert(2.5f);
ASSERT_TRUE(r.Valid);
}
// Something near 0.05v should be valid
{
auto r = f.convert(0.051f);
EXPECT_TRUE(r.Valid);
}
// Something just under 0.05v should be invalid
{
auto r = f.convert(0.049f);
EXPECT_FALSE(r.Valid);
}
// Something near 0.98 * 5v should be valid
{
auto r = f.convert(0.97f * 5);
EXPECT_TRUE(r.Valid);
}
// Something just above 0.98 * 5v should be invalid
{
auto r = f.convert(0.99f * 5);
EXPECT_FALSE(r.Valid);
}
}
TEST(resistance, InRange)
{
ResistanceFunc f;
2023-06-10 13:36:03 -07:00
f.configure(5, 10000, false);
// 1 volt -> 2500 ohms low side
{
auto r = f.convert(1.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 2500);
}
// 2 volt -> 6666.667 ohm ohms low side
// 20k/3 gives us an exact result
{
auto r = f.convert(2.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 20000.0f / 3);
}
// 3 volt -> 15000 ohms low side
{
auto r = f.convert(3.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 15000);
}
// 4 volt -> 40000 ohms low side
{
auto r = f.convert(4.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 40000);
}
}
2023-06-10 13:36:03 -07:00
TEST(resistance, PulldownMode)
{
ResistanceFunc f;
f.configure(5, 10000, true);
// 4 volt -> 2500 ohms high side
{
auto r = f.convert(4.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 2500);
}
// 3 volt -> 6666.667 ohm ohms high side
// 20k/3 gives us an exact result
{
auto r = f.convert(3.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 20000.0f / 3);
}
// 2 volt -> 15000 ohms high side
{
auto r = f.convert(2.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 15000);
}
// 1 volt -> 40000 ohms high side
{
auto r = f.convert(1.0f);
EXPECT_TRUE(r.Valid);
EXPECT_FLOAT_EQ(r.Value, 40000);
}
}