Better handling of RPM during stop of cranking #3803
This commit is contained in:
parent
a1374062f0
commit
9f5188bf30
|
@ -608,7 +608,7 @@ void configureRusefiLuaHooks(lua_State* l) {
|
||||||
});
|
});
|
||||||
|
|
||||||
lua_register(l, "getTimeSinceTriggerEventMs", [](lua_State* l) {
|
lua_register(l, "getTimeSinceTriggerEventMs", [](lua_State* l) {
|
||||||
int result = engine->triggerCentral.m_lastEventTimer.getElapsedUs() / 1000;
|
int result = engine->triggerCentral.getSecondsSinceTriggerEvent() * 1000;
|
||||||
lua_pushnumber(l, result);
|
lua_pushnumber(l, result);
|
||||||
return 1;
|
return 1;
|
||||||
});
|
});
|
||||||
|
|
|
@ -71,15 +71,13 @@ public:
|
||||||
|
|
||||||
expected<float> getCurrentEnginePhase(efitick_t nowNt) const;
|
expected<float> getCurrentEnginePhase(efitick_t nowNt) const;
|
||||||
|
|
||||||
float getTimeSinceTriggerEvent(efitick_t nowNt) const {
|
float getSecondsSinceTriggerEvent(efitick_t nowNt) const {
|
||||||
return m_lastEventTimer.getElapsedSeconds(nowNt);
|
return m_lastEventTimer.getElapsedSeconds(nowNt);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool engineMovedRecently(efitick_t nowNt) const {
|
bool engineMovedRecently(efitick_t nowNt) const {
|
||||||
// Trigger event some time in the past second = engine moving
|
constexpr float oneRevolutionLimitInSeconds = 60.0 / RPM_LOW_THRESHOLD;
|
||||||
// distributor single tooth, large engines crank at close to 120 RPM
|
return getSecondsSinceTriggerEvent(nowNt) < oneRevolutionLimitInSeconds / triggerShape.getSize();
|
||||||
// todo: make this logic account current trigger to stop idle much faster if we have more teeth on trigger wheels?
|
|
||||||
return getTimeSinceTriggerEvent(nowNt) < 60.0 / RPM_LOW_THRESHOLD / 2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool engineMovedRecently() const {
|
bool engineMovedRecently() const {
|
||||||
|
|
Loading…
Reference in New Issue