/* * @file test_engine_math.c * * @date Nov 14, 2013 * @author Andrey Belomutskiy, (c) 2012-2019 */ #include "global.h" #include "engine_math.h" #include "engine_configuration.h" #include "map.h" #include "speed_density.h" #include "engine_test_helper.h" #include "maf.h" #include "advance_map.h" TEST(misc, testIgnitionPlanning) { printf("*************************************************** testIgnitionPlanning\r\n"); WITH_ENGINE_TEST_HELPER(FORD_ESCORT_GT); eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE); assertEqualsM("testIgnitionPlanning_AFR", 13.5, eth.engine.engineState.targetAFR); ASSERT_EQ(IM_BATCH, engineConfiguration->injectionMode); } TEST(misc, testEngineMath) { printf("*************************************************** testEngineMath\r\n"); WITH_ENGINE_TEST_HELPER(FORD_ESCORT_GT); engineConfiguration->operationMode = FOUR_STROKE_CAM_SENSOR; ASSERT_NEAR( 50, getOneDegreeTimeMs(600) * 180, EPS4D) << "600 RPM"; ASSERT_EQ( 5, getOneDegreeTimeMs(6000) * 180) << "6000 RPM"; ASSERT_FLOAT_EQ(312.5, getTCharge(1000, 0, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX)); ASSERT_FLOAT_EQ(313.5833, getTCharge(1000, 50, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX)); ASSERT_FLOAT_EQ(314.6667, getTCharge(1000, 100, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX)); ASSERT_FLOAT_EQ(312.5, getTCharge(4000, 0, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX)); ASSERT_FLOAT_EQ(320.0833, getTCharge(4000, 50, 300, 350 PASS_ENGINE_PARAMETER_SUFFIX)); ASSERT_FLOAT_EQ(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(/*VE*/1.0f, /*MAP*/100.0f, /*tChargeK*/273.15f + 20.0f PASS_ENGINE_PARAMETER_SUFFIX); ASSERT_NEAR(0.5464f, engine->engineState.airMass, EPS4D); // calc. airFlow using airMass, and find tCharge ASSERT_FLOAT_EQ(59.1175f, getTCharge(/*RPM*/1000, /*TPS*/0, /*CLT*/90.0f, /*IAT*/20.0f PASS_ENGINE_PARAMETER_SUFFIX)); ASSERT_FLOAT_EQ(65.5625f/*kg/h*/, engine->engineState.airFlow); } TEST(misc, testIgnitionMapGenerator) { printf("*************************************************** testIgnitionMapGenerator\r\n"); ASSERT_EQ(35, getTopAdvanceForBore(CS_OPEN, 98, 8, 101.6)); ASSERT_EQ(33, getTopAdvanceForBore(CS_OPEN, 98, 11, 101.6)); float rpmBin[16]; setRpmBin(rpmBin, 16, 800, 7000); ASSERT_EQ(650, rpmBin[0]); ASSERT_EQ( 800, rpmBin[1]) << "@1"; ASSERT_EQ( 1100, rpmBin[2]) << "@2"; ASSERT_EQ( 1400, rpmBin[3]) << "rpm@3"; ASSERT_EQ( 4700, rpmBin[14]) << "rpm@14"; ASSERT_EQ(7000, rpmBin[15]); ASSERT_FLOAT_EQ(22.0, getTopAdvanceForBore(CS_SWIRL_TUMBLE, 89, 9, 101.6)); ASSERT_FLOAT_EQ(32.2, getTopAdvanceForBore(CS_SWIRL_TUMBLE, 89, 9, 145)); 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); } TEST(misc, testMafLookup) { printf("*************************************************** testMafLookup\r\n"); WITH_ENGINE_TEST_HELPER(FORD_ESCORT_GT); setBosch0280218037(config); engine->preCalculate(PASS_ENGINE_PARAMETER_SIGNATURE); 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]); ASSERT_EQ( 738, engine->mafDecodingLookup[255]) << "@255"; } float mockMapValue = 0; float getMap(void) { return mockMapValue; }