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
FGMassBalance Class Reference

Detailed Description

Models weight, balance and moment of inertia information.

Maintains a vector of point masses. Sums the contribution of all, and provides this to FGPropagate. Loads the <mass_balance> section of the aircraft configuration file. There can be any number of <pointmasses>. Each can also have a shape which - if present - causes an associated moment of inertia to be calculated based on the shape. Note that a cylinder is solid, a tube is hollow, a ball is solid and a sphere is hollow.

The inertia tensor must be specified in the structural frame (x axis positive aft, y axis positive out of the right wing and z axis upward). The sign of the inertia cross products are optional by JSBSim. if negated_crossproduct_inertia == "true", then define: ixy = -integral( x * y * dm ), ixz = -integral( x * z * dm ), iyz = -integral( y * z * dm ). else if negated_crossproduct_inertia == "false", then define: ixy = integral( x * y * dm ), ixz = integral( x * z * dm ), iyz = integral( y * z * dm ). default is negated_crossproduct_inertia = "true". We strongly recommend defining negated_crossproduct_inertia = "false", which is consistent with the specifications in the field of flight dynamics.

Configuration File Format for <mass_balance> Section:

<mass_balance negated_crossproduct_inertia="true|false">
<ixx unit="{SLUG*FT2 | KG*M2}"> {number} </ixx>
<iyy unit="{SLUG*FT2 | KG*M2}"> {number} </iyy>
<izz unit="{SLUG*FT2 | KG*M2}"> {number} </izz>
<ixy unit="{SLUG*FT2 | KG*M2}"> {number} </ixy>
<ixz unit="{SLUG*FT2 | KG*M2}"> {number} </ixz>
<iyz unit="{SLUG*FT2 | KG*M2}"> {number} </iyz>
<emptywt unit="{LBS | KG"> {number} </emptywt>
<location name="CG" unit="{IN | FT | M}">
<x> {number} </x>
<y> {number} </y>
<z> {number} </z>
</location>
[<pointmass name="{string}">
<form shape="{tube | cylinder | sphere | ball}">
<radius unit="{IN | FT | M}"> {number} </radius>
<length unit="{IN | FT | M}"> {number} </length>
</form>
<weight unit="{LBS | KG}"> {number} </weight>
<location name="{string}" unit="{IN | FT | M}">
<x> {number} </x>
<y> {number} </y>
<z> {number} </z>
</location>
</pointmass>
... other point masses ...]
</mass_balance>
@see Stevens and Lewis, "Flight Control & Simulation"
@see Bernard Etkin, " Dynamics Of Atmosferic Flight"
@see https://en.wikipedia.org/wiki/Moment_of_inertia#Inertia_tensor
@see https://www.mathworks.com/help/physmod/sm/ug/specify-custom-inertia.html

Definition at line 124 of file FGMassBalance.h.

#include <FGMassBalance.h>

+ Inheritance diagram for FGMassBalance:
+ Collaboration diagram for FGMassBalance:

Classes

struct  Inputs
 

Public Member Functions

 FGMassBalance (FGFDMExec *)
 
void AddPointMass (Element *el)
 
double GetDeltaXYZcg (int axis) const
 
const FGColumnVector3GetDeltaXYZcg (void) const
 
double GetEmptyWeight (void) const
 
const FGMatrix33GetJ (void) const
 Returns the inertia matrix expressed in the body frame.
 
const FGMatrix33GetJinv (void) const
 Returns the inverse of the inertia matrix expressed in the body frame.
 
double GetMass (void) const
 
void GetMassPropertiesReport (int i)
 
FGMatrix33 GetPointmassInertia (double mass_sl, const FGColumnVector3 &r) const
 Computes the inertia contribution of a pointmass.
 
const FGColumnVector3GetPointMassMoment (void)
 
double GetTotalPointMassWeight (void) const
 
double GetWeight (void) const
 
double GetXYZcg (int axis) const
 
const FGColumnVector3GetXYZcg (void) const
 Returns the coordinates of the center of gravity expressed in the structural frame.
 
bool InitModel (void) override
 
