rusefi/unit_tests/test_fuel_map.cpp

236 lines
9.0 KiB
C++
Raw Normal View History

2014-08-29 07:52:33 -07:00
/**
* @file test_fuel_map.cpp
*
2015-01-22 17:05:54 -08:00
* @date Nov 6, 2013
* @author Andrey Belomutskiy, (c) 2012-2015
2014-08-29 07:52:33 -07:00
*/
#include "test_fuel_map.h"
#include "main.h"
#include "engine_configuration.h"
#include "fuel_math.h"
#include "trigger_structure.h"
#include "allsensors.h"
#include "engine_math.h"
#include "trigger_decoder.h"
#include "engine_test_helper.h"
2014-09-27 12:03:45 -07:00
#include "efiGpio.h"
2014-08-29 07:52:33 -07:00
extern float testMafValue;
2015-02-13 18:04:20 -08:00
void testMafFuelMath(void) {
printf("*************************************************** testMafFuelMath\r\n");
EngineTestHelper eth(FORD_ASPIRE_1996);
2015-04-04 19:11:07 -07:00
EXPAND_EngineTestHelper;
2015-02-13 18:04:20 -08:00
engineConfiguration->algorithm = LM_REAL_MAF;
engineConfiguration->injector.flow = 200;
2015-04-05 14:04:54 -07:00
setMap(config->afrTable, 13);
2015-02-13 18:04:20 -08:00
float fuelMs = getRealMafFuel(300, 6000 PASS_ENGINE_PARAMETER);
assertEquals(26.7099, fuelMs);
}
2014-08-29 07:52:33 -07:00
void testFuelMap(void) {
printf("*************************************************** testFuelMap\r\n");
2015-02-07 12:04:45 -08:00
printf("Setting up FORD_ASPIRE_1996\r\n");
2014-10-02 11:03:28 -07:00
EngineTestHelper eth(FORD_ASPIRE_1996);
2015-04-04 19:11:07 -07:00
EXPAND_EngineTestHelper;
2014-10-02 11:03:28 -07:00
2015-02-07 12:04:45 -08:00
printf("Filling fuel map\r\n");
2014-08-29 07:52:33 -07:00
for (int k = 0; k < FUEL_LOAD_COUNT; k++) {
for (int r = 0; r < FUEL_RPM_COUNT; r++) {
2015-04-05 14:04:54 -07:00
eth.engine.config->fuelTable[k][r] = k * 200 + r;
2014-08-29 07:52:33 -07:00
}
}
2014-10-02 11:03:28 -07:00
for (int i = 0; i < FUEL_LOAD_COUNT; i++)
2015-04-05 14:04:54 -07:00
eth.engine.config->fuelLoadBins[i] = i;
2014-10-02 11:03:28 -07:00
for (int i = 0; i < FUEL_RPM_COUNT; i++)
2015-04-05 14:04:54 -07:00
eth.engine.config->fuelRpmBins[i] = i;
2014-08-29 07:52:33 -07:00
2014-10-02 11:03:28 -07:00
assertEqualsM("base fuel table", 1005, getBaseTableFuel(eth.engine.engineConfiguration, 5, 5));
2014-08-29 07:52:33 -07:00
2014-10-02 11:03:28 -07:00
printf("*************************************************** initThermistors\r\n");
2014-08-29 07:52:33 -07:00
2015-02-18 18:05:47 -08:00
initThermistors(NULL PASS_ENGINE_PARAMETER);
2014-11-07 22:05:46 -08:00
2014-10-02 11:03:28 -07:00
printf("*** getInjectorLag\r\n");
2014-11-07 22:05:46 -08:00
assertEquals(1.0, getInjectorLag(12 PASS_ENGINE_PARAMETER));
2014-08-29 07:52:33 -07:00
2015-02-02 09:05:12 -08:00
eth.engine.engineConfiguration->injector.lag = 0.5;
2014-08-29 07:52:33 -07:00
for (int i = 0; i < VBAT_INJECTOR_CURVE_SIZE; i++) {
2015-02-02 11:04:09 -08:00
eth.engine.engineConfiguration->injector.battLagCorrBins[i] = i;
eth.engine.engineConfiguration->injector.battLagCorr[i] = 2 * i;
2014-08-29 07:52:33 -07:00
}
2015-02-10 07:09:58 -08:00
eth.engine.updateSlowSensors();
2014-08-29 07:52:33 -07:00
// because all the correction tables are zero
2014-10-02 11:03:28 -07:00
printf("*************************************************** getRunningFuel 1\r\n");
2014-11-24 18:03:34 -08:00
float baseFuel = getBaseTableFuel(eth.engine.engineConfiguration, 5, getEngineLoadT(PASS_ENGINE_PARAMETER_F));
2014-11-29 21:03:06 -08:00
assertEqualsM("base fuel", 5.05, getRunningFuel(baseFuel, 5 PASS_ENGINE_PARAMETER));
2014-08-29 07:52:33 -07:00
printf("*************************************************** setting IAT table\r\n");
for (int i = 0; i < IAT_CURVE_SIZE; i++) {
2015-04-05 14:04:54 -07:00
eth.engine.config->iatFuelCorrBins[i] = i;
eth.engine.config->iatFuelCorr[i] = 2 * i;
2014-08-29 07:52:33 -07:00
}
2015-04-05 14:04:54 -07:00
eth.engine.config->iatFuelCorr[0] = 2;
2014-08-29 07:52:33 -07:00
printf("*************************************************** setting CLT table\r\n");
for (int i = 0; i < CLT_CURVE_SIZE; i++) {
2015-04-05 14:04:54 -07:00
eth.engine.config->cltFuelCorrBins[i] = i;
eth.engine.config->cltFuelCorr[i] = 1;
2014-08-29 07:52:33 -07:00
}
2015-02-02 09:05:12 -08:00
eth.engine.engineConfiguration->injector.lag = 0;
2014-08-29 07:52:33 -07:00
2015-02-27 14:07:50 -08:00
assertEquals(NAN, getIntakeAirTemperature(PASS_ENGINE_PARAMETER_F));
2014-11-07 22:05:46 -08:00
float iatCorrection = getIatCorrection(-KELV PASS_ENGINE_PARAMETER);
2014-08-29 07:52:33 -07:00
assertEqualsM("IAT", 2, iatCorrection);
2015-02-27 14:07:50 -08:00
float cltCorrection = getCltCorrection(getCoolantTemperature(PASS_ENGINE_PARAMETER_F) PASS_ENGINE_PARAMETER);
2014-08-29 07:52:33 -07:00
assertEqualsM("CLT", 1, cltCorrection);
2014-11-07 22:05:46 -08:00
float injectorLag = getInjectorLag(getVBatt(engineConfiguration) PASS_ENGINE_PARAMETER);
2014-08-29 07:52:33 -07:00
assertEquals(0, injectorLag);
testMafValue = 5;
// 1005 * 2 for IAT correction
2014-10-02 11:03:28 -07:00
printf("*************************************************** getRunningFuel 2\r\n");
2014-11-24 18:03:34 -08:00
baseFuel = getBaseTableFuel(eth.engine.engineConfiguration, 5, getEngineLoadT(PASS_ENGINE_PARAMETER_F));
2014-11-07 22:05:46 -08:00
assertEqualsM("v1", 30150, getRunningFuel(baseFuel, 5 PASS_ENGINE_PARAMETER));
2014-08-29 07:52:33 -07:00
testMafValue = 0;
2015-01-22 17:05:54 -08:00
engineConfiguration->cranking.baseFuel = 4;
2014-08-29 07:52:33 -07:00
printf("*************************************************** getStartingFuel\r\n");
// NAN in case we have issues with the CLT sensor
2015-04-05 09:11:54 -07:00
assertEqualsM("getStartingFuel nan", 4, getCrankingFuel3(NAN, 0 PASS_ENGINE_PARAMETER));
assertEqualsM("getStartingFuel#1", 23.7333, getCrankingFuel3(0, 4 PASS_ENGINE_PARAMETER));
assertEqualsM("getStartingFuel#2", 18.0419, getCrankingFuel3(8, 15 PASS_ENGINE_PARAMETER));
assertEqualsM("getStartingFuel#3", 11.2000, getCrankingFuel3(70, 0 PASS_ENGINE_PARAMETER));
assertEqualsM("getStartingFuel#3", 5.6000, getCrankingFuel3(70, 50 PASS_ENGINE_PARAMETER));
2014-08-29 07:52:33 -07:00
}
2014-10-02 11:03:28 -07:00
extern engine_configuration_s *engineConfiguration;
2015-01-13 05:04:00 -08:00
static void confgiureFordAspireTriggerShape(TriggerShape * s) {
2015-02-02 21:04:02 -08:00
s->reset(FOUR_STROKE_CAM_SENSOR, true);
2014-08-29 07:52:33 -07:00
s->addEvent(53.747, T_SECONDARY, TV_HIGH);
s->addEvent(121.90, T_SECONDARY, TV_LOW);
s->addEvent(232.76, T_SECONDARY, TV_HIGH);
s->addEvent(300.54, T_SECONDARY, TV_LOW);
s->addEvent(360, T_PRIMARY, TV_HIGH);
s->addEvent(409.8412, T_SECONDARY, TV_HIGH);
s->addEvent(478.6505, T_SECONDARY, TV_LOW);
s->addEvent(588.045, T_SECONDARY, TV_HIGH);
s->addEvent(657.03, T_SECONDARY, TV_LOW);
s->addEvent(720, T_PRIMARY, TV_LOW);
assertEquals(53.747 / 720, s->wave.getSwitchTime(0));
assertEqualsM("@0", 1, s->wave.getChannelState(1, 0));
assertEqualsM("@0", 1, s->wave.getChannelState(1, 0));
assertEqualsM("@1", 0, s->wave.getChannelState(0, 1));
assertEqualsM("@1", 0, s->wave.getChannelState(1, 1));
assertEqualsM("@2", 0, s->wave.getChannelState(0, 2));
assertEqualsM("@2", 1, s->wave.getChannelState(1, 2));
assertEqualsM("@3", 0, s->wave.getChannelState(0, 3));
assertEqualsM("@3", 0, s->wave.getChannelState(1, 3));
assertEqualsM("@4", 1, s->wave.getChannelState(0, 4));
assertEqualsM("@5", 1, s->wave.getChannelState(1, 5));
assertEqualsM("@8", 0, s->wave.getChannelState(1, 8));
assertEquals(121.90 / 720, s->wave.getSwitchTime(1));
assertEquals(657.03 / 720, s->wave.getSwitchTime(8));
assertEqualsM("expecting 0", 0, s->wave.findAngleMatch(53.747 / 720.0, s->getSize()));
assertEqualsM("expecting not found", -1, s->wave.findAngleMatch(53 / 720.0, s->getSize()));
assertEquals(7, s->wave.findAngleMatch(588.045 / 720.0, s->getSize()));
assertEqualsM("expecting 0", 0, s->wave.waveIndertionAngle(23.747 / 720.0, s->getSize()));
assertEqualsM("expecting 1", 1, s->wave.waveIndertionAngle(63.747 / 720.0, s->getSize()));
}
static ActuatorEventList ae;
void testAngleResolver(void) {
printf("*************************************************** testAngleResolver\r\n");
2014-11-11 14:03:38 -08:00
EngineTestHelper eth(FORD_ASPIRE_1996);
2015-04-04 19:11:07 -07:00
EXPAND_EngineTestHelper;
2014-11-07 21:07:22 -08:00
2014-08-29 07:52:33 -07:00
engineConfiguration->globalTriggerAngleOffset = 175;
2014-11-24 13:03:32 -08:00
assertTrue(engine->engineConfiguration2!=NULL);
2015-01-13 05:04:00 -08:00
TriggerShape * ts = &engine->triggerShape;
2014-08-29 07:52:33 -07:00
2015-02-27 16:09:09 -08:00
ts->calculateTriggerSynchPoint(PASS_ENGINE_PARAMETER_F);
2014-08-29 07:52:33 -07:00
2015-04-13 20:08:04 -07:00
assertEqualsM("index 2", 52.76, ts->eventAngles[3]); // this angle is relation to synch point
2014-08-29 07:52:33 -07:00
assertEqualsM("time 2", 0.3233, ts->wave.getSwitchTime(2));
2015-04-13 20:08:04 -07:00
assertEqualsM("index 5", 412.76, ts->eventAngles[6]);
assertEqualsM("time 5", 0.5733, ts->wave.getSwitchTime(5));
2014-08-29 07:52:33 -07:00
2014-11-24 13:03:32 -08:00
assertEquals(4, ts->getTriggerShapeSynchPointIndex());
2014-08-29 07:52:33 -07:00
assertEqualsM("shape size", 10, ts->getSize());
OutputSignalList list;
2015-01-01 15:04:13 -08:00
ae.reset();
2014-08-29 07:52:33 -07:00
printf("*************************************************** testAngleResolver 0\r\n");
2015-04-13 19:05:01 -07:00
findTriggerPosition(&ae.add()->injectionStart, -122 PASS_ENGINE_PARAMETER);
2014-08-29 07:52:33 -07:00
assertEqualsM("size", 1, ae.size);
2015-04-13 20:08:04 -07:00
assertEquals(2, ae.elements[0].injectionStart.eventIndex);
assertEquals(0.24, ae.elements[0].injectionStart.angleOffset);
2014-08-29 07:52:33 -07:00
2015-04-13 19:05:01 -07:00
printf("*************************************************** testAngleResolver 0.1\r\n");
ae.reset();
findTriggerPosition(&ae.add()->injectionStart, -80 PASS_ENGINE_PARAMETER);
2015-04-13 20:08:04 -07:00
assertEquals(2, ae.elements[0].injectionStart.eventIndex);
assertEquals(42.24, ae.elements[0].injectionStart.angleOffset);
2015-04-13 19:05:01 -07:00
printf("*************************************************** testAngleResolver 0.2\r\n");
ae.reset();
findTriggerPosition(&ae.add()->injectionStart, -54 PASS_ENGINE_PARAMETER);
2015-04-13 20:08:04 -07:00
assertEquals(2, ae.elements[0].injectionStart.eventIndex);
assertEquals(68.2400, ae.elements[0].injectionStart.angleOffset);
2015-04-13 19:05:01 -07:00
printf("*************************************************** testAngleResolver 0.3\r\n");
ae.reset();
findTriggerPosition(&ae.add()->injectionStart, -53 PASS_ENGINE_PARAMETER);
assertEquals(2, ae.elements[0].injectionStart.eventIndex);
2015-04-13 20:08:04 -07:00
assertEquals(69.24, ae.elements[0].injectionStart.angleOffset);
2015-04-13 19:05:01 -07:00
printf("*************************************************** testAngleResolver 1\r\n");
ae.reset();
findTriggerPosition(&ae.add()->injectionStart, 0 PASS_ENGINE_PARAMETER);
assertEquals(2, ae.elements[0].injectionStart.eventIndex);
2015-04-13 20:08:04 -07:00
assertEquals(122.24, ae.elements[0].injectionStart.angleOffset);
2015-04-13 19:05:01 -07:00
2014-08-29 07:52:33 -07:00
printf("*************************************************** testAngleResolver 2\r\n");
2015-01-01 15:04:13 -08:00
ae.reset();
2015-04-13 19:05:01 -07:00
findTriggerPosition(&ae.add()->injectionStart, 56 PASS_ENGINE_PARAMETER);
2015-04-13 16:04:35 -07:00
assertEquals(2, ae.elements[0].injectionStart.eventIndex);
2015-04-13 20:08:04 -07:00
assertEquals(178.24, ae.elements[0].injectionStart.angleOffset);
TriggerShape t;
confgiureFordAspireTriggerShape(&t);
2014-08-29 07:52:33 -07:00
}
void testPinHelper(void) {
printf("*************************************************** testPinHelper\r\n");
assertEquals(0, getElectricalValue(0, OM_DEFAULT));
assertEquals(1, getElectricalValue(1, OM_DEFAULT));
assertEquals(0, getElectricalValue(1, OM_INVERTED));
assertEquals(1, getElectricalValue(0, OM_INVERTED));
}