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

Detailed Description

Encapsulates a condition, which is used in parts of JSBSim including switches.

Definition at line 64 of file FGCondition.h.

#include <FGCondition.h>

+ Inheritance diagram for FGCondition:
+ Collaboration diagram for FGCondition:

Public Member Functions

 FGCondition (const std::string &test, std::shared_ptr< FGPropertyManager > PropertyManager, Element *el)
 
 FGCondition (Element *element, std::shared_ptr< FGPropertyManager > PropertyManager)
 
bool Evaluate (void) const
 
void PrintCondition (std::string indent=" ") const
 
- Public Member Functions inherited from FGJSBBase
 FGJSBBase ()
 Constructor for FGJSBBase.
 
virtual ~FGJSBBase ()
 Destructor for FGJSBBase.
 
void disableHighLighting (void)
 Disables highlighting in the console output.
 

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

◆ FGCondition() [1/2]

FGCondition ( Element element,
std::shared_ptr< FGPropertyManager PropertyManager 
)

Definition at line 59 of file FGCondition.cpp.

60 : Logic(elUndef), TestParam1(nullptr), TestParam2(nullptr),
61 Comparison(ecUndef)
62{
63 string logic = element->GetAttributeValue("logic");
64 if (!logic.empty()) {
65 if (logic == "OR") Logic = eOR;
66 else if (logic == "AND") Logic = eAND;
67 else { // error
68 throw BaseException("FGCondition: unrecognized LOGIC token:'" + logic + "'");
69 }
70 } else {
71 Logic = eAND; // default
72 }
73
74 assert(Logic != elUndef);
75
76 for (unsigned int i=0; i<element->GetNumDataLines(); i++) {
77 string data = element->GetDataLine(i);
78 conditions.push_back(make_shared<FGCondition>(data, PropertyManager, element));
79 }
80
81 Element* condition_element = element->GetElement();
82 const string& elName = element->GetName();
83
84 while (condition_element) {
85 string tagName = condition_element->GetName();
86
87 if (tagName != elName) {
88 throw BaseException("FGCondition: unrecognized TAG:'" + tagName + "' in the condition statement.");
89 }
90
91 conditions.push_back(make_shared<FGCondition>(condition_element, PropertyManager));
92 condition_element = element->GetNextElement();
93 }
94
95 if (conditions.empty()) throw BaseException("Empty conditional");
96
97 Debug(0);
98}

◆ FGCondition() [2/2]

FGCondition ( const std::string &  test,
std::shared_ptr< FGPropertyManager PropertyManager,
Element el 
)

Definition at line 104 of file FGCondition.cpp.

106 : Logic(elUndef), TestParam1(nullptr), TestParam2(nullptr),
107 Comparison(ecUndef)
108{
109 static constexpr array<pair<const char*, enum eComparison>, 18> mComparison {{
110 {"!=", eNE},
111 {"<", eLT},
112 {"<=", eLE},
113 {"==", eEQ},
114 {">", eGT},
115 {">=", eGE},
116 {"EQ", eEQ},
117 {"GE", eGE},
118 {"GT", eGT},
119 {"LE", eLE},
120 {"LT", eLT},
121 {"NE", eNE},
122 {"eq", eEQ},
123 {"ge", eGE},
124 {"gt", eGT},
125 {"le", eLE},
126 {"lt", eLT},
127 {"ne", eNE},
128 }};
129
130 vector<string> test_strings = split(test, ' ');
131
132 if (test_strings.size() == 3) {
133 TestParam1 = new FGPropertyValue(test_strings[0], PropertyManager, el);
134 conditional = test_strings[1];
135 TestParam2 = new FGParameterValue(test_strings[2], PropertyManager, el);
136 } else {
137 ostringstream s;
138 s << " Conditional test is invalid: \"" << test
139 << "\" has " << test_strings.size() << " elements in the "
140 << "test condition.\n";
141 throw BaseException(s.str());
142 }
143
144 assert(Comparison == ecUndef);
145 for(auto& elm: mComparison) {
146 if (conditional == elm.first) {
147 Comparison = elm.second;
148 break;
149 }
150 }
151
152 if (Comparison == ecUndef) {
153 throw BaseException("FGCondition: Comparison operator: \""+conditional
154 +"\" does not exist. Please check the conditional.");
155 }
156}

Member Function Documentation

◆ Evaluate()

bool Evaluate ( void  ) const

Definition at line 160 of file FGCondition.cpp.

161{
162 bool pass = false;
163
164 if (!TestParam1) {
165
166 if (Logic == eAND) {
167
168 pass = true;
169 for (auto& cond: conditions) {
170 if (!cond->Evaluate()) pass = false;
171 }
172
173 } else { // Logic must be eOR
174
175 pass = false;
176 for (auto& cond: conditions) {
177 if (cond->Evaluate()) pass = true;
178 }
179
180 }
181
182 } else {
183 double value1 = TestParam1->GetValue();
184 double value2 = TestParam2->GetValue();
185
186 switch (Comparison) {
187 case eEQ:
188 pass = value1 == value2;
189 break;
190 case eNE:
191 pass = value1 != value2;
192 break;
193 case eGT:
194 pass = value1 > value2;
195 break;
196 case eGE:
197 pass = value1 >= value2;
198 break;
199 case eLT:
200 pass = value1 < value2;
201 break;
202 case eLE:
203 pass = value1 <= value2;
204 break;
205 default:
206 assert(false); // Should not be reached
207 break;
208 }
209 }
210
211 return pass;
212}

◆ PrintCondition()

void PrintCondition ( std::string  indent = "  ") const

Definition at line 216 of file FGCondition.cpp.

217{
218 string scratch;
219
220 if (!conditions.empty()) {
221
222 switch(Logic) {
223 case (elUndef):
224 scratch = " UNSET";
225 cerr << "unset logic for test condition" << endl;
226 break;
227 case (eAND):
228 scratch = indent + "if all of the following are true: {";
229 break;
230 case (eOR):
231 scratch = indent + "if any of the following are true: {";
232 break;
233 default:
234 scratch = " UNKNOWN";
235 cerr << "Unknown logic for test condition" << endl;
236 }
237 cout << scratch << endl;
238
239 for (auto& cond: conditions) {
240 cond->PrintCondition(indent + " ");
241 cout << endl;
242 }
243
244 cout << indent << "}";
245
246 } else {
247 cout << indent << TestParam1->GetName() << " " << conditional
248 << " " << TestParam2->GetName();
249 }
250}

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