![]() |
JSBSim Flight Dynamics Model 1.2.2 (22 Mar 2025)
An Open Source Flight Dynamics and Control Software Library in C++
|
Encapsulates the aerodynamic calculations.
This class owns and contains the list of force/coefficients that define the aerodynamic properties of an aircraft. Here also, such unique phenomena as ground effect, aerodynamic reference point shift, and maximum lift curve tailoff are handled.
Optionally two other coordinate systems may be used.
1) Body coordinate system:
2) Axial-Normal coordinate system:
Systems may NOT be combined, or a load error will occur.
Definition at line 113 of file FGAerodynamics.h.
#include <FGAerodynamics.h>
Classes | |
struct | Inputs |
Public Member Functions | |
FGAerodynamics (FGFDMExec *Executive) | |
Constructor. | |
~FGAerodynamics () override | |
Destructor. | |
std::vector< FGFunction * > * | GetAeroFunctions (void) const |
std::string | GetAeroFunctionStrings (const std::string &delimeter) const |
Gets the strings for the current set of aero functions. | |
std::string | GetAeroFunctionValues (const std::string &delimeter) const |
Gets the aero function values. | |
double | GetAlphaCLMax (void) const |
double | GetAlphaCLMin (void) const |
double | GetAlphaW (void) const |
double | GetBI2Vel (void) const |
double | GetCI2Vel (void) const |
double | GetClSquared (void) const |
Retrieves the square of the lift coefficient. | |
double | GetForces (int n) const |
Gets the aerodynamic force for an axis. | |
const FGColumnVector3 & | GetForces (void) const |
Gets the total aerodynamic force vector. | |
double | GetForcesInStabilityAxes (int n) const |
Retrieves the aerodynamic forces in the stability axes, given an axis. | |
FGColumnVector3 | GetForcesInStabilityAxes (void) const |
Retrieves the aerodynamic forces in the stability axes. | |
double | GetHysteresisParm (void) const |
double | GetLoD (void) const |
Retrieves the lift over drag ratio. | |
double | GetMoments (int n) const |
Gets the aerodynamic moment about the CG for an axis. | |
const FGColumnVector3 & | GetMoments (void) const |
Gets the total aerodynamic moment vector about the CG. | |
double | GetMomentsInStabilityAxes (int n) const |
Gets the aerodynamic moment about the CG for an axis. | |
FGColumnVector3 | GetMomentsInStabilityAxes (void) const |
Gets the total aerodynamic moment vector about the CG in the stability axes. | |
double | GetMomentsInWindAxes (int n) const |
Gets the aerodynamic moment about the CG for an axis. | |
FGColumnVector3 | GetMomentsInWindAxes (void) const |
Gets the total aerodynamic moment vector about the CG in the wind axes. | |
double | GetMomentsMRC (int n) const |
Gets the aerodynamic moment about the Moment Reference Center for an axis. | |
const FGColumnVector3 & | GetMomentsMRC (void) const |
Gets the total aerodynamic moment vector about the Moment Reference Center. | |
double | GetStallWarn (void) const |
double | GetvFw (int axis) const |
Retrieves the aerodynamic forces in the wind axes, given an axis. | |
const FGColumnVector3 & | GetvFw (void) const |
Retrieves the aerodynamic forces in the wind axes. | |
bool | InitModel (void) override |
bool | Load (Element *element) override |
Loads the Aerodynamics model. | |
bool | Run (bool Holding) override |
Runs the Aerodynamics model; called by the Executive Can pass in a value indicating if the executive is directing the simulation to Hold. | |
void | SetAlphaCLMax (double tt) |
void | SetAlphaCLMin (double tt) |
![]() | |
FGModel (FGFDMExec *) | |
Constructor. | |
~FGModel () override | |
Destructor. | |
virtual SGPath | FindFullPathName (const SGPath &path) const |
FGFDMExec * | GetExec (void) |
const std::string & | GetName (void) |
unsigned int | GetRate (void) |
Get the output rate for the model in frames. | |
bool | InitModel (void) override |
void | SetPropertyManager (std::shared_ptr< FGPropertyManager > fgpm) |
void | SetRate (unsigned int tt) |
Set the ouput rate for the model in frames. | |
![]() | |
std::string | GetFunctionStrings (const std::string &delimeter) const |
Gets the strings for the current set of functions. | |
std::string | GetFunctionValues (const std::string &delimeter) const |
Gets the function values. | |
std::shared_ptr< FGFunction > | GetPreFunction (const std::string &name) |
Get one of the "pre" function. | |
bool | Load (Element *el, FGFDMExec *fdmex, std::string prefix="") |
void | PostLoad (Element *el, FGFDMExec *fdmex, std::string prefix="") |
void | PreLoad (Element *el, FGFDMExec *fdmex, std::string prefix="") |
void | RunPostFunctions (void) |
void | RunPreFunctions (void) |
![]() | |
FGJSBBase () | |
Constructor for FGJSBBase. | |
virtual | ~FGJSBBase () |
Destructor for FGJSBBase. | |
void | disableHighLighting (void) |
Disables highlighting in the console output. | |
Public Attributes | |
struct JSBSim::FGAerodynamics::Inputs | in |
Additional Inherited Members | |
![]() | |
enum | { eL = 1 , eM , eN } |
Moments L, M, N. More... | |
enum | { eP = 1 , eQ , eR } |
Rates P, Q, R. More... | |
enum | { eU = 1 , eV , eW } |
Velocities U, V, W. More... | |
enum | { eX = 1 , eY , eZ } |
Positions X, Y, Z. More... | |
enum | { ePhi = 1 , eTht , ePsi } |
Euler angles Phi, Theta, Psi. More... | |
enum | { eDrag = 1 , eSide , eLift } |
Stability axis forces, Drag, Side force, Lift. More... | |
enum | { eRoll = 1 , ePitch , eYaw } |
Local frame orientation Roll, Pitch, Yaw. More... | |
enum | { eNorth = 1 , eEast , eDown } |
Local frame position North, East, Down. More... | |
enum | { eLat = 1 , eLong , eRad } |
Locations Radius, Latitude, Longitude. More... | |
enum | { inNone = 0 , inDegrees , inRadians , inMeters , inFeet } |
Conversion specifiers. More... | |
![]() | |
static const std::string & | GetVersion (void) |
Returns the version number of JSBSim. | |
static constexpr double | KelvinToFahrenheit (double kelvin) |
Converts from degrees Kelvin to degrees Fahrenheit. | |
static constexpr double | CelsiusToRankine (double celsius) |
Converts from degrees Celsius to degrees Rankine. | |
static constexpr double | RankineToCelsius (double rankine) |
Converts from degrees Rankine to degrees Celsius. | |
static constexpr double | KelvinToRankine (double kelvin) |
Converts from degrees Kelvin to degrees Rankine. | |
static constexpr double | RankineToKelvin (double rankine) |
Converts from degrees Rankine to degrees Kelvin. | |
static constexpr double | FahrenheitToCelsius (double fahrenheit) |
Converts from degrees Fahrenheit to degrees Celsius. | |
static constexpr double | CelsiusToFahrenheit (double celsius) |
Converts from degrees Celsius to degrees Fahrenheit. | |
static constexpr double | CelsiusToKelvin (double celsius) |
Converts from degrees Celsius to degrees Kelvin. | |
static constexpr double | KelvinToCelsius (double kelvin) |
Converts from degrees Kelvin to degrees Celsius. | |
static constexpr double | FeetToMeters (double measure) |
Converts from feet to meters. | |
static bool | EqualToRoundoff (double a, double b) |
Finite precision comparison. | |
static bool | EqualToRoundoff (float a, float b) |
Finite precision comparison. | |
static bool | EqualToRoundoff (float a, double b) |
Finite precision comparison. | |
static bool | EqualToRoundoff (double a, float b) |
Finite precision comparison. | |
static constexpr double | Constrain (double min, double value, double max) |
Constrain a value between a minimum and a maximum value. | |
static constexpr double | sign (double num) |
![]() | |
static char | highint [5] = {27, '[', '1', 'm', '\0' } |
highlights text | |
static char | halfint [5] = {27, '[', '2', 'm', '\0' } |
low intensity text | |
static char | normint [6] = {27, '[', '2', '2', 'm', '\0' } |
normal intensity text | |
static char | reset [5] = {27, '[', '0', 'm', '\0' } |
resets text properties | |
static char | underon [5] = {27, '[', '4', 'm', '\0' } |
underlines text | |
static char | underoff [6] = {27, '[', '2', '4', 'm', '\0' } |
underline off | |
static char | fgblue [6] = {27, '[', '3', '4', 'm', '\0' } |
blue text | |
static char | fgcyan [6] = {27, '[', '3', '6', 'm', '\0' } |
cyan text | |
static char | fgred [6] = {27, '[', '3', '1', 'm', '\0' } |
red text | |
static char | fggreen [6] = {27, '[', '3', '2', 'm', '\0' } |
green text | |
static char | fgdef [6] = {27, '[', '3', '9', 'm', '\0' } |
default text | |
static short | debug_lvl = 1 |
![]() | |
bool | Upload (Element *el, bool preLoad) |
Uploads this model in memory. | |
![]() | |
static std::string | CreateIndexedPropertyName (const std::string &Property, int index) |
![]() | |
unsigned int | exe_ctr |
FGFDMExec * | FDMExec |
std::string | Name |
std::shared_ptr< FGPropertyManager > | PropertyManager |
unsigned int | rate |
![]() | |
FGPropertyReader | LocalProperties |
std::vector< std::shared_ptr< FGFunction > > | PostFunctions |
std::vector< std::shared_ptr< FGFunction > > | PreFunctions |
![]() | |
static constexpr double | radtodeg = 180. / M_PI |
static constexpr double | degtorad = M_PI / 180. |
static constexpr double | hptoftlbssec = 550.0 |
static constexpr double | psftoinhg = 0.014138 |
static constexpr double | psftopa = 47.88 |
static constexpr double | fttom = 0.3048 |
static constexpr double | ktstofps = 1852./(3600*fttom) |
static constexpr double | fpstokts = 1.0 / ktstofps |
static constexpr double | inchtoft = 1.0/12.0 |
static constexpr double | m3toft3 = 1.0/(fttom*fttom*fttom) |
static constexpr double | in3tom3 = inchtoft*inchtoft*inchtoft/m3toft3 |
static constexpr double | inhgtopa = 3386.38 |
static constexpr double | slugtolb = 32.174049 |
Note that definition of lbtoslug by the inverse of slugtolb and not to a different constant you can also get from some tables will make lbtoslug*slugtolb == 1 up to the magnitude of roundoff. | |
static constexpr double | lbtoslug = 1.0/slugtolb |
static constexpr double | kgtolb = 2.20462 |
static constexpr double | kgtoslug = 0.06852168 |
static const std::string | needed_cfg_version = "2.0" |
static const std::string | JSBSim_version = JSBSIM_VERSION " " __DATE__ " " __TIME__ |
FGAerodynamics | ( | FGFDMExec * | Executive | ) |
Constructor.
Executive | a pointer to the parent executive object |
Definition at line 51 of file FGAerodynamics.cpp.
|
override |
Destructor.
Definition at line 92 of file FGAerodynamics.cpp.
|
inline |
Definition at line 236 of file FGAerodynamics.h.
string GetAeroFunctionStrings | ( | const std::string & | delimeter | ) | const |
Gets the strings for the current set of aero functions.
delimeter | either a tab or comma string depending on output type |
Definition at line 533 of file FGAerodynamics.cpp.
string GetAeroFunctionValues | ( | const std::string & | delimeter | ) | const |
Gets the aero function values.
delimeter | either a tab or comma string depending on output type |
Definition at line 565 of file FGAerodynamics.cpp.
|
inline |
Definition at line 212 of file FGAerodynamics.h.
|
inline |
Definition at line 213 of file FGAerodynamics.h.
|
inline |
Definition at line 217 of file FGAerodynamics.h.
|
inline |
Definition at line 219 of file FGAerodynamics.h.
|
inline |
Definition at line 220 of file FGAerodynamics.h.
|
inline |
Retrieves the square of the lift coefficient.
Definition at line 211 of file FGAerodynamics.h.
|
inline |
Gets the aerodynamic force for an axis.
n | Axis index. This could be 0, 1, or 2, or one of the axis enums: eX, eY, eZ. |
Definition at line 149 of file FGAerodynamics.h.
|
inline |
Gets the total aerodynamic force vector.
Definition at line 143 of file FGAerodynamics.h.
|
inline |
Retrieves the aerodynamic forces in the stability axes, given an axis.
axis | the axis to return the force for (eX, eY, eZ). |
Definition at line 187 of file FGAerodynamics.h.
FGColumnVector3 GetForcesInStabilityAxes | ( | void | ) | const |
Retrieves the aerodynamic forces in the stability axes.
Definition at line 320 of file FGAerodynamics.cpp.
|
inline |
Definition at line 215 of file FGAerodynamics.h.
|
inline |
Retrieves the lift over drag ratio.
Definition at line 208 of file FGAerodynamics.h.
|
inline |
Gets the aerodynamic moment about the CG for an axis.
Definition at line 158 of file FGAerodynamics.h.
|
inline |
Gets the total aerodynamic moment vector about the CG.
Definition at line 153 of file FGAerodynamics.h.
|
inline |
Gets the aerodynamic moment about the CG for an axis.
Definition at line 196 of file FGAerodynamics.h.
|
inline |
Gets the total aerodynamic moment vector about the CG in the stability axes.
Definition at line 191 of file FGAerodynamics.h.
|
inline |
Gets the aerodynamic moment about the CG for an axis.
Definition at line 205 of file FGAerodynamics.h.
|
inline |
Gets the total aerodynamic moment vector about the CG in the wind axes.
Definition at line 200 of file FGAerodynamics.h.
|
inline |
Gets the aerodynamic moment about the Moment Reference Center for an axis.
Definition at line 167 of file FGAerodynamics.h.
|
inline |
Gets the total aerodynamic moment vector about the Moment Reference Center.
Definition at line 162 of file FGAerodynamics.h.
|
inline |
Definition at line 216 of file FGAerodynamics.h.
|
inline |
Retrieves the aerodynamic forces in the wind axes, given an axis.
axis | the axis to return the force for (eX, eY, eZ). |
Definition at line 177 of file FGAerodynamics.h.
|
inline |
Retrieves the aerodynamic forces in the wind axes.
Definition at line 171 of file FGAerodynamics.h.
|
overridevirtual |
Reimplemented from FGModelFunctions.
Definition at line 113 of file FGAerodynamics.cpp.
|
overridevirtual |
Loads the Aerodynamics model.
The Load function for this class expects the XML parser to have found the aerodynamics keyword in the configuration file.
element | pointer to the current XML element for aerodynamics parameters. |
Reimplemented from FGModel.
Definition at line 331 of file FGAerodynamics.cpp.
|
overridevirtual |
Runs the Aerodynamics model; called by the Executive Can pass in a value indicating if the executive is directing the simulation to Hold.
Holding | if true, the executive has been directed to hold the sim from advancing time. Some models may ignore this flag, such as the Input model, which may need to be active to listen on a socket for the "Resume" command to be given. |
Reimplemented from FGModel.
Definition at line 132 of file FGAerodynamics.cpp.
|
inline |
Definition at line 222 of file FGAerodynamics.h.
|
inline |
Definition at line 223 of file FGAerodynamics.h.