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
|
|
|
*/
|
|
|
|
|
|
|
|
#include "engine_math.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-02-28 16:42:15 -08:00
|
|
|
TEST(misc, structSize) {
|
2019-02-28 18:09:31 -08:00
|
|
|
ASSERT_EQ(1, sizeof(adc_channel_e)) << "small enum size";
|
2019-02-28 16:48:38 -08:00
|
|
|
ASSERT_EQ(1, sizeof(pin_input_mode_e)) << "small enum size";
|
2019-02-28 16:42:15 -08:00
|
|
|
ASSERT_EQ(1, sizeof(pin_output_mode_e)) << "small enum size";
|
2019-02-28 18:17:35 -08:00
|
|
|
ASSERT_EQ(1, sizeof(brain_pin_e)) << "small enum size";
|
|
|
|
ASSERT_EQ(16, sizeof(air_pressure_sensor_config_s));
|
|
|
|
ASSERT_EQ(20000, sizeof(persistent_config_s));
|
2019-02-28 16:42:15 -08:00
|
|
|
}
|
|
|
|
|
2019-01-14 12:31:56 -08:00
|
|
|
TEST(misc, testIgnitionPlanning) {
|
2015-07-10 06:01:56 -07:00
|
|
|
printf("*************************************************** testIgnitionPlanning\r\n");
|
2019-01-19 17:42:29 -08:00
|
|
|
WITH_ENGINE_TEST_HELPER(FORD_ESCORT_GT);
|
2015-07-10 06:01:56 -07:00
|
|
|
|
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
|
|
|
|
2019-01-14 15:00:59 -08:00
|
|
|
ASSERT_EQ(IM_BATCH, engineConfiguration->injectionMode);
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
2019-01-14 12:31:56 -08:00
|
|
|
TEST(misc, testEngineMath) {
|
2015-07-10 06:01:56 -07:00
|
|
|
printf("*************************************************** testEngineMath\r\n");
|
|
|
|
|
2019-01-19 17:42:29 -08:00
|
|
|
WITH_ENGINE_TEST_HELPER(FORD_ESCORT_GT);
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-08-07 21:32:31 -07:00
|
|
|
engineConfiguration->ambiguousOperationMode = FOUR_STROKE_CAM_SENSOR;
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-01-14 15:38:20 -08:00
|
|
|
ASSERT_NEAR( 50, getOneDegreeTimeMs(600) * 180, EPS4D) << "600 RPM";
|
|
|
|
ASSERT_EQ( 5, getOneDegreeTimeMs(6000) * 180) << "6000 RPM";
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-01-14 15:20:20 -08:00
|
|
|
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));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
|
2019-01-14 15:20:20 -08:00
|
|
|
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));
|
2018-09-29 09:16:36 -07:00
|
|
|
|
|
|
|
// 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)
|
2019-06-19 19:34:11 -07:00
|
|
|
engine->engineState.sd.airMassInOneCylinder = getCylinderAirMass(/*VE*/1.0f, /*MAP*/100.0f, /*tChargeK*/273.15f + 20.0f PASS_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
ASSERT_NEAR(0.5464f, engine->engineState.sd.airMassInOneCylinder, EPS4D);
|
2018-09-29 09:16:36 -07:00
|
|
|
// calc. airFlow using airMass, and find tCharge
|
2019-01-14 15:20:20 -08:00
|
|
|
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);
|
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");
|
|
|
|
|
2019-01-14 15:00:59 -08:00
|
|
|
ASSERT_EQ(35, getTopAdvanceForBore(CS_OPEN, 98, 8, 101.6));
|
|
|
|
ASSERT_EQ(33, getTopAdvanceForBore(CS_OPEN, 98, 11, 101.6));
|
2015-12-24 11:02:03 -08:00
|
|
|
|
2016-01-21 19:01:31 -08:00
|
|
|
float rpmBin[16];
|
|
|
|
setRpmBin(rpmBin, 16, 800, 7000);
|
2019-01-14 15:00:59 -08:00
|
|
|
ASSERT_EQ(650, rpmBin[0]);
|
2019-01-14 15:38:20 -08:00
|
|
|
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";
|
2019-01-14 15:00:59 -08:00
|
|
|
ASSERT_EQ(7000, rpmBin[15]);
|
2016-01-21 19:01:31 -08:00
|
|
|
|
|
|
|
|
2019-01-14 15:20:20 -08:00
|
|
|
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));
|
2015-12-24 11:02:03 -08:00
|
|
|
|
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-05-27 12:56:12 -07:00
|
|
|
float getMap(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
|
|
|
return engine->mockMapValue;
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|