JSBSim Flight Dynamics Model 1.2.2 (22 Mar 2025)
An Open Source Flight Dynamics and Control Software Library in C++
Loading...
Searching...
No Matches
FGModel Class Reference

Detailed Description

Base class for all scheduled JSBSim models.

Author
Jon S. Berndt

Definition at line 69 of file FGModel.h.

#include <FGModel.h>

+ Inheritance diagram for FGModel:
+ Collaboration diagram for FGModel:

Public Member Functions

 FGModel (FGFDMExec *)
 Constructor.
 
 ~FGModel () override
 Destructor.
 
virtual SGPath FindFullPathName (const SGPath &path) const
 
FGFDMExecGetExec (void)
 
const std::string & GetName (void)
 
unsigned int GetRate (void)
 Get the output rate for the model in frames.
 
bool InitModel (void) override
 
virtual bool Load (Element *el)
 
virtual bool Run (bool Holding)
 Runs the model; called by the Executive.
 
void SetPropertyManager (std::shared_ptr< FGPropertyManager > fgpm)
 
void SetRate (unsigned int tt)
 Set the ouput rate for the model in frames.
 
- Public Member Functions inherited from FGModelFunctions
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< FGFunctionGetPreFunction (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)
 
- Public Member Functions inherited from FGJSBBase
 FGJSBBase ()
 Constructor for FGJSBBase.
 
virtual ~FGJSBBase ()
 Destructor for FGJSBBase.
 
void disableHighLighting (void)
 Disables highlighting in the console output.
 

Protected Member Functions

virtual void Debug (int from)
 
bool Upload (Element *el, bool preLoad)
 Uploads this model in memory.
 

Protected Attributes

unsigned int exe_ctr
 
FGFDMExecFDMExec
 
std::string Name
 
std::shared_ptr< FGPropertyManagerPropertyManager
 
unsigned int rate
 
- Protected Attributes inherited from FGModelFunctions
FGPropertyReader LocalProperties
 
std::vector< std::shared_ptr< FGFunction > > PostFunctions
 
std::vector< std::shared_ptr< FGFunction > > PreFunctions
 

Additional Inherited Members

- Public Types inherited from FGJSBBase
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 Public Member Functions inherited from FGJSBBase
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 Public Attributes inherited from FGJSBBase
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
 
- Static Protected Member Functions inherited from FGJSBBase
static std::string CreateIndexedPropertyName (const std::string &Property, int index)
 
- Static Protected Attributes inherited from FGJSBBase
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__
 

Constructor & Destructor Documentation

◆ FGModel()

FGModel ( FGFDMExec fdmex)
explicit

Constructor.

Definition at line 57 of file FGModel.cpp.

58{
59 FDMExec = fdmex;
60
61 //in order for FGModel derived classes to self-bind (that is, call
62 //their bind function in the constructor, the PropertyManager pointer
63 //must be brought up now.
64 PropertyManager = FDMExec->GetPropertyManager();
65
66 exe_ctr = 1;
67 rate = 1;
68
69 if (debug_lvl & 2) cout << " FGModel Base Class" << endl;
70}
std::shared_ptr< FGPropertyManager > GetPropertyManager(void) const
Returns a pointer to the property manager object.
Definition FGFDMExec.h:421
+ Here is the call graph for this function:

◆ ~FGModel()

~FGModel ( )
override

Destructor.

Definition at line 74 of file FGModel.cpp.

75{
76 if (debug_lvl & 2) cout << "Destroyed: FGModel" << endl;
77}

Member Function Documentation

◆ Debug()

void Debug ( int  from)
protectedvirtual

Definition at line 170 of file FGModel.cpp.

171{
172 if (debug_lvl <= 0) return;
173
174 if (debug_lvl & 1) { // Standard console startup message output
175 if (from == 0) { // Constructor
176
177 }
178 }
179 if (debug_lvl & 2 ) { // Instantiation/Destruction notification
180 if (from == 0) cout << "Instantiated: FGModel" << endl;
181 if (from == 1) cout << "Destroyed: FGModel" << endl;
182 }
183 if (debug_lvl & 4 ) { // Run() method entry print for FGModel-derived objects
184 }
185 if (debug_lvl & 8 ) { // Runtime state variables
186 }
187 if (debug_lvl & 16) { // Sanity checking
188 }
189 if (debug_lvl & 64) {
190 if (from == 0) { // Constructor
191 }
192 }
193}

◆ FindFullPathName()

SGPath FindFullPathName ( const SGPath &  path) const
virtual

Definition at line 103 of file FGModel.cpp.