bool Load (Element *el) override
 
bool Run (bool Holding) override
 Runs the Mass Balance model; called by the Executive Can pass in a value indicating if the executive is directing the simulation to Hold.
 
void SetAircraftBaseInertias (const FGMatrix33 &BaseJ)
 
void SetBaseCG (const FGColumnVector3 &CG)
 
void SetEmptyWeight (double EW)
 
FGColumnVector3 StructuralToBody (const FGColumnVector3 &r) const
 Conversion from the structural frame to the body frame.
 
- Public Member Functions inherited from FGModel
 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
 
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.
 

Public Attributes

struct JSBSim::FGMassBalance::Inputs in
 

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
 
- Protected Member Functions inherited from FGModel
bool Upload (Element *el, bool preLoad)
 Uploads this model in memory.
 
- Static Protected Member Functions inherited from FGJSBBase
static std::string CreateIndexedPropertyName (const std::string &Property, int index)
 
- Protected Attributes inherited from FGModel
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
 
- 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

◆ FGMassBalance()

FGMassBalance ( FGFDMExec fdmex)
explicit

Definition at line 56 of file FGMassBalance.cpp.

57 : FGModel(fdmex)
58{
59 Name = "FGMassBalance";
60 Weight = EmptyWeight = Mass = 0.0;
61
62 vbaseXYZcg.InitMatrix();
63 vXYZcg.InitMatrix();
64 vLastXYZcg.InitMatrix();
65 vDeltaXYZcg.InitMatrix();
66 baseJ.InitMatrix();
67 mJ.InitMatrix();
68 mJinv.InitMatrix();
69 pmJ.InitMatrix();
70 Propagate = fdmex->GetPropagate();
71
72 bind();
73
74 Debug(0);
75}
void InitMatrix(void)
Initialize the matrix.
FGModel(FGFDMExec *)
Constructor.
Definition FGModel.cpp:57

◆ ~FGMassBalance()

Definition at line 79 of file FGMassBalance.cpp.

80{
81 for(auto pm: PointMasses) delete pm;
82
83 Debug(1);
84}

Member Function Documentation

◆ AddPointMass()

void AddPointMass ( Element el)

Definition at line 266 of file FGMassBalance.cpp.

267{
268 Element* loc_element = el->FindElement("location");
269 string pointmass_name = el->GetAttributeValue("name");
270 if (!loc_element) {
271 stringstream s;
272 s << el->ReadFrom() << "Pointmass " << pointmass_name
273 << " has no location.";
274 cerr << endl << s.str() << endl;
275 throw BaseException(s.str());
276 }
277
278 double w = el->FindElementValueAsNumberConvertTo("weight", "LBS");
279 FGColumnVector3 vXYZ = loc_element->FindElementTripletConvertTo("IN");
280
281 PointMass *pm = new PointMass(w, vXYZ);
282 pm->SetName(pointmass_name);
283
284 Element* form_element = el->FindElement("form");
285 if (form_element) {
286 double radius=0, length=0;
287 string shape = form_element->GetAttributeValue("shape");
288 Element* radius_element = form_element->FindElement("radius");
289 Element* length_element = form_element->FindElement("length");
290 if (radius_element) radius = form_element->FindElementValueAsNumberConvertTo("radius", "FT");
291 if (length_element) length = form_element->FindElementValueAsNumberConvertTo("length", "FT");
292 if (shape == "tube") {
293 pm->SetPointMassShapeType(PointMass::esTube);
294 pm->SetRadius(radius);
295 pm->SetLength(length);
296 pm->CalculateShapeInertia();
297 } else if (shape == "cylinder") {
298 pm->SetPointMassShapeType(PointMass::esCylinder);
299 pm->SetRadius(radius);
300 pm->SetLength(length);
301 pm->CalculateShapeInertia();
302 } else if (shape == "sphere") {
303 pm->SetPointMassShapeType(PointMass::esSphere);
304 pm->SetRadius(radius);
305 pm->CalculateShapeInertia();
306 } else if (shape == "ball") {
307 pm->SetPointMassShapeType(PointMass::esBall);
308 pm->SetRadius(radius);
309 pm->CalculateShapeInertia();
310 } else {
311 }
312 }
313 else {
314 pm->SetPointMassShapeType(PointMass::esUnspecified);
315 pm->SetPointMassMoI(ReadInertiaMatrix(el));
316 }
317
318 pm->bind(PropertyManager.get(), PointMasses.size());
319 PointMasses.push_back(pm);
320}

