rusefi-full/unit_tests/tests/test_engine_math.cpp

109 lines
4.0 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/*
* @file test_engine_math.c
*
2019-01-03 04:57:34 -08:00
* @date Nov 14, 2013
* @author Andrey Belomutskiy, (c) 2012-2019
2015-07-10 06:01:56 -07:00
*/
2018-09-16 19:39:46 -07:00
#include "global.h"
2015-07-10 06:01:56 -07:00
#include "engine_math.h"
#include "engine_configuration.h"
#include "map.h"
#include "speed_density.h"
#include "engine_test_helper.h"
#include "maf.h"
2015-12-24 11:02:03 -08:00
#include "advance_map.h"
2015-07-10 06:01:56 -07:00
2019-01-14 12:31:56 -08:00
TEST(misc, testIgnitionPlanning) {
2015-07-10 06:01:56 -07:00
printf("*************************************************** testIgnitionPlanning\r\n");
EngineTestHelper eth(FORD_ESCORT_GT);
EXPAND_EngineTestHelper;
2017-05-15 20:28:49 -07:00
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
2016-07-01 16:01:44 -07:00
assertEqualsM("testIgnitionPlanning_AFR", 13.5, eth.engine.engineState.targetAFR);
2016-07-01 07:02:58 -07:00
2015-07-10 06:01:56 -07:00
assertEquals(IM_BATCH, engineConfiguration->injectionMode);
}
2019-01-14 12:31:56 -08:00
TEST(misc, testEngineMath) {
2015-07-10 06:01:56 -07:00
printf("*************************************************** testEngineMath\r\n");
EngineTestHelper eth(FORD_ESCORT_GT);
2016-10-11 18:03:00 -07:00
EXPAND_EngineTestHelper;
2015-07-10 06:01:56 -07:00
engineConfiguration->operationMode = FOUR_STROKE_CAM_SENSOR;
assertEqualsM("600 RPM", 50, getOneDegreeTimeMs(600) * 180);
assertEqualsM("6000 RPM", 5, getOneDegreeTimeMs(6000) * 180);
2017-05-15 20:28:49 -07:00
assertEquals(312.5, getTCharge(1000, 0, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX));
assertEquals(313.5833, getTCharge(1000, 50, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX));
assertEquals(314.6667, getTCharge(1000, 100, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX));
2015-07-10 06:01:56 -07:00
2017-05-15 20:28:49 -07:00
assertEquals(312.5, getTCharge(4000, 0, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX));
assertEquals(320.0833, getTCharge(4000, 50, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX));
assertEquals(327.6667, getTCharge(4000, 100, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX));
// test Air Interpolation mode
engineConfiguration->tChargeMode = TCHARGE_MODE_AIR_INTERP;
engineConfiguration->tChargeAirCoefMin = 0.098f;
engineConfiguration->tChargeAirCoefMax = 0.902f;
engineConfiguration->tChargeAirFlowMax = 153.6f;
// calc. some airMass given the engine displacement=1.839 and 4 cylinders (FORD_ESCORT_GT)
engine->engineState.airMass = getCylinderAirMass(engineConfiguration, /*VE*/1.0f, /*MAP*/100.0f, /*tChargeK*/273.15f + 20.0f);
assertEquals(0.5464f, engine->engineState.airMass);
// calc. airFlow using airMass, and find tCharge
assertEquals(59.1175f, getTCharge(/*RPM*/1000, /*TPS*/0, /*CLT*/90.0f, /*IAT*/20.0f PASS_ENGINE_PARAMETER_SUFFIX));
assertEquals(65.5625f/*kg/h*/, engine->engineState.airFlow);
2015-07-10 06:01:56 -07:00
}
2019-01-14 12:31:56 -08:00
TEST(misc, testIgnitionMapGenerator) {
2015-12-24 11:02:03 -08:00
printf("*************************************************** testIgnitionMapGenerator\r\n");
assertEquals(35, getTopAdvanceForBore(CS_OPEN, 98, 8, 101.6));
assertEquals(33, getTopAdvanceForBore(CS_OPEN, 98, 11, 101.6));
2016-01-21 19:01:31 -08:00
float rpmBin[16];
setRpmBin(rpmBin, 16, 800, 7000);
assertEquals(650, rpmBin[0]);
assertEqualsM("@1", 800, rpmBin[1]);
2017-12-10 12:05:24 -08:00
assertEqualsM("@2", 1100, rpmBin[2]);
assertEqualsM("rpm@3", 1400, rpmBin[3]);
assertEqualsM("rpm@14", 4700, rpmBin[14]);
2016-01-21 19:01:31 -08:00
assertEquals(7000, rpmBin[15]);
2015-12-24 11:02:03 -08:00
assertEquals(22.0, getTopAdvanceForBore(CS_SWIRL_TUMBLE, 89, 9, 101.6));
assertEquals(32.2, getTopAdvanceForBore(CS_SWIRL_TUMBLE, 89, 9, 145));
2016-01-21 19:01:31 -08:00
assertEqualsM2("100@6000", 36.0, getInitialAdvance(6000, 100, 36), 0.1);
assertEqualsM2("100@600", 9.9, getInitialAdvance(600, 100, 36), 0.2);
assertEqualsM2("2400", 34.2, getInitialAdvance(2400, 40, 36), 0.1);
assertEqualsM2("4400", 41.9, getInitialAdvance(4400, 40, 36), 0.1);
assertEqualsM2("20@800", 14.2, getInitialAdvance(800, 20, 36), 0.2);
2015-12-24 11:02:03 -08:00
}
2019-01-14 12:31:56 -08:00
TEST(misc, testMafLookup) {
2015-07-10 06:01:56 -07:00
printf("*************************************************** testMafLookup\r\n");
EngineTestHelper eth(FORD_ESCORT_GT);
EXPAND_EngineTestHelper;
setBosch0280218037(config);
engine->preCalculate(PASS_ENGINE_PARAMETER_SIGNATURE);
2015-07-10 06:01:56 -07:00
assertEqualsM("@0", -34.5000, engine->mafDecodingLookup[0]);
assertEqualsM("@1", -33.7875, engine->mafDecodingLookup[1]);
assertEqualsM("@2", -33.0750, engine->mafDecodingLookup[2]);
assertEqualsM("@200", 313.8826, engine->mafDecodingLookup[200]);
assertEqualsM("@255", 738, engine->mafDecodingLookup[255]);
}
2019-01-10 22:18:35 -08:00
float mockMapValue = 0;
2016-08-26 16:02:56 -07:00
2015-07-10 06:01:56 -07:00
float getMap(void) {
2019-01-10 22:18:35 -08:00
return mockMapValue;
2015-07-10 06:01:56 -07:00
}