custom-board-bundle-sample-.../unit_tests/tests/ignition_injection/test_ignition_scheduling.cpp

145 lines
4.6 KiB
C++
Raw Normal View History

2019-11-17 06:32:12 -08:00
/*
* @file test_ignition_scheduling.cpp
*
* @date Nov 17, 2019
2020-01-07 21:02:40 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2019-11-17 06:32:12 -08:00
*/
#include "pch.h"
2019-11-17 06:32:12 -08:00
#include "spark_logic.h"
using ::testing::_;
2019-11-17 06:32:12 -08:00
TEST(ignition, twoCoils) {
EngineTestHelper eth(FRANKENSO_BMW_M73_F);
2019-11-17 06:32:12 -08:00
// first one to fire uses first coil
ASSERT_EQ(engine->ignitionPin[ID2INDEX(1)], 0);
ASSERT_EQ(engine->ignitionPin[ID2INDEX(2)], 1);
ASSERT_EQ(engine->ignitionPin[ID2INDEX(3)], 0);
ASSERT_EQ(engine->ignitionPin[ID2INDEX(4)], 1);
2019-11-17 06:32:12 -08:00
ASSERT_EQ(engine->ignitionPin[ID2INDEX(11)], 0);
ASSERT_EQ(engine->ignitionPin[ID2INDEX(12)], 1);
2019-11-17 06:32:12 -08:00
// let's recalculate with zero timing so that we can focus on relation advance between cylinders
setArrayValues(engine->engineState.timingAdvance, 0.0f);
initializeIgnitionActions();
2019-11-17 06:32:12 -08:00
2019-11-23 20:49:39 -08:00
ASSERT_EQ(engine->ignitionEvents.elements[0].sparkAngle, 0);
2019-11-17 06:32:12 -08:00
ASSERT_EQ((void*)engine->ignitionEvents.elements[0].outputs[0], (void*)&enginePins.coils[0]);
2019-11-23 20:49:39 -08:00
ASSERT_EQ(engine->ignitionEvents.elements[1].sparkAngle, 720 / 12);
2019-11-17 06:32:12 -08:00
ASSERT_EQ((void*)engine->ignitionEvents.elements[1].outputs[0], (void*)&enginePins.coils[6]);
2019-11-23 20:49:39 -08:00
ASSERT_EQ(engine->ignitionEvents.elements[3].sparkAngle, 3 * 720 / 12);
2019-11-17 06:32:12 -08:00
ASSERT_EQ((void*)engine->ignitionEvents.elements[3].outputs[0], (void*)&enginePins.coils[6]);
}
2019-11-17 06:32:12 -08:00
TEST(ignition, trailingSpark) {
EngineTestHelper eth(TEST_ENGINE);
2019-11-17 06:32:12 -08:00
2021-10-01 22:17:53 -07:00
/**
// TODO #3220: this feature makes this test sad, eventually remove this line (and the ability to disable it altogether)
2021-10-01 22:17:53 -07:00
* I am pretty sure that it's about usage of improper method clearQueue() below see it's comment
*/
engine->enableOverdwellProtection = false;
EXPECT_CALL(eth.mockAirmass, getAirmass(_))
.WillRepeatedly(Return(AirmassResult{0.1008f, 50.0f}));
setupSimpleTestEngineWithMafAndTT_ONE_trigger(&eth);
engineConfiguration->specs.cylindersCount = 1;
engineConfiguration->specs.firingOrder = FO_1;
engineConfiguration->isInjectionEnabled = false;
engineConfiguration->isIgnitionEnabled = true;
// Fire trailing spark 10 degrees after main spark
engine->engineState.trailingSparkAngle = 10;
engineConfiguration->injectionMode = IM_SEQUENTIAL;
setWholeTimingTable(0);
eth.fireTriggerEventsWithDuration(20);
// still no RPM since need to cycles measure cycle duration
eth.fireTriggerEventsWithDuration(20);
2022-01-20 19:58:12 -08:00
ASSERT_EQ( 3000, Sensor::getOrZero(SensorType::Rpm)) << "RPM#0";
eth.clearQueue();
/**
* Trigger up - scheduling fuel for full engine cycle
*/
eth.fireRise(20);
2019-11-17 06:32:12 -08:00
// Primary coil should be high
EXPECT_EQ(enginePins.coils[0].getLogicValue(), true);
EXPECT_EQ(enginePins.trailingCoils[0].getLogicValue(), false);
2019-11-17 06:32:12 -08:00
// Should be a TDC callback + spark firing
EXPECT_EQ(engine->executor.size(), 2);
2019-11-17 06:32:12 -08:00
// execute all actions
2021-10-01 21:13:15 -07:00
eth.executeActions();
// Primary and secondary coils should be low - primary just fired
EXPECT_EQ(enginePins.coils[0].getLogicValue(), false);
EXPECT_EQ(enginePins.trailingCoils[0].getLogicValue(), false);
// Now enable trailing sparks
engineConfiguration->enableTrailingSparks = true;
// Fire trigger fall - should schedule ignition chargings (rising edges)
eth.fireFall(20);
2021-10-01 21:00:08 -07:00
eth.moveTimeForwardMs(18);
eth.executeActions();
2021-10-01 21:00:08 -07:00
// Primary low, scheduling trailing
EXPECT_EQ(enginePins.coils[0].getLogicValue(), true);
2021-10-01 21:00:08 -07:00
EXPECT_EQ(enginePins.trailingCoils[0].getLogicValue(), false);
eth.moveTimeForwardMs(2);
eth.executeActions();
// and secondary coils should be low
EXPECT_EQ(enginePins.trailingCoils[0].getLogicValue(), true);
// Fire trigger rise - should schedule ignition firings
2021-10-01 21:00:08 -07:00
eth.fireRise(0);
2021-10-01 20:53:22 -07:00
eth.moveTimeForwardMs(1);
eth.executeActions();
2021-10-01 20:53:22 -07:00
// Primary goes low, scheduling trailing
EXPECT_EQ(enginePins.coils[0].getLogicValue(), false);
2021-10-01 20:53:22 -07:00
EXPECT_EQ(enginePins.trailingCoils[0].getLogicValue(), true);
eth.moveTimeForwardMs(1);
eth.executeActions();
// secondary coils should be low
EXPECT_EQ(enginePins.trailingCoils[0].getLogicValue(), false);
}
TEST(ignition, CylinderTimingTrim) {
EngineTestHelper eth(TEST_ENGINE);
// Base timing 15 degrees
setTable(config->ignitionTable, 15);
// negative numbers retard timing, positive advance
setTable(config->ignTrims[0].table, -4);
setTable(config->ignTrims[1].table, -2);
setTable(config->ignTrims[2].table, 2);
setTable(config->ignTrims[3].table, 4);
// run the ignition math
engine->periodicFastCallback();
2021-10-01 20:53:22 -07:00
// Check that each cylinder gets the expected timing
float unadjusted = 15;
EXPECT_NEAR(engine->engineState.timingAdvance[0], unadjusted - 4, EPS4D);
EXPECT_NEAR(engine->engineState.timingAdvance[1], unadjusted - 2, EPS4D);
EXPECT_NEAR(engine->engineState.timingAdvance[2], unadjusted + 2, EPS4D);
EXPECT_NEAR(engine->engineState.timingAdvance[3], unadjusted + 4, EPS4D);
}