◆ GetDeltaXYZcg() [1/2]

double GetDeltaXYZcg ( int  axis) const
inline

Definition at line 151 of file FGMassBalance.h.

151{return vDeltaXYZcg(axis);}

◆ GetDeltaXYZcg() [2/2]

const FGColumnVector3 & GetDeltaXYZcg ( void  ) const
inline

Definition at line 150 of file FGMassBalance.h.

150{return vDeltaXYZcg;}

◆ GetEmptyWeight()

double GetEmptyWeight ( void  ) const
inline

Definition at line 145 of file FGMassBalance.h.

145{return EmptyWeight;}

◆ GetJ()

const FGMatrix33 & GetJ ( void  ) const
inline

Returns the inertia matrix expressed in the body frame.

Definition at line 195 of file FGMassBalance.h.

195{return mJ;}

◆ GetJinv()

const FGMatrix33 & GetJinv ( void  ) const
inline

Returns the inverse of the inertia matrix expressed in the body frame.

Definition at line 197 of file FGMassBalance.h.

197{return mJinv;}

◆ GetMass()

double GetMass ( void  ) const
inline

Definition at line 143 of file FGMassBalance.h.

143{return Mass;}

◆ GetMassPropertiesReport()

void GetMassPropertiesReport ( int  i)

Definition at line 452 of file FGMassBalance.cpp.

453{
454 cout << endl << fgblue << highint
455 << " Mass Properties Report (English units: lbf, in, slug-ft^2)"
456 << reset << endl;
457 cout << " " << underon << " Weight CG-X CG-Y"
458 << " CG-Z Ixx Iyy Izz"
459 << " Ixy Ixz Iyz" << underoff << endl;
460 cout.precision(1);
461 cout << highint << setw(34) << left << " Base Vehicle " << normint
462 << right << setw(12) << EmptyWeight
463 << setw(8) << vbaseXYZcg(eX) << setw(8) << vbaseXYZcg(eY) << setw(8) << vbaseXYZcg(eZ)
464 << setw(12) << baseJ(1,1) << setw(12) << baseJ(2,2) << setw(12) << baseJ(3,3)
465 << setw(12) << baseJ(1,2) << setw(12) << baseJ(1,3) << setw(12) << baseJ(2,3) << endl;
466
467 for (unsigned int i=0;i<PointMasses.size();i++) {
468 PointMass* pm = PointMasses[i];
469 double pmweight = pm->GetPointMassWeight();
470 cout << highint << left << setw(4) << i << setw(30) << pm->GetName() << normint
471 << right << setw(12) << pmweight << setw(8) << pm->GetLocation()(eX)
472 << setw(8) << pm->GetLocation()(eY) << setw(8) << pm->GetLocation()(eZ)
473 << setw(12) << pm->GetPointMassMoI(1,1) << setw(12) << pm->GetPointMassMoI(2,2) << setw(12) << pm->GetPointMassMoI(3,3)
474 << setw(12) << pm->GetPointMassMoI(1,2) << setw(12) << pm->GetPointMassMoI(1,3) << setw(12) << pm->GetPointMassMoI(2,3) << endl;
475 }
476
477 cout << FDMExec->GetPropulsionTankReport();
478
479 cout << " " << underon << setw(136) << " " << underoff << endl;
480 cout << highint << left << setw(30) << " Total: " << right << setw(14) << Weight
481 << setw(8) << vXYZcg(eX)
482 << setw(8) << vXYZcg(eY)
483 << setw(8) << vXYZcg(eZ)
484 << setw(12) << mJ(1,1)
485 << setw(12) << mJ(2,2)
486 << setw(12) << mJ(3,3)
487 << setw(12) << mJ(1,2)
488 << setw(12) << mJ(1,3)
489 << setw(12) << mJ(2,3)
490 << normint << endl;
491
492 cout.setf(ios_base::fixed);
493}
static char normint[6]
normal intensity text
Definition FGJSBBase.h:154
static char fgblue[6]
blue text
Definition FGJSBBase.h:162
static char underon[5]
underlines text
Definition FGJSBBase.h:158
static char reset[5]
resets text properties
Definition FGJSBBase.h:156
static char underoff[6]
underline off
Definition FGJSBBase.h:160
static char highint[5]
highlights text
Definition FGJSBBase.h:150

