rusefi/unit_tests/tests/trigger/test_fasterEngineSpinningUp...

132 lines
5.0 KiB
C++
Raw Normal View History

/*
* test_fasterEngineSpinningUp.cpp
*
* Created on: Mar 6, 2018
*/
#include "pch.h"
2019-01-20 19:21:12 -08:00
TEST(cranking, testFasterEngineSpinningUp) {
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
setTable(config->injectionPhase, -180.0f);
engine->tdcMarkEnabled = false;
// turn on FasterEngineSpinUp mode
engineConfiguration->isFasterEngineSpinUpEnabled = true;
engineConfiguration->cranking.baseFuel = 12;
2019-01-21 19:45:37 -08:00
// set ignition mode
engineConfiguration->ignitionMode = IM_INDIVIDUAL_COILS;
// set cranking threshold (used below)
engineConfiguration->cranking.rpm = 999;
// set sequential injection mode to test auto-change to simultaneous when spinning-up
setupSimpleTestEngineWithMafAndTT_ONE_trigger(&eth, IM_SEQUENTIAL);
// Lie that this trigger requires disambiguation
engine->triggerCentral.triggerState.setNeedsDisambiguation(true);
ASSERT_EQ(IM_WASTED_SPARK, getCurrentIgnitionMode());
eth.fireRise(1000 /*ms*/);
// check if it's true
ASSERT_EQ(IM_SEQUENTIAL, getCurrentInjectionMode());
ASSERT_EQ(IM_WASTED_SPARK, getCurrentIgnitionMode());
// check if the engine has the right state
ASSERT_EQ(SPINNING_UP, engine->rpmCalculator.getState());
// check RPM
2022-01-20 20:19:48 -08:00
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm))) << "RPM=0";
// the queue should be empty, no trigger events yet
2019-01-14 12:31:56 -08:00
ASSERT_EQ(0, engine->executor.size()) << "plain#1";
// check all events starting from now
// advance 1 revolution
2019-01-13 21:21:08 -08:00
// because we have trivial TT_ONE trigger here synchronization would happen with just one rise front
2018-07-28 16:51:41 -07:00
eth.fireRise(200);
// check if the mode is changed
2019-01-14 12:31:56 -08:00
ASSERT_EQ(SPINNING_UP, engine->rpmCalculator.getState());
// due to isFasterEngineSpinUp=true, we should have already detected RPM!
2022-01-20 20:19:48 -08:00
ASSERT_EQ( 300, round(Sensor::getOrZero(SensorType::Rpm))) << "spinning-RPM#1";
// two simultaneous injections
2019-01-14 12:31:56 -08:00
ASSERT_EQ(4, engine->executor.size()) << "plain#2";
// test if they are simultaneous
ASSERT_EQ(IM_SIMULTANEOUS, getCurrentInjectionMode());
// test if ignition mode is temporary changed to wasted spark, if set to individual coils
ASSERT_EQ(IM_WASTED_SPARK, getCurrentIgnitionMode());
// check real events
2022-08-31 19:56:38 -07:00
eth.assertEvent5("inj start#1", 0, (void*)startSimultaneousInjection, 97500);
eth.assertEvent5("inj end#1", 1, (void*)endSimultaneousInjection, 100000);
// skip the rest of the cycle
2018-07-28 17:02:01 -07:00
eth.fireFall(200);
// now clear and advance more
2021-10-01 19:33:06 -07:00
eth.executeActions();
2018-07-28 16:51:41 -07:00
eth.fireRise(200);
// check if the mode is changed when fully synched
2019-01-14 12:31:56 -08:00
ASSERT_EQ(CRANKING, engine->rpmCalculator.getState());
// check RPM
2022-01-20 20:19:48 -08:00
ASSERT_EQ( 200, round(Sensor::getOrZero(SensorType::Rpm))) << "RPM#2";
// test if they are simultaneous in cranking mode too
ASSERT_EQ(IM_SIMULTANEOUS, getCurrentInjectionMode());
// Should still be in wasted spark since we don't have cam sync yet
ASSERT_EQ(IM_WASTED_SPARK, getCurrentIgnitionMode());
// two simultaneous injections
2019-01-14 15:38:20 -08:00
ASSERT_EQ( 4, engine->executor.size()) << "plain#2";
// check real events
2022-08-31 19:56:38 -07:00
eth.assertEvent5("inj start#2", 0, (void*)startSimultaneousInjection, 148375);
eth.assertEvent5("inj end#2", 1, (void*)endSimultaneousInjection, 149999);
// Now perform a fake VVT sync and check that ignition mode changes to sequential
engine->triggerCentral.syncAndReport(2, 0);
ASSERT_EQ(IM_SEQUENTIAL, getCurrentIgnitionMode());
// skip, clear & advance 1 more revolution at higher RPM
2018-07-28 17:02:01 -07:00
eth.fireFall(60);
eth.clearQueue();
2018-07-28 16:37:10 -07:00
eth.fireTriggerEventsWithDuration(60);
// check if the mode is now changed to 'running' at higher RPM
2019-01-14 12:45:35 -08:00
ASSERT_EQ(RUNNING, engine->rpmCalculator.getState());
// check RPM
2022-01-20 20:19:48 -08:00
ASSERT_EQ( 1000, round(Sensor::getOrZero(SensorType::Rpm))) << "RPM#3";
// check if the injection mode is back to sequential now
ASSERT_EQ(IM_SEQUENTIAL, getCurrentInjectionMode());
// 4 sequential injections for the full cycle
2019-01-14 15:38:20 -08:00
ASSERT_EQ( 8, engine->executor.size()) << "plain#3";
// check real events for sequential injection
// Note: See addFuelEvents() fix inside setRpmValue()!
eth.assertEvent5("inj start#3", 0, (void*)turnInjectionPinHigh, -31625);
eth.assertEvent5("inj end#3", 1, (void*)turnInjectionPinLow, -30001);
}
2019-01-20 19:21:12 -08:00
static void doTestFasterEngineSpinningUp60_2(int startUpDelayMs, int rpm1, int expectedRpm) {
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
2019-01-20 19:21:12 -08:00
// turn on FasterEngineSpinUp mode
engineConfiguration->isFasterEngineSpinUpEnabled = true;
2019-01-20 19:21:12 -08:00
setupSimpleTestEngineWithMaf(&eth, IM_SEQUENTIAL, trigger_type_e::TT_TOOTHED_WHEEL_60_2);
2019-01-21 19:45:37 -08:00
eth.moveTimeForwardMs(startUpDelayMs);
2019-01-20 19:21:12 -08:00
2022-09-25 04:40:28 -07:00
// fire 30 tooth rise/fall signals
eth.fireTriggerEvents2(30 /* count */, 1 /*ms*/);
// now fire missed tooth rise/fall
eth.fireRise(5 /*ms*/);
EXPECT_EQ(rpm1, round(Sensor::getOrZero(SensorType::Rpm)));
eth.fireFall(1);
eth.fireTriggerEvents2(30, 1);
// After some more regular teeth, instant RPM is still correct
EXPECT_EQ(rpm1, round(Sensor::getOrZero(SensorType::Rpm)));
}
2019-01-21 19:45:37 -08:00
TEST(cranking, testFasterEngineSpinningUp60_2) {
doTestFasterEngineSpinningUp60_2(0, 1000, 1000);
doTestFasterEngineSpinningUp60_2(100, 1000, 1000);
doTestFasterEngineSpinningUp60_2(1000, 1000, 1000);
2019-01-20 19:21:12 -08:00
}