![]() |
JSBSim Flight Dynamics Model 1.2.3 (07 Jun 2025)
An Open Source Flight Dynamics and Control Software Library in C++
|
Models a helicopter rotor.
Brief description and the symbol frequently found in the literature.
<diameter> - Rotor disk diameter (2x R).
<numblades> - Number of blades (b).
<gearratio> - Ratio of (engine rpm) / (rotor rpm), usually > 1.
<nominalrpm> - RPM at which the rotor usally operates.
<minrpm> - Lowest RPM used in the model, optional and defaults to 1.
<maxrpm> - Largest RPM used in the model, optional and defaults to 2 x nominalrpm.
<chord> - Blade chord, (c).
<liftcurveslope> - Slope of curve of section lift against section angle of attack,
per rad (a).
<twist> - Blade twist from root to tip, (theta_1).
<hingeoffset> - Rotor flapping-hinge offset (e).
<flappingmoment> - Flapping moment of inertia (I_b).
<massmoment> - Blade mass moment. Mass of a single blade times the blade's
cg-distance from the hub, optional.
<polarmoment> - Moment of inertia for the whole rotor disk, optional.
<inflowlag> - Rotor inflow time constant, sec. Smaller values yield to quicker
responses (typical values for main rotor: 0.1 - 0.2 s).
<tiplossfactor> - Tip-loss factor. The Blade fraction that produces lift.
Value usually ranges between 0.95 - 1.0, optional (B).
<maxbrakepower> - Rotor brake, 20-30 hp should work for a mid size helicopter.
<gearloss> - Friction in gear, 0.2% to 3% of the engine power, optional (see notes).
<gearmoment> - Approximation for the moment of inertia of the gear (and engine),
defaults to 0.1 * polarmoment, optional.
<controlmap> - Defines the control inputs used (see notes).
<ExternalRPM> - Links the rotor to another rotor, or an user controllable property.
Experimental properties
<groundeffectexp> - Exponent for ground effect approximation. Values usually range from 0.04
for large rotors to 0.1 for smaller ones. As a rule of thumb the effect
vanishes at a height 2-3 times the rotor diameter.
formula used: exp ( - groundeffectexp * (height+groundeffectshift) )
Omitting or setting to 0.0 disables the effect calculation.
<groundeffectshift> - Further adjustment of ground effect, approx. hub height or slightly above
(This lessens the influence of the ground effect).
The behavior of the rotor is controlled/influenced by following inputs.
fdm property propulsion/engine[x]/collective-ctrl-rad. See below for tail rotor propulsion/engine[x]/lateral-ctrl-rad. propulsion/engine[x]/longitudinal-ctrl-rad. The tail rotor collective (aka antitorque, aka pedal) control input. Read from propulsion/engine[x]/antitorque-ctrl-rad or propulsion/engine[x]/tail-collective-ctrl-rad.
Providing <ExternalRPM> 0 </ExternalRPM> the tail rotor's RPM is linked to to the main (=first, =0) rotor, and specifing <controlmap> TAIL </controlmap> tells this rotor to read the collective input from propulsion/engine[1]/antitorque-ctrl-rad (The TAIL-map ignores lateral and longitudinal input). The rotor needs to be attached to a dummy engine, e.g. an 1HP electrical engine. A tandem rotor is setup analogous.
The 'sense' parameter from the thruster is interpreted as follows, sense=1 means counter clockwise rotation of the main rotor, as viewed from above. This is as a far as I know more popular than clockwise rotation, which is defined by setting sense to -1. Concerning coaxial designs - by setting 'sense' to zero, a Kamov-style rotor is modeled (i.e. the rotor produces no torque).
In order to keep the rotor/engine speed constant, use of a RPM-Governor system is encouraged (see examples).
In case the model requires the manual use of a clutch the <gearloss> property might need attention.
Turboprop: Here the default value might be a bit too small. Also it's advisable to adjust the power table for rpm values that are far beyond the nominal value.
The property propulsion/engine[x]/groundeffect-scale-norm allows fdm based scaling of the ground effect influence. For instance the effect vanishes at speeds above approx. 50kts, or one likes to land on a 'perforated' helipad.
Setting <ExternalRPM> -1 </ExternalRPM> the rotor's RPM is controlled by the propulsion/engine[x]/x-rpm-dict property. This feature can be useful when developing a FDM.
<dl>
<dt>/SH79/</dt><dd>Shaugnessy, J. D., Deaux, Thomas N., and Yenni, Kenneth R.,
"Development and Validation of a Piloted Simulation of a
Helicopter and External Sling Load", NASA TP-1285, 1979.</dd>
<dt>/BA41/</dt><dd>Bailey,F.J.,Jr., "A Simplified Theoretical Method of Determining
the Characteristics of a Lifting Rotor in Forward Flight", NACA Rep.716, 1941.</dd>
<dt>/AM50/</dt><dd>Amer, Kenneth B.,"Theory of Helicopter Damping in Pitch or Roll and a
Comparison With Flight Measurements", NACA TN-2136, 1950.</dd>
<dt>/TA77/</dt><dd>Talbot, Peter D., Corliss, Lloyd D., "A Mathematical Force and Moment
Model of a UH-1H Helicopter for Flight Dynamics Simulations", NASA TM-73,254, 1977.</dd>
<dt>/GE49/</dt><dd>Gessow, Alfred, Amer, Kenneth B. "An Introduction to the Physical
Aspects of Helicopter Stability", NACA TN-1982, 1949.</dd>
</dl>
@author Thomas Kreitler
#include <FGRotor.h>
Inheritance diagram for FGRotor:
Collaboration diagram for FGRotor:Public Member Functions | |
| FGRotor (FGFDMExec *exec, Element *rotor_element, int num) | |
| Constructor for FGRotor. | |
| ~FGRotor () | |
| Destructor for FGRotor. | |
| double | Calculate (double EnginePower) |
| Returns the scalar thrust of the rotor, and adjusts the RPM value. | |
| double | GetA0 (void) const |
| Retrieves the rotor's coning angle. | |
| double | GetA1 (void) const |
| Retrieves the longitudinal flapping angle with respect to the rotor shaft. | |
| double | GetB1 (void) const |
| Retrieves the lateral flapping angle with respect to the rotor shaft. | |
| double | GetCollectiveCtrl (void) const |
| Retrieves the collective control input in radians. | |
| double | GetCT (void) const |
| Retrieves the thrust coefficient. | |
| double | GetEngineRPM (void) const |
| Retrieves the RPMs of the Engine, as seen from this rotor. | |
| double | GetGearRatio (void) |
| Tells the rotor's gear ratio, usually the engine asks for this. | |
| double | GetGroundEffectScaleNorm (void) const |
| Retrieves the ground effect scaling factor. | |
| double | GetLambda (void) const |
| Retrieves the inflow ratio. | |
| double | GetLateralCtrl (void) const |
| Retrieves the lateral control input in radians. | |
| double | GetLongitudinalCtrl (void) const |
| Retrieves the longitudinal control input in radians. | |
| double | GetMu (void) const |
| Retrieves the tip-speed (aka advance) ratio. | |
| double | GetNu (void) const |
| Retrieves the induced inflow ratio. | |
| double | GetPhiDW (void) const |
| Downwash angle - positive values point leftward (given a horizontal spinning rotor) | |
| double | GetPowerRequired (void) |
| Returns the power required by the rotor. | |
| double | GetRPM (void) const |
| Retrieves the RPMs of the rotor. | |
| double | GetThetaDW (void) const |
| Downwash angle - positive values point forward (given a horizontal spinning rotor) | |
| double | GetThrust (void) const |
| Retrieves the thrust of the rotor. | |
| std::string | GetThrusterLabels (int id, const std::string &delimeter) |
| std::string | GetThrusterValues (int id, const std::string &delimeter) |
| double | GetTorque (void) const |
| Retrieves the torque. | |
| double | GetVi (void) const |
| Retrieves the induced velocity. | |
| void | SetCollectiveCtrl (double c) |
| Sets the collective control input in radians. | |
| void | SetEngineRPM (double rpm) |
| void | SetGroundEffectScaleNorm (double g) |
| Sets the ground effect scaling factor. | |
| void | SetLateralCtrl (double c) |
| Sets the lateral control input in radians. | |
| void | SetLongitudinalCtrl (double c) |
| Sets the longitudinal control input in radians. | |
| void | SetRPM (double rpm) |
Public Member Functions inherited from FGThruster | |
| FGThruster (FGFDMExec *FDMExec, Element *el, int num) | |
| Constructor. | |
| virtual | ~FGThruster () |
| Destructor. | |
| double | GetGearRatio (void) |
| std::string | GetName (void) |
| double | GetReverserAngle (void) const |
| double | GetThrust (void) const |
| eType | GetType (void) |
| virtual void | ResetToIC (void) |
| void | SetName (std::string name) |
| void | SetReverserAngle (double angle) |
Public Member Functions inherited from FGForce | |
| FGForce (FGFDMExec *FDMExec) | |
| Constructor. | |
| virtual | ~FGForce () |
| Destructor. | |
| const FGColumnVector3 & | GetActingLocation (void) const |
| double | GetActingLocationX (void) const |
| double | GetActingLocationY (void) const |
| double | GetActingLocationZ (void) const |
| double | GetAnglesToBody (int axis) const |
| const FGColumnVector3 & | GetAnglesToBody (void) const |
| virtual const FGColumnVector3 & | GetBodyForces (void) |
| double | GetBodyXForce (void) const |
| double | GetBodyYForce (void) const |
| double | GetBodyZForce (void) const |
| const FGColumnVector3 & | GetLocation (void) const |
| double | GetLocationX (void) const |
| double | GetLocationY (void) const |
| double | GetLocationZ (void) const |
| const FGColumnVector3 & | GetMoments (void) const |
| double | GetPitch (void) const |
| TransformType | GetTransformType (void) const |
| double | GetYaw (void) const |
| void | SetActingLocation (const FGColumnVector3 &vv) |
| void | SetActingLocation (double x, double y, double z) |
| Acting point of application. | |
| void | SetActingLocationX (double x) |
| void | SetActingLocationY (double y) |
| void | SetActingLocationZ (double z) |
| void | SetAnglesToBody (const FGColumnVector3 &vv) |
| void | SetAnglesToBody (double broll, double bpitch, double byaw) |
| void | SetLocation (const FGColumnVector3 &vv) |
| void | SetLocation (double x, double y, double z) |
| void | SetLocationX (double x) |
| void | SetLocationY (double y) |
| void | SetLocationZ (double z) |
| void | SetPitch (double pitch) |
| void | SetTransformType (TransformType ii) |
| void | SetYaw (double yaw) |
| const FGMatrix33 & | Transform (void) const |
| void | UpdateCustomTransformMatrix (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. | |
Additional Inherited Members | |
Public Types inherited from FGThruster | |
| enum | eType { ttNozzle , ttRotor , ttPropeller , ttDirect } |
Public Types inherited from FGForce | |
| enum | TransformType { tNone , tWindBody , tLocalBody , tInertialBody , tCustom } |
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) |
Public Attributes inherited from FGThruster | |
| struct JSBSim::FGThruster::Inputs | in |
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) |
Protected Attributes inherited from FGThruster | |
| int | EngineNum |
| double | GearRatio |
| std::string | Name |
| double | PowerRequired |
| double | ReverserAngle |
| double | Thrust |
| double | ThrustCoeff |
| eType | Type |
Protected Attributes inherited from FGForce | |
| FGFDMExec * | fdmex |
| std::shared_ptr< FGMassBalance > | MassBalance |
| FGMatrix33 | mT |
| TransformType | ttype |
| FGColumnVector3 | vActingXYZn |
| FGColumnVector3 | vFn |
| FGColumnVector3 | vMn |
| FGColumnVector3 | vOrient |
| FGColumnVector3 | vXYZn |
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 for FGRotor.
| exec | a pointer to the main executive object |
| rotor_element | a pointer to the thruster config file XML element |
| num | the number of this rotor |
Definition at line 75 of file FGRotor.cpp.
Here is the call graph for this function:| ~FGRotor | ( | ) |
Destructor for FGRotor.
Definition at line 221 of file FGRotor.cpp.
|
virtual |
Returns the scalar thrust of the rotor, and adjusts the RPM value.
Reimplemented from FGThruster.
Definition at line 671 of file FGRotor.cpp.
Here is the call graph for this function:
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inlinevirtual |
Retrieves the RPMs of the Engine, as seen from this rotor.
Reimplemented from FGThruster.
Definition at line 262 of file FGRotor.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inlinevirtual |
Returns the power required by the rotor.
Reimplemented from FGThruster.
Definition at line 251 of file FGRotor.h.
|
inlinevirtual |
Retrieves the RPMs of the rotor.
Reimplemented from FGThruster.
Definition at line 258 of file FGRotor.h.
|
inline |
|
inline |
|
virtual |
Reimplemented from FGThruster.
Definition at line 789 of file FGRotor.cpp.
|
virtual |
Reimplemented from FGThruster.
Definition at line 802 of file FGRotor.cpp.
|
inline |
|
inline |
|
inline |
|
inlinevirtual |
Reimplemented from FGThruster.
Definition at line 263 of file FGRotor.h.
|
inline |
|
inline |
|
inline |
|
inlinevirtual |