![]() |
JSBSim Flight Dynamics Model 1.2.2 (22 Mar 2025)
An Open Source Flight Dynamics and Control Software Library in C++
|
Turboprop engine model.
For an example of this model in use see the file: engine/engtm601.xml
milthrust [LBS] idlen1 [%] maxn1 [%] betarangeend[%] if ThrottleCmd < betarangeend/100.0 then engine power=idle, propeller pitch is controled by ThrottleCmd (between MINPITCH and REVERSEPITCH). if ThrottleCmd > betarangeend/100.0 then engine power increases up to max reverse power reversemaxpower [%] max engine power in reverse mode maxpower [HP] psfc power specific fuel consumption [pph/HP] for N1=100% n1idle_max_delay [-] time constant for N1 change maxstartenginetime [sec] after this time the automatic starting cycle is interrupted when the engine doesn't start (0=automatic starting not present) startern1 [%] when starting starter spin up engine to this spin ielumaxtorque [lb.ft] if torque>ielumaxtorque limiters decrease the throttle (ielu = Integrated Electronic Limiter Unit) itt_delay [-] time constant for ITT change (ITT = Inter Turbine Temperature)
Definition at line 92 of file FGTurboProp.h.
#include <FGTurboProp.h>
Public Types | |
enum | phaseType { tpOff , tpRun , tpSpinUp , tpStart , tpTrim } |
![]() | |
enum | EngineType { etUnknown , etRocket , etPiston , etTurbine , etTurboprop , etElectric } |
![]() | |
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 | |
FGTurboProp (FGFDMExec *Executive, Element *el, int engine_number, struct Inputs &input) | |
Constructor. | |
double | CalcFuelNeed (void) |
The fuel need is calculated based on power levels and flow rate for that power level. | |
void | Calculate (void) |
Calculates the thrust of the engine, and other engine functions. | |
double | ExpSeek (double *var, double target, double accel, double decel) |
int | GetCondition (void) const |
bool | GetCutoff (void) const |
std::string | GetEngineLabels (const std::string &delimiter) |
std::string | GetEngineValues (const std::string &delimiter) |
double | GetEngStarting (void) const |
bool | GetGeneratorPower (void) const |
bool | GetIeluIntervent (void) const |
double | GetIeluThrottle (void) const |
double | GetITT (void) const |
double | GetN1 (void) const |
double | getOilPressure_psi () const |
double | getOilTemp_degF (void) |
phaseType | GetPhase (void) const |
double | GetPowerAvailable (void) const |
bool | GetReversed (void) const |
double | GetRPM (void) const |
int | InitRunning (void) |
double | Seek (double *var, double target, double accel, double decel) |
void | SetCondition (bool c) |
void | SetCutoff (bool cutoff) |
void | SetGeneratorPower (bool gp) |
void | SetPhase (phaseType p) |
void | SetReverse (bool reversed) |
![]() | |
FGEngine (int engine_number, struct Inputs &input) | |
virtual double | CalcOxidizerNeed (void) |
virtual const FGColumnVector3 & | GetBodyForces (void) |
virtual bool | GetCranking (void) const |
virtual double | getFuelFlow_gph () const |
virtual double | getFuelFlow_pph () const |
virtual double | GetFuelFlowRate (void) const |
virtual double | GetFuelFlowRateGPH (void) const |
virtual double | GetFuelUsedLbs (void) const |
virtual const FGColumnVector3 & | GetMoments (void) |
virtual const std::string & | GetName (void) const |
size_t | GetNumSourceTanks () const |
virtual double | GetPowerAvailable (void) |
virtual bool | GetRunning (void) const |
unsigned int | GetSourceTank (unsigned int i) const |
virtual bool | GetStarter (void) const |
virtual bool | GetStarved (void) const |
virtual double | GetThrottleMax (void) const |
virtual double | GetThrottleMin (void) const |
virtual double | GetThrust (void) const |
FGThruster * | GetThruster (void) const |
EngineType | GetType (void) const |
void | LoadThruster (FGFDMExec *exec, Element *el) |
void | LoadThrusterInputs () |
virtual void | ResetToIC (void) |
Resets the Engine parameters to the initial conditions. | |
virtual void | SetFuelDensity (double d) |
virtual void | SetFuelFreeze (bool f) |
virtual void | SetName (const std::string &name) |
virtual void | SetRunning (bool bb) |
virtual void | SetStarter (bool s) |
virtual void | SetStarved (bool tt) |
virtual void | SetStarved (void) |
![]() | |
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. | |
Additional Inherited Members | |
![]() | |
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) |
![]() | |
struct Inputs & | in |
![]() | |
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 |
![]() | |
void | Debug (int from) |
bool | Load (FGFDMExec *exec, Element *el) |
![]() | |
virtual bool | InitModel (void) |
![]() | |
static std::string | CreateIndexedPropertyName (const std::string &Property, int index) |
![]() | |
bool | Cranking |
const int | EngineNumber |
double | FuelDensity |
double | FuelExpended |
double | FuelFlow_gph |
double | FuelFlow_pph |
double | FuelFlowRate |
bool | FuelFreeze |
double | FuelUsedLbs |
double | MaxThrottle |
double | MinThrottle |
std::string | Name |
double | PctPower |
bool | Running |
double | SLFuelFlowMax |
std::vector< int > | SourceTanks |
bool | Starter |
bool | Starved |
FGThruster * | Thruster |
EngineType | Type |
![]() | |
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 phaseType |
Definition at line 101 of file FGTurboProp.h.
FGTurboProp | ( | FGFDMExec * | Executive, |
Element * | el, | ||
int | engine_number, | ||
struct Inputs & | input | ||
) |
Constructor.
Executive | pointer to executive structure |
el | pointer to the XML element representing the turbine engine |
engine_number | engine number |
Definition at line 62 of file FGTurboProp.cpp.
|
virtual |
The fuel need is calculated based on power levels and flow rate for that power level.
It is also turned from a rate into an actual amount (pounds) by multiplying it by the delta T and the rate.
Reimplemented from FGEngine.
Definition at line 425 of file FGTurboProp.cpp.
|
virtual |
Calculates the thrust of the engine, and other engine functions.
Implements FGEngine.
Definition at line 182 of file FGTurboProp.cpp.
double ExpSeek | ( | double * | var, |
double | target, | ||
double | accel, | ||
double | decel | ||
) |
Definition at line 450 of file FGTurboProp.cpp.
|
inline |
Definition at line 127 of file FGTurboProp.h.
|
inline |
Definition at line 117 of file FGTurboProp.h.
|
virtual |
Implements FGEngine.
Definition at line 493 of file FGTurboProp.cpp.
|
virtual |
Implements FGEngine.
Definition at line 506 of file FGTurboProp.cpp.
|
inline |
Definition at line 121 of file FGTurboProp.h.
|
inline |
Definition at line 126 of file FGTurboProp.h.
|
inline |
Definition at line 109 of file FGTurboProp.h.
|
inline |
Definition at line 108 of file FGTurboProp.h.
|
inline |
Definition at line 120 of file FGTurboProp.h.
|
inline |
Definition at line 119 of file FGTurboProp.h.
|
inline |
Definition at line 123 of file FGTurboProp.h.
|
inline |
Definition at line 124 of file FGTurboProp.h.
|
inline |
Definition at line 114 of file FGTurboProp.h.
|
inline |
Definition at line 106 of file FGTurboProp.h.
|
inline |
Definition at line 116 of file FGTurboProp.h.
|
inline |
Definition at line 107 of file FGTurboProp.h.
|
virtual |
Reimplemented from FGEngine.
Definition at line 519 of file FGTurboProp.cpp.
double Seek | ( | double * | var, |
double | target, | ||
double | accel, | ||
double | decel | ||
) |
Definition at line 435 of file FGTurboProp.cpp.
|
inline |
Definition at line 134 of file FGTurboProp.h.
|
inline |
Definition at line 131 of file FGTurboProp.h.
|
inline |
Definition at line 133 of file FGTurboProp.h.
|
inline |
Definition at line 129 of file FGTurboProp.h.
|
inline |
Definition at line 130 of file FGTurboProp.h.