◆ GetPointmassInertia()

FGMatrix33 GetPointmassInertia ( double  mass_sl,
const FGColumnVector3 r 
) const
inline

Computes the inertia contribution of a pointmass.

Computes and returns the inertia matrix of a pointmass of mass slugs at the given vector r in the structural frame. The units should be for the mass in slug and the vector in the structural frame as usual in inches.

Parameters
mass_slthe mass of this single pointmass given in slugs
rthe location of this single pointmass in the structural frame

Definition at line 161 of file FGMassBalance.h.

162 {
163 FGColumnVector3 v = StructuralToBody( r );
164 FGColumnVector3 sv = mass_sl*v;
165 double xx = sv(1)*v(1);
166 double yy = sv(2)*v(2);
167 double zz = sv(3)*v(3);
168 double xy = -sv(1)*v(2);
169 double xz = -sv(1)*v(3);
170 double yz = -sv(2)*v(3);
171 return FGMatrix33( yy+zz, xy, xz,
172 xy, xx+zz, yz,
173 xz, yz, xx+yy );
174 }
FGColumnVector3 StructuralToBody(const FGColumnVector3 &r) const
Conversion from the structural frame to the body frame.

◆ GetPointMassMoment()

const FGColumnVector3 & GetPointMassMoment ( void  )

Definition at line 336 of file FGMassBalance.cpp.

337{
338 PointMassCG.InitMatrix();
339
340 for (auto pm: PointMasses)
341 PointMassCG += pm->Weight * pm->Location;
342
343 return PointMassCG;
344}

◆ GetTotalPointMassWeight()

double GetTotalPointMassWeight ( void  ) const

Definition at line 324 of file FGMassBalance.cpp.

325{
326 double PM_total_weight = 0.0;
327
328 for(auto pm: PointMasses)
329 PM_total_weight += pm->Weight;
330
331 return PM_total_weight;
332}

◆ GetWeight()

double GetWeight ( void  ) const
inline

Definition at line 144 of file FGMassBalance.h.

144{return Weight;}

◆ GetXYZcg() [1/2]

double GetXYZcg ( int  axis) const
inline

Definition at line 149 of file FGMassBalance.h.

149{return vXYZcg(axis);}

◆ GetXYZcg() [2/2]

const FGColumnVector3 & GetXYZcg ( void  ) const
inline

Returns the coordinates of the center of gravity expressed in the structural frame.

Definition at line 148 of file FGMassBalance.h.

148{return vXYZcg;}

◆ InitModel()

bool InitModel ( void  )
overridevirtual

Reimplemented from FGModelFunctions.

Definition at line 88 of file FGMassBalance.cpp.

89{
90 if (!FGModel::InitModel()) return false;
91
92 vLastXYZcg.InitMatrix();
93 vDeltaXYZcg.InitMatrix();
94
95 return true;
96}

◆ Load()

bool Load ( Element el)
overridevirtual

Reimplemented from FGModel.

Definition at line 132 of file FGMassBalance.cpp.

