2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2020-11-19 05:15:56 -08:00
|
|
|
#include "launch_control.h"
|
|
|
|
|
|
|
|
TEST(LaunchControl, TpsCondition) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2020-11-19 05:15:56 -08:00
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
2022-07-20 15:48:55 -07:00
|
|
|
engineConfiguration->launchTpsThreshold = 10;
|
2020-11-19 05:15:56 -08:00
|
|
|
|
|
|
|
// Should return false with failed sensor
|
|
|
|
Sensor::resetMockValue(SensorType::DriverThrottleIntent);
|
|
|
|
EXPECT_FALSE(dut.isInsideTpsCondition());
|
|
|
|
|
|
|
|
// Should return false when throttle is closed
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 5.0f);
|
|
|
|
EXPECT_FALSE(dut.isInsideTpsCondition());
|
2024-02-29 19:21:05 -08:00
|
|
|
|
2020-11-19 05:15:56 -08:00
|
|
|
// Should return true when throttle is opened past the threshold
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 20.0f);
|
|
|
|
EXPECT_TRUE(dut.isInsideTpsCondition());
|
|
|
|
}
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
|
|
|
|
TEST(LaunchControl, VSSCondition) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
2021-11-16 13:46:54 -08:00
|
|
|
// Test Speed threshold
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchSpeedThreshold = 30;
|
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 10.0);
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_TRUE(dut.isInsideSpeedCondition());
|
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 40.0);
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_FALSE(dut.isInsideSpeedCondition());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2023-07-20 13:05:16 -07:00
|
|
|
TEST(LaunchControl, ZeroVSSCondition) {
|
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
|
|
|
// Test Speed threshold
|
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
|
|
|
engineConfiguration->launchSpeedThreshold = 0;
|
|
|
|
|
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 10.0);
|
2023-07-20 13:09:52 -07:00
|
|
|
EXPECT_TRUE(dut.isInsideSpeedCondition());
|
2023-07-20 13:05:16 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(LaunchControl, VSSConditionWithSwitch) {
|
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
|
|
|
// Test Speed threshold
|
|
|
|
engineConfiguration->launchActivationMode = SWITCH_INPUT_LAUNCH;
|
|
|
|
engineConfiguration->launchActivatePin = Gpio::G1;
|
|
|
|
setMockState(engineConfiguration->launchActivatePin, true);
|
|
|
|
engineConfiguration->launchSpeedThreshold = 30;
|
|
|
|
|
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 10.0);
|
|
|
|
EXPECT_TRUE(dut.isInsideSpeedCondition());
|
|
|
|
|
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 40.0);
|
2023-07-20 13:25:24 -07:00
|
|
|
EXPECT_FALSE(dut.isInsideSpeedCondition());
|
2023-07-20 13:05:16 -07:00
|
|
|
}
|
|
|
|
|
2020-11-19 18:14:38 -08:00
|
|
|
TEST(LaunchControl, RPMCondition) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
|
|
|
engineConfiguration->launchRpm = 3000;
|
|
|
|
|
2024-05-21 00:06:17 -07:00
|
|
|
EXPECT_EQ(engineConfiguration->launchRpmWindow, 500);
|
2020-11-19 18:14:38 -08:00
|
|
|
|
2024-05-21 00:06:17 -07:00
|
|
|
EXPECT_EQ(dut.calculateRPMLaunchCondition(2499), LaunchCondition::NotMet);
|
|
|
|
EXPECT_EQ(dut.calculateRPMLaunchCondition(2500), LaunchCondition::PreLaunch);
|
|
|
|
EXPECT_EQ(dut.calculateRPMLaunchCondition(2900), LaunchCondition::PreLaunch);
|
|
|
|
EXPECT_EQ(dut.calculateRPMLaunchCondition(2999), LaunchCondition::PreLaunch);
|
|
|
|
EXPECT_EQ(dut.calculateRPMLaunchCondition(3000), LaunchCondition::Launch);
|
2024-05-20 12:54:05 -07:00
|
|
|
EXPECT_EQ(dut.calculateRPMLaunchCondition(3100), LaunchCondition::Launch);
|
2020-11-19 18:14:38 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(LaunchControl, SwitchInputCondition) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
|
|
|
//activation based on VSS
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
//active by switch
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = SWITCH_INPUT_LAUNCH;
|
2022-04-28 14:32:39 -07:00
|
|
|
engineConfiguration->launchActivatePin = Gpio::G1;
|
2020-11-19 18:14:38 -08:00
|
|
|
setMockState(engineConfiguration->launchActivatePin, true);
|
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
setMockState(engineConfiguration->launchActivatePin, false);
|
|
|
|
EXPECT_FALSE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
//by clutch
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = CLUTCH_INPUT_LAUNCH;
|
2022-04-28 14:32:39 -07:00
|
|
|
engineConfiguration->clutchDownPin = Gpio::G2;
|
2020-11-19 18:14:38 -08:00
|
|
|
engineConfiguration->clutchDownPinMode = PI_PULLUP;
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, true);
|
2021-11-16 01:15:29 -08:00
|
|
|
engine->updateSwitchInputs();
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, false);
|
2021-11-16 01:15:29 -08:00
|
|
|
engine->updateSwitchInputs();
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_FALSE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
engineConfiguration->clutchDownPinMode = PI_PULLDOWN;
|
2021-07-24 16:49:23 -07:00
|
|
|
engineConfiguration->clutchDownPinInverted = true;
|
2020-11-19 18:14:38 -08:00
|
|
|
setMockState(engineConfiguration->clutchDownPin, false);
|
2021-11-16 01:15:29 -08:00
|
|
|
engine->updateSwitchInputs();
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, true);
|
2021-11-16 01:15:29 -08:00
|
|
|
engine->updateSwitchInputs();
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_FALSE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(LaunchControl, CombinedCondition) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
|
|
|
|
//check VSS normal usage
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
|
|
|
|
2020-11-19 18:14:38 -08:00
|
|
|
engineConfiguration->launchRpm = 3000;
|
2022-07-20 15:48:55 -07:00
|
|
|
engineConfiguration->launchTpsThreshold = 10;
|
2020-11-19 18:14:38 -08:00
|
|
|
//valid TPS
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 20.0f);
|
2024-02-29 19:21:05 -08:00
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 10.0);
|
2022-01-20 20:43:18 -08:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 1200);
|
2020-11-19 18:14:38 -08:00
|
|
|
|
2024-05-20 12:54:05 -07:00
|
|
|
EXPECT_FALSE(dut.isLaunchConditionMet(1200));
|
2020-11-19 18:14:38 -08:00
|
|
|
|
2024-05-20 12:54:05 -07:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 3200);
|
|
|
|
EXPECT_TRUE(dut.isLaunchConditionMet(3200));
|
2020-11-19 18:14:38 -08:00
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 40.0);
|
2024-05-20 12:54:05 -07:00
|
|
|
EXPECT_FALSE(dut.isLaunchConditionMet(3200));
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
}
|
2020-12-01 10:03:42 -08:00
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
static void setDefaultLaunchParameters() {
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchRpm = 4000; // Rpm to trigger Launch condition
|
|
|
|
// engineConfiguration->launchTimingRetard = 10; // retard in absolute degrees ATDC
|
2024-03-09 06:42:41 -08:00
|
|
|
engineConfiguration->launchRpmWindow = 500; // RPM window (Launch RPM - Window) for transitioning to full retard
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchSparkCutEnable = true;
|
|
|
|
engineConfiguration->launchFuelCutEnable = false;
|
|
|
|
engineConfiguration->launchSpeedThreshold = 10; //maximum speed allowed before disable launch
|
2024-02-29 19:21:05 -08:00
|
|
|
engineConfiguration->launchFuelAdderPercent = 10; // Extra fuel in % when launch are triggered
|
2024-04-23 19:36:49 -07:00
|
|
|
// engineConfiguration->launchBoostDuty = 70; // boost valve duty cycle at launch
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchActivateDelay = 3; // Delay in seconds for launch to kick in
|
|
|
|
// engineConfiguration->enableLaunchRetard = true;
|
|
|
|
// dead code todo engineConfiguration->enableLaunchBoost = true;
|
|
|
|
engineConfiguration->launchSmoothRetard = true; //interpolates the advance linear from launchrpm to fully retarded at launchtimingrpmrange
|
|
|
|
// dead code todo engineConfiguration->antiLagRpmTreshold = 3000;
|
|
|
|
}
|
|
|
|
|
2020-12-01 10:03:42 -08:00
|
|
|
TEST(LaunchControl, CompleteRun) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
//load default config
|
2021-11-16 01:15:29 -08:00
|
|
|
setDefaultLaunchParameters();
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
//check VSS normal usage
|
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchSpeedThreshold = 30;
|
|
|
|
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchRpm = 3000;
|
2022-07-20 15:48:55 -07:00
|
|
|
engineConfiguration->launchTpsThreshold = 10;
|
2021-11-15 18:13:01 -08:00
|
|
|
engineConfiguration->launchControlEnabled = true;
|
2020-12-01 10:03:42 -08:00
|
|
|
//valid TPS
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 20.0f);
|
2024-02-29 19:21:05 -08:00
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 10.0);
|
2022-01-20 20:43:18 -08:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 1200);
|
2020-12-01 10:03:42 -08:00
|
|
|
|
2021-11-15 15:57:12 -08:00
|
|
|
engine->launchController.update();
|
|
|
|
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
//check if we have some sort of cut? we should not have at this point
|
2021-11-15 16:54:34 -08:00
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchSparkRpmRetardCondition());
|
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchFuelRpmRetardCondition());
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
|
2022-01-20 20:43:18 -08:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 3510);
|
2020-12-01 10:03:42 -08:00
|
|
|
//update condition check
|
2021-11-15 15:57:12 -08:00
|
|
|
engine->launchController.update();
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
|
|
|
|
//we have a 3 seconds delay to actually enable it!
|
2021-03-11 21:43:48 -08:00
|
|
|
eth.moveTimeForwardAndInvokeEventsSec(1);
|
2021-11-15 15:57:12 -08:00
|
|
|
engine->launchController.update();
|
2024-02-29 19:21:05 -08:00
|
|
|
|
2021-11-15 16:54:34 -08:00
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchSparkRpmRetardCondition());
|
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchFuelRpmRetardCondition());
|
2020-12-01 10:03:42 -08:00
|
|
|
|
2021-03-11 21:43:48 -08:00
|
|
|
eth.moveTimeForwardAndInvokeEventsSec(3);
|
2021-11-15 15:57:12 -08:00
|
|
|
engine->launchController.update();
|
2020-12-01 10:03:42 -08:00
|
|
|
|
2021-11-15 16:54:34 -08:00
|
|
|
|
|
|
|
EXPECT_TRUE(engine->launchController.isLaunchSparkRpmRetardCondition());
|
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchFuelRpmRetardCondition());
|
2020-12-01 10:03:42 -08:00
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 40.0);
|
2021-11-15 15:57:12 -08:00
|
|
|
engine->launchController.update();
|
2021-11-15 16:54:34 -08:00
|
|
|
|
|
|
|
|
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchSparkRpmRetardCondition());
|
|
|
|
EXPECT_FALSE(engine->launchController.isLaunchFuelRpmRetardCondition());
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
}
|
2023-05-25 12:17:07 -07:00
|
|
|
|
|
|
|
TEST(LaunchControl, hardSkip) {
|
|
|
|
SoftSparkLimiter hardSparkLimiter(true);
|
|
|
|
ASSERT_FALSE(hardSparkLimiter.shouldSkip());
|
|
|
|
|
|
|
|
|
|
|
|
hardSparkLimiter.setTargetSkipRatio(1);
|
|
|
|
// open question if we need special handling of '1' or random would just work?
|
|
|
|
ASSERT_TRUE(hardSparkLimiter.shouldSkip());
|
|
|
|
|
|
|
|
int counter = 0;
|
|
|
|
hardSparkLimiter.setTargetSkipRatio(0.5);
|
|
|
|
for (int i =0;i<1000;i++) {
|
|
|
|
if (hardSparkLimiter.shouldSkip()) {
|
|
|
|
counter++;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
ASSERT_TRUE(counter > 400 && counter < 600) << "How good is random " << counter;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|