![]() |
JSBSim Flight Dynamics Model 1.3.1 (17 May 2026)
An Open Source Flight Dynamics and Control Software Library in C++
|
Lookup table class.
Models a one or more dimensional lookup table for use in aerodynamics and function definitions.
The legacy 1D/2D/3D XML syntax is preserved. For 4D and higher, add independent variables with lookup="axis4", lookup="axis5", ... and nest <tableData breakPoint="..."> elements.
For a single "vector" lookup table, the format is as follows:
The lookup="row" attribute in the independentVar element is option in this case; it is assumed that the independentVar is a row variable.
A "real life" example is as shown here:
The first column in the data table represents the lookup index (or "key"). In this case, the lookup index is aero/alpha-rad (angle of attack in radians). If alpha is 0.26 radians, the value returned from the lookup table would be 0.033.
The definition for a 2D table, is as follows:
The data is in a gridded format.
A "real life" example is as shown below. Alpha in radians is the row lookup (alpha breakpoints are arranged in the first column) and flap position in degrees is
The definition for a 3D table in a coefficient would be (for example):
[Note the "breakpoint" attribute in the tableData element, above.]
Here's an example:
Example of a 4D table (outer axis is axis4, then axis3/table, row, column):
Example of a 5D table (outer axis is axis5, then axis4, axis3/table, row, column):
In addition to using a Table for something like a coefficient, where all the row and column elements are read in from a file, a Table could be created and populated completely within program code:
The first column in the table, above, is thi (the lookup index, or key). The second column is the output data - in this case, "neta" (the Greek letter referring to combustion efficiency). Later on, the table is used like this:
#include <FGTable.h>
Inheritance diagram for FGTable:
Collaboration diagram for FGTable:Public Member Functions | |
| FGTable (const FGTable &table) | |
| This is the very important copy constructor. | |
| FGTable (int) | |
| FGTable (int, int) | |
| FGTable (std::shared_ptr< FGPropertyManager > propMan, Element *el, const std::string &prefix="") | |
| The constructor for a table. | |
| ~FGTable () | |
| Destructor. | |
| double | GetElement (unsigned int r, unsigned int c) const |
| double | GetMinValue (double colKey) const |
| double | GetMinValue (double colKey, double TableKey) const |
| double | GetMinValue (void) const |
| std::string | GetName (void) const |
| unsigned int | GetNumRows () const |
| double | GetValue (const std::vector< double > &keys) const |
| double | GetValue (double a1, double a2, double a3, double a4) const |
| double | GetValue (double a1, double a2, double a3, double a4, double a5) const |
| double | GetValue (double a1, double a2, double a3, double a4, double a5, double a6) const |
| double | GetValue (double key) const |
| Get a value from a 1D internal table. | |
| double | GetValue (double rowKey, double colKey) const |
| Get a value from a 2D internal table. | |
| double | GetValue (double rowKey, double colKey, double TableKey) const |
| Get a value from a 3D internal table. | |
| double | GetValue (void) const |
| Get the current table value. | |
| double | operator() (unsigned int r, unsigned int c) const |
| FGTable & | operator<< (const double x) |
| void | operator<< (std::istream &) |
| Read the table in. | |
| FGTable & | operator= (const FGTable &) |
| Copy assignment constructor. | |
| void | Print (void) |
| void | SetColumnIndexProperty (SGPropertyNode *node) |
| void | SetRowIndexProperty (SGPropertyNode *node) |
Public Member Functions inherited from FGParameter | |
| double | getDoubleValue (void) const |
| virtual bool | IsConstant (void) 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__ |
| ~FGTable | ( | ) |
Destructor.
Definition at line 491 of file FGTable.cpp.
Here is the call graph for this function:This is the very important copy constructor.
| table | a const reference to a table. |
Definition at line 195 of file FGTable.cpp.
| FGTable | ( | std::shared_ptr< FGPropertyManager > | propMan, |
| Element * | el, | ||
| const std::string & | prefix = "" |
||
| ) |
The constructor for a table.
Definition at line 217 of file FGTable.cpp.
Here is the call graph for this function:| FGTable | ( | int | NRows | ) |
Definition at line 172 of file FGTable.cpp.
| FGTable | ( | int | NRows, |
| int | NCols | ||
| ) |
Definition at line 184 of file FGTable.cpp.
| double GetElement | ( | unsigned int | r, |
| unsigned int | c | ||
| ) | const |
Definition at line 507 of file FGTable.cpp.
| double GetMinValue | ( | void | ) | const |
Definition at line 696 of file FGTable.cpp.
|
inlinevirtual |
|
inline |
| double GetValue | ( | const std::vector< double > & | keys | ) | const |
Definition at line 547 of file FGTable.cpp.
| double GetValue | ( | double | a1, |
| double | a2, | ||
| double | a3, | ||
| double | a4 | ||
| ) | const |
Definition at line 668 of file FGTable.cpp.
| double GetValue | ( | double | a1, |
| double | a2, | ||
| double | a3, | ||
| double | a4, | ||
| double | a5 | ||
| ) | const |
Definition at line 677 of file FGTable.cpp.
| double GetValue | ( | double | a1, |
| double | a2, | ||
| double | a3, | ||
| double | a4, | ||
| double | a5, | ||
| double | a6 | ||
| ) | const |
Definition at line 686 of file FGTable.cpp.
| double GetValue | ( | double | key | ) | const |
Get a value from a 1D internal table.
| key | Row coordinate at which the value must be interpolated |
Definition at line 598 of file FGTable.cpp.
| double GetValue | ( | double | rowKey, |
| double | colKey | ||
| ) | const |
Get a value from a 2D internal table.
| rowKey | Row coordinate at which the value must be interpolated |
| colKey | Column coordinate at which the value must be interpolated |
Definition at line 626 of file FGTable.cpp.
Here is the call graph for this function:| double GetValue | ( | double | rowKey, |
| double | colKey, | ||
| double | TableKey | ||
| ) | const |
Get a value from a 3D internal table.
| rowKey | Row coordinate at which the value must be interpolated |
| colKey | Column coordinate at which the value must be interpolated |
| TableKey | Table coordinate at which the value must be interpolated |
Definition at line 659 of file FGTable.cpp.
Here is the call graph for this function:
|
virtual |
Get the current table value.
Implements FGParameter.
Definition at line 520 of file FGTable.cpp.
Here is the call graph for this function:
Here is the caller graph for this function:
|
inline |
| FGTable & operator<< | ( | const double | x | ) |
Definition at line 725 of file FGTable.cpp.
| void operator<< | ( | std::istream & | in_stream | ) |
Read the table in.
Data in the config file should be in matrix format with the row independents as the first column and the column independents in the first row. The implication of this layout is that there should be no value in the upper left corner of the matrix e.g:
0 10 20 30 ...
-5 1 2 3 4 ...
...
For multiple-table (i.e. 3D) data sets there is an additional number key in the table definition. For example:
0.0
0 10 20 30 ...
-5 1 2 3 4 ...
...
Definition at line 711 of file FGTable.cpp.
| void Print | ( | void | ) |
Definition at line 749 of file FGTable.cpp.
|
inline |
|
inline |