From 2ca5f906136c4fa30e0a04c25cd3c6636cb986f8 Mon Sep 17 00:00:00 2001 From: Matthew Kennedy Date: Tue, 11 Aug 2020 20:35:10 -0700 Subject: [PATCH 1/2] simplify fuel math --- firmware/controllers/algo/fuel_math.cpp | 32 +++++++++++++++---------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/firmware/controllers/algo/fuel_math.cpp b/firmware/controllers/algo/fuel_math.cpp index 221d725f67..c0dde746ef 100644 --- a/firmware/controllers/algo/fuel_math.cpp +++ b/firmware/controllers/algo/fuel_math.cpp @@ -261,6 +261,23 @@ int getNumberOfInjections(injection_mode_e mode DECLARE_ENGINE_PARAMETER_SUFFIX) } } +float getInjectionModeDurationMultiplier(DECLARE_ENGINE_PARAMETER_SIGNATURE) { + injection_mode_e mode = ENGINE(getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE)); + + switch (mode) { + case IM_SIMULTANEOUS: + return 1.0f / engineConfiguration->specs.cylindersCount; + case IM_SEQUENTIAL: + case IM_SINGLE_POINT: + return 1; + case IM_BATCH: + return 0.5f; + default: + firmwareError(CUSTOM_ERR_INVALID_INJECTION_MODE, "Unexpected injection_mode_e %d", mode); + return 0; + } +} + /** * This is more like MOSFET duty cycle since durations include injector lag * @see getCoilDutyCycle @@ -287,31 +304,20 @@ floatms_t getInjectionDuration(int rpm DECLARE_ENGINE_PARAMETER_SUFFIX) { ScopePerf perf(PE::GetInjectionDuration); #if EFI_SHAFT_POSITION_INPUT - bool isCranking = ENGINE(rpmCalculator).isCranking(PASS_ENGINE_PARAMETER_SIGNATURE); - injection_mode_e mode = ENGINE(getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE)); - int numberOfInjections = getNumberOfInjections(mode PASS_ENGINE_PARAMETER_SUFFIX); - if (numberOfInjections == 0) { - warning(CUSTOM_CONFIG_NOT_READY, "config not ready"); - return 0; // we can end up here during configuration reset - } - // Always update base fuel - some cranking modes use it floatms_t baseFuel = getBaseFuel(rpm PASS_ENGINE_PARAMETER_SUFFIX); + bool isCranking = ENGINE(rpmCalculator).isCranking(PASS_ENGINE_PARAMETER_SIGNATURE); floatms_t fuelPerCycle = getFuel(isCranking, baseFuel PASS_ENGINE_PARAMETER_SUFFIX); efiAssert(CUSTOM_ERR_ASSERT, !cisnan(fuelPerCycle), "NaN fuelPerCycle", 0); - if (mode == IM_SINGLE_POINT) { - // here we convert per-cylinder fuel amount into total engine amount since the single injector serves all cylinders - fuelPerCycle *= engineConfiguration->specs.cylindersCount; - } // Fuel cut-off isn't just 0 or 1, it can be tapered fuelPerCycle *= ENGINE(engineState.fuelCutoffCorrection); // If no fuel, don't add injector lag if (fuelPerCycle == 0.0f) return 0; - floatms_t theoreticalInjectionLength = fuelPerCycle / numberOfInjections; + floatms_t theoreticalInjectionLength = fuelPerCycle * getInjectionModeDurationMultiplier(PASS_ENGINE_PARAMETER_SIGNATURE); floatms_t injectorLag = ENGINE(engineState.running.injectorLag); if (cisnan(injectorLag)) { warning(CUSTOM_ERR_INJECTOR_LAG, "injectorLag not ready"); From f722ced7a9c736aa0036397e99c621f8d30107a6 Mon Sep 17 00:00:00 2001 From: Matthew Kennedy Date: Wed, 12 Aug 2020 22:18:56 -0700 Subject: [PATCH 2/2] safety --- firmware/controllers/algo/fuel_math.cpp | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/firmware/controllers/algo/fuel_math.cpp b/firmware/controllers/algo/fuel_math.cpp index c0dde746ef..5f19441c5e 100644 --- a/firmware/controllers/algo/fuel_math.cpp +++ b/firmware/controllers/algo/fuel_math.cpp @@ -265,8 +265,16 @@ float getInjectionModeDurationMultiplier(DECLARE_ENGINE_PARAMETER_SIGNATURE) { injection_mode_e mode = ENGINE(getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE)); switch (mode) { - case IM_SIMULTANEOUS: - return 1.0f / engineConfiguration->specs.cylindersCount; + case IM_SIMULTANEOUS: { + auto cylCount = engineConfiguration->specs.cylindersCount; + + if (cylCount == 0) { + // we can end up here during configuration reset + return 0; + } + + return 1.0f / cylCount; + } case IM_SEQUENTIAL: case IM_SINGLE_POINT: return 1;