Etb rev limit (#2820)

* cfg

* impl

* a test

* don't break the ts channel

* text
This commit is contained in:
Matthew Kennedy 2021-06-16 05:44:48 -07:00 committed by GitHub
parent 46494877af
commit 93adb8ea76
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 60 additions and 3 deletions

View File

@ -316,6 +316,14 @@ expected<percent_t> EtbController::getSetpointEtb() const {
// 100% target from table -> 100% target position
percent_t targetPosition = interpolateClamped(0, etbIdleAddition, 100, 100, targetFromTable);
// Lastly, apply ETB rev limiter
auto etbRpmLimit = CONFIG(etbRevLimitStart);
if (etbRpmLimit != 0) {
auto fullyLimitedRpm = etbRpmLimit + CONFIG(etbRevLimitRange);
// Linearly taper throttle to closed from the limit across the range
targetPosition = interpolateClamped(etbRpmLimit, targetPosition, fullyLimitedRpm, 0, rpm);
}
#if EFI_TUNER_STUDIO
if (m_function == ETB_Throttle1) {
tsOutputChannels.etbTarget = targetPosition;

View File

@ -569,8 +569,8 @@ int16_t tpsErrorDetectionTooHigh;+TPS error detection: what throttle % is unreal
cranking_parameters_s cranking
float primingSquirtDurationMs;;"*C", 1, 0, -40, 200, 1
float ignitionDwellForCrankingMs;+Dwell duration while cranking;"ms", 1, 0, 0, 200, 1
float unused104;;"deg", 1, 0, 0, 3000.0, 0
uint16_t etbRevLimitStart;+Once engine speed passes this value, start reducing ETB angle.;1, 0, 0, 15000, 0
uint16_t etbRevLimitRange;+This far above 'Soft limiter start', fully close the throttle. At the bottom of the range, throttle control is normal. At the top of the range, the throttle is fully closed.;1, 0, 0, 2000, 0
MAP_sensor_config_s map;@see hasMapSensor\n@see isMapAveragingEnabled

View File

@ -3047,12 +3047,18 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00"
field = "RPM hard limit", rpmHardLimit, { cutFuelOnHardLimit || cutSparkOnHardLimit }
field = "Boost cut pressure", boostCutPressure
dialog = etbLimits, "Electronic Throttle Limiting"
field = "Smoothly close the throttle to limit RPM."
field = "Soft limiter start", etbRevLimitStart
field = "Soft limiter range", etbRevLimitRange
dialog = fallbacks, "Fallbacks"
field = "Use MAP estimation table as fallback", enableMapEstimationTableFallback
field = "Failed MAP sensor fallback", failedMapFallback, { !enableMapEstimationTableFallback }
dialog = limitsAndFallback, "Limits and fallbacks"
panel = limits
panel = etbLimits
panel = fallbacks
; Engine->Base Engine Settings

View File

@ -346,6 +346,49 @@ TEST(etb, setpointIdle) {
EXPECT_FLOAT_EQ(55, etb.getSetpoint().value_or(-1));
}
TEST(etb, setpointRevLimit) {
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
// Configure 5000 limit start, with 750 rpm taper
engineConfiguration->etbRevLimitStart = 5000;
engineConfiguration->etbRevLimitRange = 750;
// Must have TPS & PPS initialized for ETB setup
Sensor::setMockValue(SensorType::Tps1, 0.0f, true);
Sensor::setMockValue(SensorType::AcceleratorPedal, 0.0f, true);
EtbController etb;
INJECT_ENGINE_REFERENCE(&etb);
// Mock pedal map to just return 80%
StrictMock<MockVp3d> pedalMap;
EXPECT_CALL(pedalMap, getValue(_, _))
.WillRepeatedly([](float, float) {
return 80;
});
etb.init(ETB_Throttle1, nullptr, nullptr, &pedalMap, true);
// Below threshold, should return unadjusted throttle
ENGINE(rpmCalculator.mockRpm) = 1000;
EXPECT_EQ(80, etb.getSetpoint().value_or(-1));
// At threshold, should return unadjusted throttle
ENGINE(rpmCalculator.mockRpm) = 5000;
EXPECT_EQ(80, etb.getSetpoint().value_or(-1));
// Middle of range, should return half of unadjusted
ENGINE(rpmCalculator.mockRpm) = 5375;
EXPECT_EQ(40, etb.getSetpoint().value_or(-1));
// At limit+range, should return 0
ENGINE(rpmCalculator.mockRpm) = 5750;
EXPECT_EQ(0, etb.getSetpoint().value_or(-1));
// Above limit+range, should return 0
ENGINE(rpmCalculator.mockRpm) = 6000;
EXPECT_EQ(0, etb.getSetpoint().value_or(-1));
}
TEST(etb, setpointNoPedalMap) {
EtbController etb;