104{
105 return CheckPathName(FDMExec->GetFullAircraftPath(), path);
106}
const SGPath & GetFullAircraftPath(void)
Retrieves the full aircraft path name.
Definition FGFDMExec.h:401

◆ GetExec()

FGFDMExec * GetExec ( void  )
inline

Definition at line 94 of file FGModel.h.

94{return FDMExec;}

◆ GetName()

const std::string & GetName ( void  )
inline

Definition at line 98 of file FGModel.h.

98{ return Name; }

◆ GetRate()

unsigned int GetRate ( void  )
inline

Get the output rate for the model in frames.

Definition at line 93 of file FGModel.h.

93{return rate;}

◆ InitModel()

bool InitModel ( void  )
overridevirtual

Reimplemented from FGModelFunctions.

Reimplemented in FGPropagate, FGOutputFile, FGOutputSocket, FGOutputType, FGMSIS, and FGOutput.

Definition at line 81 of file FGModel.cpp.

82{
83 exe_ctr = 1;
84 return FGModelFunctions::InitModel();
85}

◆ Load()

virtual bool Load ( Element el)
inlinevirtual

◆ Run()

bool Run ( bool  Holding)
virtual

Runs the model; called by the Executive.

Can pass in a value indicating if the executive is directing the simulation to Hold.

Parameters
Holdingif 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. The Holding flag is not used in the base FGModel class.
See also
JSBSim.cpp documentation
Returns
false if no error

Reimplemented in FGPropagate, FGInputType, FGOutputType, FGWinds, FGAccelerations, FGAerodynamics, FGAircraft, FGAtmosphere, FGAuxiliary, FGBuoyantForces, FGExternalReactions, FGFCS, FGGroundReactions, FGInertial, FGInput, FGMassBalance, FGOutput, and FGPropulsion.

Definition at line 89 of file FGModel.cpp.

90{
91 if (debug_lvl & 4) cout << "Entering Run() for model " << Name << endl;
92
93 if (rate == 1) return false; // Fast exit if nothing to do
94
95 if (exe_ctr >= rate) exe_ctr = 0;
96
97 if (exe_ctr++ == 1) return false;
98 else return true;
99}
+ Here is the caller graph for this function:

◆ SetPropertyManager()

void SetPropertyManager ( std::shared_ptr< FGPropertyManager fgpm)
inline

Definition at line 96 of file FGModel.h.

96{ PropertyManager=fgpm;}

◆ SetRate()

void SetRate ( unsigned int  tt)
inline

Set the ouput rate for the model in frames.

Definition at line 91 of file FGModel.h.

91{rate = tt;}
+ Here is the caller graph for this function:

◆ Upload()

bool Upload ( Element el,
bool  preLoad 
)
protected

Uploads this model in memory.

Uploads the model in memory if its contents are contained in a separate file.

Parameters
ela pointer to the element
preLoadtrue if model functions and local properties must be preloaded.
Returns
true if model is successfully loaded

Definition at line 110 of file FGModel.cpp.

111{
112 FGModelLoader ModelLoader(this);
113 Element* document = ModelLoader.Open(el);
114
115 if (!document) return false;
116
117 if (document->GetName() != el->GetName()) {
118 cerr << el->ReadFrom()
119 << " Read model '" << document->GetName()
120 << "' while expecting model '" << el->GetName() << "'" << endl;
121 return false;
122 }
123
124 bool result = true;
125
126 if (preLoad)
127 result = FGModelFunctions::Load(document, FDMExec);
128
129 if (document != el) {
130 el->MergeAttributes(document);
131
132 if (preLoad) {
133 // After reading interface properties in a file, read properties in the
134 // local model element. This allows general-purpose models to be defined
135 // in a file, with overrides or initial loaded constants supplied in the
136 // relevant element of the aircraft configuration file.
137 LocalProperties.Load(el, PropertyManager.get(), true);
138 }
139
140 Element* element = document->FindElement();
141 while (element) {
142 el->AddChildElement(element);
143 element->SetParent(el);
144 element = document->FindNextElement();
145 }
146 }
147
148 return result;
149}
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Member Data Documentation

◆ exe_ctr

unsigned int exe_ctr
protected

Definition at line 102 of file FGModel.h.

◆ FDMExec

FGFDMExec* FDMExec
protected

Definition at line 117 of file FGModel.h.

◆ Name

std::string Name
protected

Definition at line 104 of file FGModel.h.

◆ PropertyManager

std::shared_ptr<FGPropertyManager> PropertyManager
protected

Definition at line 118 of file FGModel.h.

◆ rate

unsigned int rate
protected

Definition at line 103 of file FGModel.h.


The documentation for this class was generated from the following files: