2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2020-07-23 01:12:38 -07:00
|
|
|
#include "airmass.h"
|
2021-01-10 21:54:37 -08:00
|
|
|
#include "idle_thread.h"
|
2020-09-06 16:06:32 -07:00
|
|
|
|
2021-05-14 04:17:22 -07:00
|
|
|
AirmassVeModelBase::AirmassVeModelBase(const ValueProvider3D& veTable) : m_veTable(&veTable) {}
|
2020-07-23 01:12:38 -07:00
|
|
|
|
2023-05-02 15:04:15 -07:00
|
|
|
static float getVeLoadAxis(ve_override_e mode, float passedLoad) {
|
|
|
|
switch(mode) {
|
2020-09-07 07:15:42 -07:00
|
|
|
case VE_None: return passedLoad;
|
2021-10-05 16:59:07 -07:00
|
|
|
case VE_MAP: return Sensor::getOrZero(SensorType::Map);
|
|
|
|
case VE_TPS: return Sensor::getOrZero(SensorType::Tps1);
|
2020-09-07 07:15:42 -07:00
|
|
|
default: return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-24 23:21:39 -07:00
|
|
|
float AirmassVeModelBase::getVe(float rpm, float load, bool postState) const {
|
2023-04-11 17:01:34 -07:00
|
|
|
efiAssert(ObdCode::OBD_PCM_Processor_Fault, m_veTable != nullptr, "VE table null", 0);
|
2020-07-23 01:12:38 -07:00
|
|
|
|
2020-09-07 07:15:42 -07:00
|
|
|
// Override the load value if necessary
|
2023-05-02 15:04:15 -07:00
|
|
|
load = getVeLoadAxis(engineConfiguration->veOverrideMode, load);
|
2020-09-07 07:15:42 -07:00
|
|
|
|
2021-12-26 09:33:32 -08:00
|
|
|
percent_t ve = m_veTable->getValue(rpm, load);
|
2020-09-06 16:06:32 -07:00
|
|
|
|
2022-12-17 15:04:54 -08:00
|
|
|
#if EFI_IDLE_CONTROL
|
2020-09-06 16:06:32 -07:00
|
|
|
auto tps = Sensor::get(SensorType::Tps1);
|
2021-01-10 21:54:37 -08:00
|
|
|
// get VE from the separate table for Idle if idling
|
2022-01-20 11:08:54 -08:00
|
|
|
if (engine->module<IdleController>()->isIdlingOrTaper() &&
|
2023-03-27 00:42:56 -07:00
|
|
|
tps && engineConfiguration->useSeparateVeForIdle) {
|
2023-05-02 15:04:15 -07:00
|
|
|
float idleVeLoad = getVeLoadAxis(engineConfiguration->idleVeOverrideMode, load);
|
|
|
|
|
2022-01-20 11:08:54 -08:00
|
|
|
percent_t idleVe = interpolate3d(
|
|
|
|
config->idleVeTable,
|
2023-05-02 15:04:15 -07:00
|
|
|
config->idleVeLoadBins, idleVeLoad,
|
2022-01-20 11:08:54 -08:00
|
|
|
config->idleVeRpmBins, rpm
|
|
|
|
);
|
2023-03-27 00:42:56 -07:00
|
|
|
|
2020-09-06 16:06:32 -07:00
|
|
|
// interpolate between idle table and normal (running) table using TPS threshold
|
2023-03-27 00:42:56 -07:00
|
|
|
// 0 TPS -> idle table
|
|
|
|
// 1/2 threshold -> idle table
|
|
|
|
// idle threshold -> normal table
|
|
|
|
float idleThreshold = engineConfiguration->idlePidDeactivationTpsThreshold;
|
|
|
|
ve = interpolateClamped(idleThreshold / 2, idleVe, idleThreshold, ve, tps.Value);
|
2020-09-06 16:06:32 -07:00
|
|
|
}
|
2022-12-17 15:04:54 -08:00
|
|
|
#endif // EFI_IDLE_CONTROL
|
2020-09-06 16:06:32 -07:00
|
|
|
|
2022-10-19 03:42:22 -07:00
|
|
|
// Add any adjustments if configured
|
|
|
|
for (size_t i = 0; i < efi::size(config->veBlends); i++) {
|
|
|
|
auto result = calculateBlend(config->veBlends[i], rpm, load);
|
|
|
|
|
2023-05-15 17:18:35 -07:00
|
|
|
if (postState) {
|
|
|
|
engine->outputChannels.veBlendParameter[i] = result.BlendParameter;
|
|
|
|
engine->outputChannels.veBlendBias[i] = result.Bias;
|
|
|
|
engine->outputChannels.veBlendOutput[i] = result.Value;
|
|
|
|
}
|
2022-10-19 03:42:22 -07:00
|
|
|
|
2024-01-17 02:43:04 -08:00
|
|
|
// Skip extra floating point math if we can...
|
2022-10-19 03:42:22 -07:00
|
|
|
if (result.Value == 0) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Apply as a multiplier, not as an adder
|
|
|
|
// Value of +5 means add 5%, aka multiply by 1.05
|
|
|
|
ve *= ((100 + result.Value) * 0.01f);
|
|
|
|
}
|
|
|
|
|
2023-05-15 17:18:35 -07:00
|
|
|
if (postState) {
|
|
|
|
engine->engineState.currentVe = ve;
|
|
|
|
engine->engineState.veTableYAxis = load;
|
|
|
|
}
|
|
|
|
|
2021-12-26 09:33:32 -08:00
|
|
|
return ve * PERCENT_DIV;
|
2020-07-23 01:12:38 -07:00
|
|
|
}
|