2001-12-01 06:22:24 +00:00
|
|
|
#ifndef _ATMOSPHERE_HPP
|
|
|
|
#define _ATMOSPHERE_HPP
|
|
|
|
|
|
|
|
namespace yasim {
|
|
|
|
|
2017-04-22 14:14:52 +00:00
|
|
|
//constexpr int Atmosphere::numColumns {4};
|
|
|
|
|
2001-12-01 06:22:24 +00:00
|
|
|
class Atmosphere {
|
2017-04-22 14:14:52 +00:00
|
|
|
enum Column {
|
|
|
|
ALTITUDE,
|
|
|
|
TEMPERATURE,
|
|
|
|
PRESSURE,
|
|
|
|
DENSITY
|
|
|
|
};
|
|
|
|
static const int numColumns {4};
|
2001-12-01 06:22:24 +00:00
|
|
|
public:
|
2017-04-22 14:14:52 +00:00
|
|
|
void setTemperature(float t) { _temperature = t; }
|
|
|
|
void setPressure(float p) { _pressure = p; }
|
|
|
|
void setDensity(float d) { _density = d; }
|
|
|
|
|
|
|
|
//set temperature, pressure and density to standard values for given altitude
|
|
|
|
void setStandard(float altitude);
|
|
|
|
|
|
|
|
float getTemperature() const { return _temperature; }
|
|
|
|
float getPressure() const { return _pressure; }
|
|
|
|
float getDensity() const { return _density; }
|
|
|
|
|
2001-12-01 06:22:24 +00:00
|
|
|
static float getStdTemperature(float alt);
|
|
|
|
static float getStdPressure(float alt);
|
|
|
|
static float getStdDensity(float alt);
|
|
|
|
|
|
|
|
static float calcVCAS(float spd, float pressure, float temp);
|
2002-06-10 08:47:29 +00:00
|
|
|
static float calcVEAS(float spd, float pressure, float temp, float density);
|
2001-12-01 06:22:24 +00:00
|
|
|
static float calcMach(float spd, float temp);
|
2002-06-10 08:47:29 +00:00
|
|
|
static float calcStdDensity(float pressure, float temp);
|
2003-03-02 01:43:39 +00:00
|
|
|
|
|
|
|
static float spdFromMach(float mach, float temp);
|
|
|
|
static float spdFromVCAS(float vcas, float pressure, float temp);
|
2017-04-22 14:14:52 +00:00
|
|
|
float spdFromMach(float mach);
|
|
|
|
float spdFromVCAS(float vcas);
|
2001-12-24 13:54:03 +00:00
|
|
|
|
|
|
|
// Given ambient ("0") pressure/density/temperature values,
|
|
|
|
// calculate the properties of static air (air accelerated to the
|
|
|
|
// aircraft's speed) at a given velocity. Includes
|
|
|
|
// compressibility, but not shock effects.
|
|
|
|
static void calcStaticAir(float p0, float t0, float d0, float v,
|
|
|
|
float* pOut, float* tOut, float* dOut);
|
2017-04-22 14:14:52 +00:00
|
|
|
void calcStaticAir(float v, float* pOut, float* tOut, float* dOut);
|
|
|
|
static bool test();
|
|
|
|
|
2001-12-01 06:22:24 +00:00
|
|
|
private:
|
2017-04-22 14:14:52 +00:00
|
|
|
static float getRecord(float alt, Atmosphere::Column recNum);
|
|
|
|
static float data[][numColumns];
|
|
|
|
static int maxTableIndex();
|
|
|
|
|
|
|
|
float _temperature = 288.11f;
|
|
|
|
float _pressure = 101325.0f;
|
|
|
|
float _density = 1.22500f;
|
2001-12-01 06:22:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}; // namespace yasim
|
|
|
|
#endif // _ATMOSPHERE_HPP
|