133{
134 string element_name = "";
135
136 Name = "Mass Properties Model: " + document->GetAttributeValue("name");
137
138 // Perform base class Pre-Load
139 if (!FGModel::Upload(document, true))
140 return false;
141
142 SetAircraftBaseInertias(ReadInertiaMatrix(document));
143 if (document->FindElement("emptywt")) {
144 EmptyWeight = document->FindElementValueAsNumberConvertTo("emptywt", "LBS");
145 }
146
147 Element *element = document->FindElement("location");
148 while (element) {
149 element_name = element->GetAttributeValue("name");
150 if (element_name == "CG") vbaseXYZcg = element->FindElementTripletConvertTo("IN");
151 element = document->FindNextElement("location");
152 }
153
154// Find all POINTMASS elements that descend from this METRICS branch of the
155// config file.
156
157 element = document->FindElement("pointmass");
158 while (element) {
159 AddPointMass(element);
160 element = document->FindNextElement("pointmass");
161 }
162
163 double ChildFDMWeight = 0.0;
164 for (size_t fdm=0; fdm<FDMExec->GetFDMCount(); fdm++) {
165 if (FDMExec->GetChildFDM(fdm)->mated) ChildFDMWeight += FDMExec->GetChildFDM(fdm)->exec->GetMassBalance()->GetWeight();
166 }
167
168 Weight = EmptyWeight + in.TanksWeight + GetTotalPointMassWeight()
169 + in.GasMass*slugtolb + ChildFDMWeight;
170
171 Mass = lbtoslug*Weight;
172
173 PostLoad(document, FDMExec);
174
175 Debug(2);
176 return true;
177}
size_t GetFDMCount(void) const
Gets the number of child FDMs.
Definition FGFDMExec.h:425
auto GetChildFDM(int i) const
Gets a particular child FDM.
Definition FGFDMExec.h:427
static constexpr double slugtolb
Note that definition of lbtoslug by the inverse of slugtolb and not to a different constant you can a...
Definition FGJSBBase.h:313
bool Upload(Element *el, bool preLoad)
Uploads this model in memory.
Definition FGModel.cpp:110

◆ Run()

bool Run ( bool  Holding)
overridevirtual

Runs the Mass Balance 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.
Returns
false if no error

Reimplemented from FGModel.

Definition at line 181 of file FGMassBalance.cpp.

182{
183 double denom, k1, k2, k3, k4, k5, k6;
184 double Ixx, Iyy, Izz, Ixy, Ixz, Iyz;
185
186 if (FGModel::Run(Holding)) return true;
187 if (Holding) return false;
188
189 RunPreFunctions();
190
191 double ChildFDMWeight = 0.0;
192 for (size_t fdm=0; fdm<FDMExec->GetFDMCount(); fdm++) {
193 if (FDMExec->GetChildFDM(fdm)->mated) ChildFDMWeight += FDMExec->GetChildFDM(fdm)->exec->GetMassBalance()->GetWeight();
194 }
195
196 Weight = EmptyWeight + in.TanksWeight + GetTotalPointMassWeight()
197 + in.GasMass*slugtolb + ChildFDMWeight;
198
199 Mass = lbtoslug*Weight;
200
201// Calculate new CG
202
203 vXYZcg = (EmptyWeight*vbaseXYZcg
204 + GetPointMassMoment()
205 + in.TanksMoment
206 + in.GasMoment) / Weight;
207
208 // Track frame-by-frame delta CG, and move the EOM-tracked location
209 // by this amount.
210 if (vLastXYZcg.Magnitude() == 0.0) vLastXYZcg = vXYZcg;
211 vDeltaXYZcg = vXYZcg - vLastXYZcg;
212 vDeltaXYZcgBody = StructuralToBody(vLastXYZcg) - StructuralToBody(vXYZcg);
213 vLastXYZcg = vXYZcg;
214
215 // Compensate displacements of the structural frame when the mass distribution
216 // is modified while the aircraft is in contact with the ground.
217 if (FDMExec->GetHoldDown() || in.WOW)
218 Propagate->NudgeBodyLocation(vDeltaXYZcgBody);
219
220// Calculate new total moments of inertia
221
222 // At first it is the base configuration inertia matrix ...
223 mJ = baseJ;
224 // ... with the additional term originating from the parallel axis theorem.
225 mJ += GetPointmassInertia( lbtoslug * EmptyWeight, vbaseXYZcg );
226 // Then add the contributions from the additional pointmasses.
227 mJ += CalculatePMInertias();
228 mJ += in.TankInertia;
229 mJ += in.GasInertia;
230
231 Ixx = mJ(1,1);
232 Iyy = mJ(2,2);
233 Izz = mJ(3,3);
234 Ixy = -mJ(1,2);
235 Ixz = -mJ(1,3);
236 Iyz = -mJ(2,3);
237
238// Calculate inertia matrix inverse (ref. Stevens and Lewis, "Flight Control &
239// Simulation")
240
241 k1 = (Iyy*Izz - Iyz*Iyz);
242 k2 = (Iyz*Ixz + Ixy*Izz);
243 k3 = (Ixy*Iyz + Iyy*Ixz);
244
245 denom = 1.0/(Ixx*k1 - Ixy*k2 - Ixz*k3 );
246 k1 = k1*denom;
247 k2 = k2*denom;
248 k3 = k3*denom;
249 k4 = (Izz*Ixx - Ixz*Ixz)*denom;
250 k5 = (Ixy*Ixz + Iyz*Ixx)*denom;
251 k6 = (Ixx*Iyy - Ixy*Ixy)*denom;
252
253 mJinv = { k1, k2, k3,
254 k2, k4, k5,
255 k3, k5, k6 };
256
257 RunPostFunctions();
258
259 Debug(0);
260
261 return false;
262}
double Magnitude(void) const
Length of the vector.
bool GetHoldDown(void) const
Gets the value of the property forces/hold-down.
Definition FGFDMExec.h:616
FGMatrix33 GetPointmassInertia(double mass_sl, const FGColumnVector3 &r) const
Computes the inertia contribution of a pointmass.
virtual bool Run(bool Holding)
Runs the model; called by the Executive.
Definition FGModel.cpp:89
+ Here is the call graph for this function:

