rusefi/firmware/controllers/algo/airmass/speed_density_base.cpp

30 lines
810 B
C++
Raw Normal View History

2020-07-22 18:24:20 -07:00
/**
* @file speed_density_base.cpp
*
* Base for speed density (ie, ideal gas law) math shared by multiple fueling modes.
*
* @date July 22, 2020
* @author Matthew Kennedy, (C) 2020
*/
2020-07-22 13:11:07 -07:00
#include "pch.h"
2020-07-22 13:11:07 -07:00
#include "speed_density_base.h"
/**
2020-07-22 18:24:20 -07:00
* Derived via:
* (8.31 J K mol^-1) <- ideal gas constant R
* /
* (28.97g mol^-1) <- molar mass of air
* = 0.28705 J*K/g
2020-07-22 13:11:07 -07:00
*/
2020-07-22 18:24:20 -07:00
#define AIR_R 0.28705f
2020-07-22 13:11:07 -07:00
float idealGasLaw(float volume, float pressure, float temperature) {
2020-07-22 18:24:20 -07:00
return volume * pressure / (AIR_R * temperature);
2020-07-22 13:11:07 -07:00
}
2021-05-14 04:17:22 -07:00
/*static*/ float SpeedDensityBase::getAirmassImpl(float ve, float manifoldPressure, float temperature DECLARE_ENGINE_PARAMETER_SUFFIX) {
2020-07-22 13:11:07 -07:00
float cycleAir = ve * idealGasLaw(CONFIG(specs.displacement), manifoldPressure, temperature);
return cycleAir / CONFIG(specs.cylindersCount);
}