rusefi/unit_tests/tests/ignition_injection/test_fuel_wall_wetting.cpp

61 lines
1.7 KiB
C++
Raw Normal View History

/*
* @file test_fuel_wall_wetting.cpp
*
* See also test_accel_enrichment.cpp
*
* @date Oct 16, 2019
2020-01-07 21:02:40 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
*/
#include "pch.h"
2019-10-16 19:10:38 -07:00
TEST(fuel, testWallWettingEnrichmentMath) {
EngineTestHelper eth(FORD_ASPIRE_1996);
engineConfiguration->wwaeTau = 1.0f;
engineConfiguration->wwaeBeta = 0.40f;
engine->rpmCalculator.setRpmValue(3000);
2020-07-20 00:04:05 -07:00
WallFuel wallFuel;
2019-10-16 19:10:38 -07:00
// each invocation of 'adjust' changes WallWetting internal state
ASSERT_NEAR(16.6666, wallFuel.adjust(10.0), EPS4D);
ASSERT_NEAR(16.198, wallFuel.adjust(10.0), EPS4D);
2019-10-16 19:10:38 -07:00
}
2019-10-16 19:10:38 -07:00
TEST(fuel, testWallWettingEnrichmentScheduling) {
EngineTestHelper eth(FORD_ASPIRE_1996);
2019-10-16 19:10:38 -07:00
setOperationMode(engineConfiguration, FOUR_STROKE_CRANK_SENSOR);
engineConfiguration->useOnlyRisingEdgeForTrigger = true;
eth.setTriggerType(TT_ONE);
2019-10-16 19:10:38 -07:00
eth.fireTriggerEvents2(/* count */ 4, 25 /* ms */);
2022-01-20 19:58:12 -08:00
ASSERT_EQ( 1200, Sensor::getOrZero(SensorType::Rpm)) << "RPM";
2019-10-16 19:10:38 -07:00
2019-10-16 21:06:54 -07:00
int expectedInvocationCounter = 1;
for (int i = 0; i < 4; i++) {
ASSERT_EQ(expectedInvocationCounter, engine->injectionEvents.elements[i].wallFuel.invocationCounter);
2019-10-16 21:06:54 -07:00
}
// Cylinder 5 doesn't exist - shouldn't have been called!
ASSERT_EQ(0, engine->injectionEvents.elements[5].wallFuel.invocationCounter);
eth.engine.periodicFastCallback();
eth.engine.periodicFastCallback();
eth.engine.periodicFastCallback();
2019-10-16 21:06:54 -07:00
// still same 1 per cylinder - wall wetting is NOT invoked from 'periodicFastCallback'
for (int i = 0; i < 4; i++) {
ASSERT_EQ(expectedInvocationCounter, engine->injectionEvents.elements[i].wallFuel.invocationCounter);
2019-10-16 21:06:54 -07:00
}
// Cylinder 5 doesn't exist - shouldn't have been called!
ASSERT_EQ(0, engine->injectionEvents.elements[5].wallFuel.invocationCounter);
}