◆ SetAircraftBaseInertias()

void SetAircraftBaseInertias ( const FGMatrix33 BaseJ)
inline

Definition at line 198 of file FGMassBalance.h.

198{baseJ = BaseJ;}

◆ SetBaseCG()

void SetBaseCG ( const FGColumnVector3 CG)
inline

Definition at line 188 of file FGMassBalance.h.

188{vbaseXYZcg = vXYZcg = CG;}

◆ SetEmptyWeight()

void SetEmptyWeight ( double  EW)
inline

Definition at line 187 of file FGMassBalance.h.

187{ EmptyWeight = EW;}

◆ StructuralToBody()

FGColumnVector3 StructuralToBody ( const FGColumnVector3 r) const

Conversion from the structural frame to the body frame.

Converts the location given in the structural frame coordinate system to the body frame. The units of the structural frame are assumed to be in inches. The unit of the result is in ft.

Parameters
rvector coordinate in the structural reference frame (X positive aft, measurements in inches).
Returns
vector coordinate in the body frame, in feet.

Definition at line 364 of file FGMassBalance.cpp.

365{
366 // Under the assumption that in the structural frame the:
367 //
368 // - X-axis is directed afterwards,
369 // - Y-axis is directed towards the right,
370 // - Z-axis is directed upwards,
371 //
372 // (as documented in http://jsbsim.sourceforge.net/JSBSimCoordinates.pdf)
373 // we have to subtract first the center of gravity of the plane which
374 // is also defined in the structural frame:
375 //
376 // FGColumnVector3 cgOff = r - vXYZcg;
377 //
378 // Next, we do a change of units:
379 //
380 // cgOff *= inchtoft;
381 //
382 // And then a 180 degree rotation is done about the Y axis so that the:
383 //
384 // - X-axis is directed forward,
385 // - Y-axis is directed towards the right,
386 // - Z-axis is directed downward.
387 //
388 // This is needed because the structural and body frames are 180 degrees apart.
389
390 return FGColumnVector3(inchtoft*(vXYZcg(1)-r(1)),
391 inchtoft*(r(2)-vXYZcg(2)),
392 inchtoft*(vXYZcg(3)-r(3)));
393}

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