2014-08-29 07:52:33 -07:00
|
|
|
/**
|
|
|
|
* @file test_sensors.c
|
|
|
|
*
|
|
|
|
* @date Dec 7, 2013
|
2015-01-12 16:05:46 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2015
|
2014-08-29 07:52:33 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "main.h"
|
|
|
|
#include "thermistors.h"
|
|
|
|
#include "allsensors.h"
|
2015-01-04 18:03:36 -08:00
|
|
|
#include "hip9011_lookup.h"
|
2014-08-29 07:52:33 -07:00
|
|
|
|
|
|
|
static ThermistorConf tc;
|
|
|
|
|
|
|
|
static void testMapDecoding(void) {
|
|
|
|
|
|
|
|
air_pressure_sensor_config_s s;
|
2015-01-22 17:05:54 -08:00
|
|
|
s.type = MT_DENSO183;
|
2014-08-29 07:52:33 -07:00
|
|
|
|
|
|
|
assertEqualsM("denso 0 volts", -6.64, decodePressure(0, &s));
|
|
|
|
assertEquals(31.244, decodePressure(1, &s));
|
|
|
|
|
2015-01-22 17:05:54 -08:00
|
|
|
s.type = MT_MPX4250;
|
2014-08-29 07:52:33 -07:00
|
|
|
assertEqualsM("MPX_4250 0 volts", 8, decodePressure(0, &s));
|
|
|
|
assertEquals(58.4, decodePressure(1, &s));
|
|
|
|
}
|
|
|
|
|
|
|
|
void testTpsRateOfChange(void) {
|
|
|
|
print("************************************************** testTpsRateOfChange\r\n");
|
|
|
|
saveTpsState(0, 0);
|
|
|
|
saveTpsState(CH_FREQUENCY, 50);
|
|
|
|
assertEquals(50, getTpsRateOfChange());
|
|
|
|
|
|
|
|
saveTpsState(2 * CH_FREQUENCY, 50);
|
|
|
|
assertEquals(0, getTpsRateOfChange());
|
|
|
|
|
|
|
|
saveTpsState(3 * CH_FREQUENCY, 75);
|
|
|
|
assertEquals(25, getTpsRateOfChange());
|
2015-01-04 18:03:36 -08:00
|
|
|
}
|
2014-08-29 07:52:33 -07:00
|
|
|
|
2015-01-04 18:03:36 -08:00
|
|
|
static void testHip9011lookup(void) {
|
|
|
|
print("************************************************** testHip9011lookup\r\n");
|
2014-08-29 07:52:33 -07:00
|
|
|
|
2015-01-04 18:03:36 -08:00
|
|
|
assertEqualsM2("", 3183.1013, getRpmByAngleWindowAndTimeUs(600, 360), 0.1);
|
2015-01-04 19:03:31 -08:00
|
|
|
assertEqualsM2("40us", 47746.5195, getRpmByAngleWindowAndTimeUs(40, 360), 0.1);
|
|
|
|
|
|
|
|
assertEqualsM2("600us 50 degree", 442.0974, getRpmByAngleWindowAndTimeUs(600, 50), 0.1);
|
|
|
|
assertEqualsM2("240us 50 degree", 1105.2435, getRpmByAngleWindowAndTimeUs(240, 50), 0.1);
|
|
|
|
assertEqualsM2("240us 50 degree", 6631.4619, getRpmByAngleWindowAndTimeUs(40, 50), 0.1);
|
|
|
|
|
|
|
|
assertEquals(0, getHip9011GainIndex(3));
|
|
|
|
assertEquals(0, getHip9011GainIndex(2));
|
|
|
|
assertEquals(47, getHip9011GainIndex(0.234));
|
|
|
|
assertEquals(63, getHip9011GainIndex(0.000001));
|
|
|
|
|
|
|
|
prepareHip9011RpmLookup(50);
|
|
|
|
|
|
|
|
assertEquals(31, getIntegrationIndexByRpm(1));
|
|
|
|
assertEquals(21, getIntegrationIndexByRpm(1100));
|
|
|
|
assertEquals(1, getIntegrationIndexByRpm(6600));
|
|
|
|
assertEquals(0, getIntegrationIndexByRpm(16600));
|
2014-08-29 07:52:33 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void testSensors(void) {
|
|
|
|
print("************************************************** testSensors\r\n");
|
|
|
|
testMapDecoding();
|
|
|
|
testTpsRateOfChange();
|
2015-01-04 18:03:36 -08:00
|
|
|
testHip9011lookup();
|
2014-08-29 07:52:33 -07:00
|
|
|
|
2015-02-18 18:05:47 -08:00
|
|
|
{
|
|
|
|
setThermistorConfiguration(&tc, 32, 9500, 75, 2100, 120, 1000);
|
|
|
|
|
|
|
|
prepareThermistorCurve(&tc);
|
|
|
|
|
|
|
|
assertEquals(-0.003, tc.s_h_a);
|
|
|
|
assertEquals(0.001, tc.s_h_b);
|
|
|
|
assertEquals(0.0, tc.s_h_c);
|
|
|
|
|
|
|
|
float t = convertResistanceToKelvinTemperature(2100, &tc);
|
|
|
|
assertEquals(75 + KELV, t);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// 2003 Neon sensor
|
|
|
|
setThermistorConfiguration(&tc, 0, 32500, 30, 7550, 100, 700);
|
|
|
|
prepareThermistorCurve(&tc);
|
|
|
|
|
|
|
|
assertEqualsM("A", 0.0009, tc.s_h_a);
|
|
|
|
assertEqualsM("B", 0.0003, tc.s_h_b);
|
|
|
|
assertEquals(0.0, tc.s_h_c);
|
|
|
|
float t = convertResistanceToKelvinTemperature(38000, &tc);
|
|
|
|
assertEquals(-2.7983, t - KELV);
|
|
|
|
}
|
2014-08-29 07:52:33 -07:00
|
|
|
}
|
2015-01-04 18:03:36 -08:00
|
|
|
|