custom-board-bundle-sample-.../firmware/controllers/algo/launch_control.cpp

167 lines
4.8 KiB
C++
Raw Normal View History

/*
* @file launch_control.cpp
*
* @date 10. sep. 2019
* Author: Ola Ruud
*/
#include "pch.h"
#if EFI_LAUNCH_CONTROL
#include "boost_control.h"
#include "launch_control.h"
#include "periodic_task.h"
#include "advance_map.h"
#include "engine_state.h"
#include "advance_map.h"
2021-11-25 19:40:19 -08:00
#include "tinymt32.h"
/**
* We can have active condition from switch or from clutch.
* In case we are dependent on VSS we just return true.
*/
2021-11-15 17:09:03 -08:00
bool LaunchControlBase::isInsideSwitchCondition() {
switch (engineConfiguration->launchActivationMode) {
case SWITCH_INPUT_LAUNCH:
2021-11-16 13:45:14 -08:00
#if !EFI_SIMULATOR
if (isBrainPinValid(engineConfiguration->launchActivatePin)) {
//todo: we should take into consideration if this sw is pulled high or low!
launchActivatePinState = efiReadPin(engineConfiguration->launchActivatePin);
}
2021-11-16 13:31:35 -08:00
#endif // EFI_PROD_CODE
2021-11-15 17:09:03 -08:00
return launchActivatePinState;
case CLUTCH_INPUT_LAUNCH:
if (isBrainPinValid(engineConfiguration->clutchDownPin)) {
return engine->clutchDownState;
} else {
return false;
}
default:
// ALWAYS_ACTIVE_LAUNCH
return true;
}
}
/**
2021-11-16 13:46:54 -08:00
* Returns True in case Vehicle speed is less then threshold.
* This condition would only return true based on speed if DisablebySpeed is true
* The condition logic is written in that way, that if we do not use disable by speed
* then we have to return true, and trust that we would disable by other condition!
*/
bool LaunchControlBase::isInsideSpeedCondition() const {
2021-10-05 16:59:07 -07:00
int speed = Sensor::getOrZero(SensorType::VehicleSpeed);
return (engineConfiguration->launchSpeedThreshold > speed) || (!(engineConfiguration->launchActivationMode == ALWAYS_ACTIVE_LAUNCH));
}
/**
2021-11-16 13:46:54 -08:00
* Returns false if TPS is invalid or TPS > preset threshold
*/
bool LaunchControlBase::isInsideTpsCondition() const {
auto tps = Sensor::get(SensorType::DriverThrottleIntent);
// Disallow launch without valid TPS
if (!tps.Valid) {
return false;
}
return engineConfiguration->launchTpsTreshold < tps.Value;
}
/**
* Condition is true as soon as we are above LaunchRpm
*/
bool LaunchControlBase::isInsideRPMCondition(int rpm) const {
int launchRpm = engineConfiguration->launchRpm;
return (launchRpm < rpm);
}
2021-11-15 17:09:03 -08:00
bool LaunchControlBase::isLaunchConditionMet(int rpm) {
activateSwitchCondition = isInsideSwitchCondition();
rpmCondition = isInsideRPMCondition(rpm);
speedCondition = isInsideSpeedCondition();
tpsCondition = isInsideTpsCondition();
#if EFI_TUNER_STUDIO
// todo: implement fancy logging of all live data
engine->outputChannels.launchSpeedCondition = speedCondition;
engine->outputChannels.launchRpmCondition = rpmCondition;
engine->outputChannels.launchTpsCondition = tpsCondition;
engine->outputChannels.launchActivateSwitchCondition = activateSwitchCondition;
#endif /* EFI_TUNER_STUDIO */
return speedCondition && activateSwitchCondition && rpmCondition && tpsCondition;
}
LaunchControlBase::LaunchControlBase() {
launchActivatePinState = false;
isLaunchCondition = false;
}
void LaunchControlBase::update() {
if (!engineConfiguration->launchControlEnabled) {
return;
}
int rpm = GET_RPM();
combinedConditions = isLaunchConditionMet(rpm);
//and still recalculate in case user changed the values
retardThresholdRpm = engineConfiguration->launchRpm + (engineConfiguration->enableLaunchRetard ?
engineConfiguration->launchAdvanceRpmRange : 0) + engineConfiguration->hardCutRpmRange;
if (!combinedConditions) {
// conditions not met, reset timer
2020-11-30 16:35:06 -08:00
m_launchTimer.reset();
2021-11-15 17:09:03 -08:00
isLaunchCondition = false;
} else {
// If conditions are met...
isLaunchCondition = m_launchTimer.hasElapsedSec(engineConfiguration->launchActivateDelay);
}
#if EFI_TUNER_STUDIO
engine->outputChannels.clutchDownState = engine->clutchDownState;
engine->outputChannels.launchActivatePinState = launchActivatePinState;
engine->outputChannels.launchIsLaunchCondition = isLaunchCondition;
engine->outputChannels.launchCombinedConditions = combinedConditions;
#endif /* EFI_TUNER_STUDIO */
}
2021-11-15 16:48:55 -08:00
bool LaunchControlBase::isLaunchRpmRetardCondition() const {
2021-11-15 17:09:03 -08:00
return isLaunchCondition && (retardThresholdRpm < GET_RPM());
2021-11-15 16:48:55 -08:00
}
bool LaunchControlBase::isLaunchSparkRpmRetardCondition() const {
return isLaunchRpmRetardCondition() && engineConfiguration->launchSparkCutEnable;
}
bool LaunchControlBase::isLaunchFuelRpmRetardCondition() const {
return isLaunchRpmRetardCondition() && engineConfiguration->launchFuelCutEnable;
}
2021-11-16 10:15:12 -08:00
void SoftSparkLimiter::setTargetSkipRatio(float targetSkipRatio) {
this->targetSkipRatio = targetSkipRatio;
}
2021-11-25 19:40:19 -08:00
static tinymt32_t tinymt;
2021-11-16 10:15:12 -08:00
bool SoftSparkLimiter::shouldSkip() {
if (targetSkipRatio == 0 || wasJustSkipped) {
wasJustSkipped = false;
return false;
}
2021-11-25 19:40:19 -08:00
float r = tinymt32_generate_float(&tinymt);
2021-11-16 10:15:12 -08:00
wasJustSkipped = r < 2 * targetSkipRatio;
return wasJustSkipped;
}
void initLaunchControl() {
2021-11-25 19:40:19 -08:00
tinymt32_init(&tinymt, 1345135);
}
#endif /* EFI_LAUNCH_CONTROL */