const airmass (#2694)

This commit is contained in:
Matthew Kennedy 2021-05-14 04:17:22 -07:00 committed by GitHub
parent 989677c863
commit 1d10fbc7a8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
15 changed files with 35 additions and 29 deletions

View File

@ -4,9 +4,9 @@
EXTERN_ENGINE; EXTERN_ENGINE;
AirmassModelBase::AirmassModelBase(const ValueProvider3D& veTable) : m_veTable(&veTable) {} AirmassVeModelBase::AirmassVeModelBase(const ValueProvider3D& veTable) : m_veTable(&veTable) {}
float AirmassModelBase::getVeLoadAxis(float passedLoad) const { float AirmassVeModelBase::getVeLoadAxis(float passedLoad) const {
switch(CONFIG(veOverrideMode)) { switch(CONFIG(veOverrideMode)) {
case VE_None: return passedLoad; case VE_None: return passedLoad;
case VE_MAP: return Sensor::get(SensorType::Map).value_or(0); case VE_MAP: return Sensor::get(SensorType::Map).value_or(0);
@ -15,7 +15,7 @@ float AirmassModelBase::getVeLoadAxis(float passedLoad) const {
} }
} }
float AirmassModelBase::getVe(int rpm, float load) const { float AirmassVeModelBase::getVe(int rpm, float load) const {
efiAssert(OBD_PCM_Processor_Fault, m_veTable != nullptr, "VE table null", 0); efiAssert(OBD_PCM_Processor_Fault, m_veTable != nullptr, "VE table null", 0);
// Override the load value if necessary // Override the load value if necessary

View File

@ -9,12 +9,15 @@ struct AirmassResult {
float EngineLoadPercent = 100; float EngineLoadPercent = 100;
}; };
class AirmassModelBase { struct AirmassModelBase {
virtual AirmassResult getAirmass(int rpm) const = 0;
};
class AirmassVeModelBase : public AirmassModelBase {
public: public:
DECLARE_ENGINE_PTR; DECLARE_ENGINE_PTR;
explicit AirmassModelBase(const ValueProvider3D& veTable); explicit AirmassVeModelBase(const ValueProvider3D& veTable);
virtual AirmassResult getAirmass(int rpm) = 0;
protected: protected:
// Retrieve the user-calibrated volumetric efficiency from the table // Retrieve the user-calibrated volumetric efficiency from the table

View File

@ -1,7 +1,7 @@
#include "alphan_airmass.h" #include "alphan_airmass.h"
#include "sensor.h" #include "sensor.h"
AirmassResult AlphaNAirmass::getAirmass(int rpm) { AirmassResult AlphaNAirmass::getAirmass(int rpm) const {
auto tps = Sensor::get(SensorType::Tps1); auto tps = Sensor::get(SensorType::Tps1);
if (!tps.Valid) { if (!tps.Valid) {

View File

@ -6,5 +6,5 @@ class AlphaNAirmass : public SpeedDensityBase {
public: public:
explicit AlphaNAirmass(const ValueProvider3D& veTable) : SpeedDensityBase(veTable) {} explicit AlphaNAirmass(const ValueProvider3D& veTable) : SpeedDensityBase(veTable) {}
AirmassResult getAirmass(int rpm) override; AirmassResult getAirmass(int rpm) const override;
}; };

View File

@ -5,7 +5,7 @@
EXTERN_ENGINE; EXTERN_ENGINE;
AirmassResult MafAirmass::getAirmass(int rpm) { AirmassResult MafAirmass::getAirmass(int rpm) const {
float maf = Sensor::get(SensorType::Maf).value_or(0) + engine->engineLoadAccelEnrichment.getEngineLoadEnrichment(PASS_ENGINE_PARAMETER_SIGNATURE); float maf = Sensor::get(SensorType::Maf).value_or(0) + engine->engineLoadAccelEnrichment.getEngineLoadEnrichment(PASS_ENGINE_PARAMETER_SIGNATURE);
return getAirmassImpl(maf, rpm); return getAirmassImpl(maf, rpm);
} }

View File

@ -2,11 +2,11 @@
#include "airmass.h" #include "airmass.h"
class MafAirmass final : public AirmassModelBase { class MafAirmass final : public AirmassVeModelBase {
public: public:
explicit MafAirmass(const ValueProvider3D& veTable) : AirmassModelBase(veTable) {} explicit MafAirmass(const ValueProvider3D& veTable) : AirmassVeModelBase(veTable) {}
AirmassResult getAirmass(int rpm) override; AirmassResult getAirmass(int rpm) const override;
// Compute airmass based on flow & engine speed // Compute airmass based on flow & engine speed
AirmassResult getAirmassImpl(float massAirFlow, int rpm) const; AirmassResult getAirmassImpl(float massAirFlow, int rpm) const;

View File

@ -5,7 +5,7 @@
EXTERN_ENGINE; EXTERN_ENGINE;
AirmassResult SpeedDensityAirmass::getAirmass(int rpm) { AirmassResult SpeedDensityAirmass::getAirmass(int rpm) const {
ScopePerf perf(PE::GetSpeedDensityFuel); ScopePerf perf(PE::GetSpeedDensityFuel);
/** /**

View File

@ -9,7 +9,7 @@ public:
, m_mapEstimationTable(&mapEstimationTable) , m_mapEstimationTable(&mapEstimationTable)
{} {}
AirmassResult getAirmass(int rpm) override; AirmassResult getAirmass(int rpm) const override;
float getMap(int rpm) const; float getMap(int rpm) const;

View File

@ -25,7 +25,7 @@ float idealGasLaw(float volume, float pressure, float temperature) {
return volume * pressure / (AIR_R * temperature); return volume * pressure / (AIR_R * temperature);
} }
float SpeedDensityBase::getAirmassImpl(float ve, float manifoldPressure, float temperature DECLARE_ENGINE_PARAMETER_SUFFIX) { /*static*/ float SpeedDensityBase::getAirmassImpl(float ve, float manifoldPressure, float temperature DECLARE_ENGINE_PARAMETER_SUFFIX) {
float cycleAir = ve * idealGasLaw(CONFIG(specs.displacement), manifoldPressure, temperature); float cycleAir = ve * idealGasLaw(CONFIG(specs.displacement), manifoldPressure, temperature);
return cycleAir / CONFIG(specs.cylindersCount); return cycleAir / CONFIG(specs.cylindersCount);
} }

View File

@ -13,9 +13,9 @@
float idealGasLaw(float volume, float pressure, float temperature); float idealGasLaw(float volume, float pressure, float temperature);
class SpeedDensityBase : public AirmassModelBase { class SpeedDensityBase : public AirmassVeModelBase {
protected: protected:
explicit SpeedDensityBase(const ValueProvider3D& veTable) : AirmassModelBase(veTable) {} explicit SpeedDensityBase(const ValueProvider3D& veTable) : AirmassVeModelBase(veTable) {}
public: public:
static float getAirmassImpl(float ve, float manifoldPressure, float temperature DECLARE_ENGINE_PARAMETER_SUFFIX); static float getAirmassImpl(float ve, float manifoldPressure, float temperature DECLARE_ENGINE_PARAMETER_SUFFIX);

View File

@ -35,7 +35,7 @@
#define SLOW_CALLBACK_PERIOD_MS 50 #define SLOW_CALLBACK_PERIOD_MS 50
class RpmCalculator; class RpmCalculator;
class AirmassModelBase; struct AirmassModelBase;
#define MAF_DECODING_CACHE_SIZE 256 #define MAF_DECODING_CACHE_SIZE 256

View File

@ -165,8 +165,8 @@ static SpeedDensityAirmass sdAirmass(veMap, mapEstimationTable);
static MafAirmass mafAirmass(veMap); static MafAirmass mafAirmass(veMap);
static AlphaNAirmass alphaNAirmass(veMap); static AlphaNAirmass alphaNAirmass(veMap);
AirmassModelBase* getAirmassModel(DECLARE_ENGINE_PARAMETER_SIGNATURE) { AirmassModelBase* getAirmassModel(engine_load_mode_e mode DECLARE_ENGINE_PARAMETER_SUFFIX) {
switch (CONFIG(fuelAlgorithm)) { switch (mode) {
case LM_SPEED_DENSITY: return &sdAirmass; case LM_SPEED_DENSITY: return &sdAirmass;
case LM_REAL_MAF: return &mafAirmass; case LM_REAL_MAF: return &mafAirmass;
case LM_ALPHA_N: return &alphaNAirmass; case LM_ALPHA_N: return &alphaNAirmass;
@ -188,7 +188,7 @@ static float getBaseFuelMass(int rpm DECLARE_ENGINE_PARAMETER_SUFFIX) {
ScopePerf perf(PE::GetBaseFuel); ScopePerf perf(PE::GetBaseFuel);
// airmass modes - get airmass first, then convert to fuel // airmass modes - get airmass first, then convert to fuel
auto model = getAirmassModel(PASS_ENGINE_PARAMETER_SIGNATURE); auto model = getAirmassModel(CONFIG(fuelAlgorithm) PASS_ENGINE_PARAMETER_SUFFIX);
efiAssert(CUSTOM_ERR_ASSERT, model != nullptr, "Invalid airmass mode", 0.0f); efiAssert(CUSTOM_ERR_ASSERT, model != nullptr, "Invalid airmass mode", 0.0f);
auto airmass = model->getAirmass(rpm); auto airmass = model->getAirmass(rpm);

View File

@ -7,8 +7,8 @@
#pragma once #pragma once
#include "engine.h" #include "engine_ptr.h"
#include "airmass.h" #include "rusefi_types.h"
void initFuelMap(DECLARE_ENGINE_PARAMETER_SIGNATURE); void initFuelMap(DECLARE_ENGINE_PARAMETER_SIGNATURE);
@ -31,3 +31,6 @@ floatms_t getInjectionMass(int rpm DECLARE_ENGINE_PARAMETER_SUFFIX);
percent_t getInjectorDutyCycle(int rpm DECLARE_ENGINE_PARAMETER_SUFFIX); percent_t getInjectorDutyCycle(int rpm DECLARE_ENGINE_PARAMETER_SUFFIX);
float getStandardAirCharge(DECLARE_ENGINE_PARAMETER_SIGNATURE); float getStandardAirCharge(DECLARE_ENGINE_PARAMETER_SIGNATURE);
struct AirmassModelBase;
AirmassModelBase* getAirmassModel(engine_load_mode_e mode DECLARE_ENGINE_PARAMETER_SUFFIX);

View File

@ -59,13 +59,13 @@ public:
MOCK_METHOD(void, scheduleForLater, (scheduling_s *scheduling, int delayUs, action_s action), (override)); MOCK_METHOD(void, scheduleForLater, (scheduling_s *scheduling, int delayUs, action_s action), (override));
}; };
class MockAirmass : public AirmassModelBase { class MockAirmass : public AirmassVeModelBase {
public: public:
MockAirmass() : AirmassModelBase(veTable) {} MockAirmass() : AirmassVeModelBase(veTable) {}
MockVp3d veTable; MockVp3d veTable;
MOCK_METHOD(AirmassResult, getAirmass, (int rpm), (override)); MOCK_METHOD(AirmassResult, getAirmass, (int rpm), (const, override));
}; };
class MockInjectorModel2 : public IInjectorModel { class MockInjectorModel2 : public IInjectorModel {

View File

@ -112,10 +112,10 @@ TEST(AirmassModes, VeOverride) {
EXPECT_CALL(veTable, getValue(_, 30.0f)).WillOnce(Return(0)); EXPECT_CALL(veTable, getValue(_, 30.0f)).WillOnce(Return(0));
} }
struct DummyAirmassModel : public AirmassModelBase { struct DummyAirmassModel : public AirmassVeModelBase {
DummyAirmassModel(const ValueProvider3D& veTable) : AirmassModelBase(veTable) {} DummyAirmassModel(const ValueProvider3D& veTable) : AirmassVeModelBase(veTable) {}
AirmassResult getAirmass(int rpm) override { AirmassResult getAirmass(int rpm) const override {
// Default load value 10, will be overriden // Default load value 10, will be overriden
getVe(rpm, 10.0f); getVe(rpm, 10.0f);