rusefi/firmware/controllers/algo/fuel/dfco.cpp

49 lines
1.4 KiB
C++

#include "pch.h"
bool DfcoController::getState() const {
if (!engineConfiguration->coastingFuelCutEnabled) {
return false;
}
auto rpm = Sensor::getOrZero(SensorType::Rpm);
const auto [tpsValid, tpsPos] = Sensor::get(SensorType::DriverThrottleIntent);
const auto [cltValid, clt] = Sensor::get(SensorType::Clt);
const auto [mapValid, map] = Sensor::get(SensorType::Map);
// If some sensor is broken, inhibit DFCO
if (!tpsValid || !cltValid || !mapValid) {
return false;
}
bool mapActivate = map < engineConfiguration->coastingFuelCutMap;
bool tpsActivate = tpsPos < engineConfiguration->coastingFuelCutTps;
bool cltActivate = clt > engineConfiguration->coastingFuelCutClt;
// True if throttle, MAP, and CLT are all acceptable for DFCO to occur
bool dfcoAllowed = mapActivate && tpsActivate && cltActivate;
bool rpmActivate = (rpm > engineConfiguration->coastingFuelCutRpmHigh);
bool rpmDeactivate = (rpm < engineConfiguration->coastingFuelCutRpmLow);
// RPM is high enough, and DFCO allowed
if (dfcoAllowed && rpmActivate) {
return true;
}
// RPM too low, or DFCO not allowed
if (!dfcoAllowed || rpmDeactivate) {
return false;
}
// No conditions hit, no change to state (provides hysteresis)
return m_isDfco;
}
void DfcoController::update() {
// Run state machine
m_isDfco = getState();
}
bool DfcoController::cutFuel() const {
return m_isDfco;
}