![]() |
JSBSim Flight Dynamics Model 1.2.2 (22 Mar 2025)
An Open Source Flight Dynamics and Control Software Library in C++
|
Models inertial forces (e.g.
centripetal and coriolis accelerations). Starting conversion to WGS84.
Definition at line 65 of file FGInertial.h.
#include <FGInertial.h>
Classes | |
struct | Inputs |
Public Types | |
enum | eGravType { gtStandard , gtWGS84 } |
These define the indices use to select the gravitation models. More... | |
![]() | |
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... | |
Public Member Functions | |
FGInertial (FGFDMExec *) | |
double | GetGM (void) const |
const FGColumnVector3 & | GetGravity (void) const |
int | GetGravityType (void) const |
Get the gravity type. | |
const FGColumnVector3 & | GetOmegaPlanet () const |
double | GetSemimajor (void) const |
double | GetSemiminor (void) const |
FGMatrix33 | GetTec2l (const FGLocation &location) const |
Transform matrix from the earth centered to local horizontal frame. | |
FGMatrix33 | GetTl2ec (const FGLocation &location) const |
Transform matrix from the local horizontal frame to earth centered. | |
bool | Load (Element *el) override |
bool | Run (bool Holding) override |
Runs the Inertial model; called by the Executive Can pass in a value indicating if the executive is directing the simulation to Hold. | |
void | SetGravityType (int gt) |
Set the gravity type. | |
void | SetGroundCallback (FGGroundCallback *gc) |
Sets the ground callback pointer. | |
void | SetOmegaPlanet (double rate) |
Functions that rely on the ground callback | |
The following functions allow to set and get the vehicle position above the ground. The ground level is obtained by interrogating an instance of FGGroundCallback. A ground callback must therefore be set with SetGroundCallback() before calling any of these functions. | |
double | GetContactPoint (const FGLocation &location, FGLocation &contact, FGColumnVector3 &normal, FGColumnVector3 &velocity, FGColumnVector3 &ang_velocity) const |
Get terrain contact point information below the current location. | |
double | GetAltitudeAGL (const FGLocation &location) const |
Get the altitude above ground level. | |
void | SetAltitudeAGL (FGLocation &location, double altitudeAGL) |
Set the altitude above ground level. | |
void | SetTerrainElevation (double h) |
Set the terrain elevation above sea level. | |
void | SetTime (double time) |
Set the simulation time. | |
![]() | |
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. | |
Static Public Member Functions | |
static constexpr double | GetStandardGravity (void) |
![]() | |
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) |
Public Attributes | |
struct JSBSim::FGInertial::Inputs | in |
Additional Inherited Members | |
![]() | |
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__ |
enum eGravType |
These define the indices use to select the gravitation models.
Enumerator | |
---|---|
gtStandard | Evaluate gravity using Newton's classical formula assuming the Earth is spherical. |
gtWGS84 | Evaluate gravity using WGS84 formulas that take the Earth oblateness into account. |
Definition at line 154 of file FGInertial.h.
|
explicit |
Definition at line 51 of file FGInertial.cpp.
~FGInertial | ( | void | ) |
Definition at line 83 of file FGInertial.cpp.
|
inline |
Get the altitude above ground level.
location | Location at which the AGL is evaluated. |
Definition at line 115 of file FGInertial.h.
|
inline |
Get terrain contact point information below the current location.
location | Location at which the contact point is evaluated. |
contact | Contact point location |
normal | Terrain normal vector in contact point (ECEF frame) |
velocity | Terrain linear velocity in contact point (ECEF frame) |
ang_velocity | Terrain angular velocity in contact point (ECEF frame) |
Definition at line 104 of file FGInertial.h.
|
inline |
Definition at line 88 of file FGInertial.h.
|
inline |
Definition at line 81 of file FGInertial.h.
|
inline |
|
inline |
Definition at line 82 of file FGInertial.h.
|
inline |
Definition at line 86 of file FGInertial.h.
|
inline |
Definition at line 87 of file FGInertial.h.
|
inlinestaticconstexpr |
Definition at line 80 of file FGInertial.h.
|
inline |
Transform matrix from the earth centered to local horizontal frame.
The local frame is the NED (North-East-Down) frame. Since the Down direction depends on the gravity so is the local frame. The East direction is tangent to the spheroid with a null component along the Z axis. The North direction is obtained from the cross product between East and Down.
location | The location at which the transform matrix must be evaluated. |
Definition at line 195 of file FGInertial.h.
FGMatrix33 GetTl2ec | ( | const FGLocation & | location | ) | const |
Transform matrix from the local horizontal frame to earth centered.
The local frame is the NED (North-East-Down) frame. Since the Down direction depends on the gravity so is the local frame. The East direction is tangent to the spheroid with a null component along the Z axis. The North direction is obtained from the cross product between East and Down.
location | The location at which the transform matrix must be evaluated. |
Definition at line 159 of file FGInertial.cpp.
|
overridevirtual |
Reimplemented from FGModel.
Definition at line 90 of file FGInertial.cpp.
|
overridevirtual |
Runs the Inertial 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 135 of file FGInertial.cpp.
void SetAltitudeAGL | ( | FGLocation & | location, |
double | altitudeAGL | ||
) |
Set the altitude above ground level.
location | Location at which the AGL is set. |
altitudeAGL | Altitude above Ground Level in feet. |
Definition at line 224 of file FGInertial.cpp.
void SetGravityType | ( | int | gt | ) |
Set the gravity type.
Definition at line 239 of file FGInertial.cpp.
|
inline |
Sets the ground callback pointer.
FGInertial will take ownership of the pointer which must therefore be located in the heap.
gc | A pointer to a ground callback object |
Definition at line 151 of file FGInertial.h.
|
inline |
Definition at line 83 of file FGInertial.h.
|
inline |
Set the terrain elevation above sea level.
h | Terrain elevation in ft. |
Definition at line 131 of file FGInertial.h.
|
inline |
Set the simulation time.
The elapsed time can be used by the ground callback to assess the planet rotation or the movement of objects.
time | elapsed time in seconds since the simulation started. |
Definition at line 140 of file FGInertial.h.