2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file engine_math.h
|
|
|
|
*
|
|
|
|
* @date Jul 13, 2013
|
2015-12-31 13:02:30 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2016
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ENGINE_MATH_H_
|
|
|
|
#define ENGINE_MATH_H_
|
|
|
|
|
|
|
|
#include "engine_configuration.h"
|
|
|
|
|
|
|
|
#include "trigger_structure.h"
|
|
|
|
#include "table_helper.h"
|
|
|
|
#include "engine.h"
|
|
|
|
|
|
|
|
void setAlgorithm(engine_load_mode_e algo DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
|
|
|
|
void findTriggerPosition(
|
|
|
|
event_trigger_position_s *position, angle_t angleOffset DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
|
|
|
|
void initializeIgnitionActions(angle_t advance, angle_t dwellAngle,
|
|
|
|
IgnitionEventList *list DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
|
2016-06-30 21:02:20 -07:00
|
|
|
#if EFI_ENABLE_ASSERTS
|
2016-06-30 22:01:34 -07:00
|
|
|
#define assertAngleRange(angle) if(angle > 10000000 || angle < -10000000) { firmwareError("angle range");angle = 0;}
|
2016-06-30 21:02:20 -07:00
|
|
|
#else
|
|
|
|
#define assertAngleRange(angle) {}
|
|
|
|
#endif
|
|
|
|
|
2016-07-24 20:02:52 -07:00
|
|
|
void setInjectorLag(float value DECLARE_ENGINE_PARAMETER_S);
|
2016-06-30 21:02:20 -07:00
|
|
|
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @brief Shifts angle into the [0..720) range for four stroke and [0..360) for two stroke
|
|
|
|
* I guess this implementation would be faster than 'angle % engineCycle'
|
|
|
|
*/
|
2016-06-30 21:02:20 -07:00
|
|
|
#define fixAngle(angle) \
|
2016-01-14 21:01:42 -08:00
|
|
|
{ \
|
2016-06-30 21:02:20 -07:00
|
|
|
assertAngleRange(angle); \
|
2016-01-14 21:01:42 -08:00
|
|
|
float engineCycleDurationLocalCopy = ENGINE(engineCycle); \
|
|
|
|
/* todo: split this method into 'fixAngleUp' and 'fixAngleDown'*/ \
|
|
|
|
/* as a performance optimization?*/ \
|
|
|
|
while (angle < 0) \
|
|
|
|
angle += engineCycleDurationLocalCopy; \
|
|
|
|
/* todo: would 'if' work as good as 'while'? */ \
|
|
|
|
while (angle >= engineCycleDurationLocalCopy) \
|
|
|
|
angle -= engineCycleDurationLocalCopy; \
|
2015-11-12 09:01:26 -08:00
|
|
|
}
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return time needed to rotate crankshaft by one degree, in milliseconds.
|
|
|
|
* @deprecated use at least Us, maybe even Nt
|
|
|
|
*/
|
|
|
|
#define getOneDegreeTimeMs(rpm) (1000.0f * 60 / 360 / (rpm))
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return float, time needed to rotate crankshaft by one degree, in microseconds.
|
|
|
|
* See also engine->rpmCalculator.oneDegreeUs
|
|
|
|
*/
|
|
|
|
#define getOneDegreeTimeUs(rpm) (1000000.0f * 60 / 360 / (rpm))
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return float, time needed to rotate crankshaft by one degree, in native clicks.
|
|
|
|
*/
|
|
|
|
#define getOneDegreeTimeNt(rpm) (US2NT(1000000) * 60.0f / 360 / (rpm))
|
|
|
|
|
2015-09-07 06:03:24 -07:00
|
|
|
floatms_t getCrankshaftRevolutionTimeMs(int rpm);
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
#define isCrankingR(rpm) ((rpm) > 0 && (rpm) < CONFIG(cranking.rpm))
|
|
|
|
|
|
|
|
float getEngineLoadT(DECLARE_ENGINE_PARAMETER_F);
|
|
|
|
|
2016-01-01 14:02:49 -08:00
|
|
|
floatms_t getSparkDwell(int rpm DECLARE_ENGINE_PARAMETER_S);
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
int getCylinderId(firing_order_e firingOrder, int index);
|
|
|
|
|
|
|
|
void setFuelRpmBin(float from, float to DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
void setFuelLoadBin(float from, float to DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
void setTimingRpmBin(float from, float to DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
void setTimingLoadBin(float from, float to DECLARE_ENGINE_PARAMETER_S);
|
|
|
|
|
|
|
|
void setSingleCoilDwell(engine_configuration_s *engineConfiguration);
|
|
|
|
|
|
|
|
#define tdcPosition() \
|
|
|
|
(ENGINE(triggerShape.tdcPosition) + CONFIG(globalTriggerAngleOffset))
|
|
|
|
|
|
|
|
#endif /* ENGINE_MATH_H_ */
|