46#include "models/FGModel.h"
47#include "models/FGLGear.h"
48#include "models/FGGroundReactions.h"
57typedef enum { ofRad=0, ofDeg, ofNorm, ofMag , NForms} OutputForm;
198 bool InitModel(
void)
override;
207 bool Run(
bool Holding)
override;
242 double GetThrottleCmd(
int engine)
const;
244 const std::vector<double>& GetThrottleCmd()
const {
return ThrottleCmd;}
255 const std::vector<double>& GetMixtureCmd()
const {
return MixtureCmd;}
290 const {
return DaLPos[form]; }
295 const {
return DaRPos[form]; }
300 const {
return DePos[form]; }
305 const {
return DrPos[form]; }
310 const {
return DsbPos[form]; }
315 const {
return DspPos[form]; }
320 const {
return DfPos[form]; }
325 double GetThrottlePos(
int engine)
const;
327 const std::vector<double>& GetThrottlePos()
const {
return ThrottlePos;}
338 const std::vector<double>& GetMixturePos()
const {
return MixturePos;}
357 const std::vector<double>& GetPropAdvance()
const {
return PropAdvance; }
364 const std::vector<bool>& GetPropFeather()
const {
return PropFeather; }
370 std::string GetComponentStrings(
const std::string& delimiter)
const;
376 std::string GetComponentValues(
const std::string& delimiter)
const;
423 void SetThrottleCmd(
int engine,
double cmd);
432 void SetMixtureCmd(
int engine,
double cmd);
441 void SetPropAdvanceCmd(
int engine,
double cmd);
446 void SetFeatherCmd(
int engine,
bool cmd);
453 void SetDaLPos(
int form ,
double pos );
457 void SetDaRPos(
int form ,
double pos );
461 void SetDePos(
int form ,
double pos );
465 void SetDrPos(
int form ,
double pos );
469 void SetDfPos(
int form ,
double pos );
473 void SetDsbPos(
int form ,
double pos );
477 void SetDspPos(
int form ,
double pos );
482 void SetThrottlePos(
int engine,
double cmd);
494 void SetMixturePos(
int engine,
double cmd);
511 void SetPropAdvance(
int engine,
double cmd);
516 void SetPropFeather(
int engine,
bool cmd);
523 void SetLBrake(
double cmd) {BrakePos[FGLGear::bgLeft] = cmd;}
527 void SetRBrake(
double cmd) {BrakePos[FGLGear::bgRight] = cmd;}
531 void SetCBrake(
double cmd) {BrakePos[FGLGear::bgCenter] = cmd;}
538 const std::vector<double>& GetBrakePos()
const {
return BrakePos;}
542 double GetLBrake(
void)
const {
return BrakePos[FGLGear::bgLeft];}
546 double GetRBrake(
void)
const {
return BrakePos[FGLGear::bgRight];}
550 double GetCBrake(
void)
const {
return BrakePos[FGLGear::bgCenter];}
553 enum SystemType { stFCS, stSystem, stAutoPilot };
559 bool Load(Element* el)
override;
561 SGPath FindFullPathName(
const SGPath& path)
const override;
563 void AddThrottle(
void);
564 double GetDt(
void)
const;
566 std::shared_ptr<FGPropertyManager> GetPropertyManager(
void) {
return PropertyManager; }
568 bool GetTrimStatus(
void)
const {
return FDMExec->GetTrimStatus(); }
569 double GetChannelDeltaT(
void)
const {
return GetDt() * ChannelRate; }
572 double DaCmd, DeCmd, DrCmd, DfCmd, DsbCmd, DspCmd;
573 double DePos[NForms], DaLPos[NForms], DaRPos[NForms], DrPos[NForms];
574 double DfPos[NForms], DsbPos[NForms], DspPos[NForms];
575 double PTrimCmd, YTrimCmd, RTrimCmd;
576 std::vector <double> ThrottleCmd;
577 std::vector <double> ThrottlePos;
578 std::vector <double> MixtureCmd;
579 std::vector <double> MixturePos;
580 std::vector <double> PropAdvanceCmd;
581 std::vector <double> PropAdvance;
582 std::vector <bool> PropFeatherCmd;
583 std::vector <bool> PropFeather;
585 std::vector <double> BrakePos;
586 double GearCmd,GearPos;
587 double TailhookPos, WingFoldPos;
591 typedef std::vector <FGFCSChannel*> Channels;
592 Channels SystemChannels;
594 void bindThrottle(
unsigned int);
595 void Debug(
int from)
override;
Encapsulates the Flight Control System (FCS) functionality.
void SetPitchTrimCmd(double cmd)
Sets the pitch trim command.
void SetGearPos(double gearpos)
Set the gear extend/retract position, defaults to down.
double GetCBrake(void) const
Gets the center brake.
double GetLBrake(void) const
Gets the left brake.
double GetDfPos(int form=ofRad) const
Gets the flaps position.
void SetDsbCmd(double cmd)
Sets the speedbrake command.
bool GetFeatherCmd(int engine) const
Gets the prop feather command.
double GetDfCmd(void) const
Gets the flaps command.
double GetDeCmd(void) const
Gets the elevator command.
double GetDsCmd(void) const
Gets the steering command.
double GetTailhookPos(void) const
Gets the tailhook position (0 up, 1 down)
double GetPropAdvanceCmd(int engine) const
Gets the prop pitch command.
void SetDeCmd(double cmd)
Sets the elevator command.
double GetDePos(int form=ofRad) const
Gets the elevator position.
void SetDaCmd(double cmd)
Sets the aileron command.
double GetDsbPos(int form=ofRad) const
Gets the speedbrake position.
double GetRBrake(void) const
Gets the right brake.
void SetRBrake(double cmd)
Sets the right brake group.
void SetDrCmd(double cmd)
Sets the rudder command.
double GetDrCmd(void) const
Gets the rudder command.
double GetDaCmd(void) const
Gets the aileron command.
double GetDaLPos(int form=ofRad) const
Gets the left aileron position.
double GetMixtureCmd(int engine) const
Gets the mixture command.
double GetRollTrimCmd(void) const
Gets the aileron trim command.
double GetDaRPos(int form=ofRad) const
Gets the right aileron position.
void SetTailhookPos(double hookpos)
Set the tailhook position.
void SetDfCmd(double cmd)
Sets the flaps command.
void SetDsCmd(double cmd)
Sets the steering command.
double GetWingFoldPos(void) const
Gets the wing fold position (0 unfolded, 1 folded)
double GetDspCmd(void) const
Gets the spoiler command.
double GetPitchTrimCmd(void) const
Gets the pitch trim command.
double GetGearPos(void) const
Gets the gear position (0 up, 1 down), defaults to down.
bool GetPropFeather(int engine) const
Gets the prop feather position.
double GetDsbCmd(void) const
Gets the speedbrake command.
void SetDspCmd(double cmd)
Sets the spoilers command.
void SetLBrake(double cmd)
Sets the left brake group.
double GetPropAdvance(int engine) const
Gets the prop pitch position.
double GetDspPos(int form=ofRad) const
Gets the spoiler position.
void SetCBrake(double cmd)
Sets the center brake group.
double GetYawTrimCmd(void) const
Gets the rudder trim command.
void SetRollTrimCmd(double cmd)
Sets the aileron trim command.
void SetYawTrimCmd(double cmd)
Sets the rudder trim command.
double GetGearCmd(void) const
Get the gear extend/retract command.
double GetMixturePos(int engine) const
Gets the mixture position.
void SetWingFoldPos(double foldpos)
Set the wing fold position.
double GetDrPos(int form=ofRad) const
Gets the rudder position.
void SetGearCmd(double gearcmd)
Set the gear extend/retract command, defaults to down.
Encapsulates the JSBSim simulation executive.
std::shared_ptr< FGGroundReactions > GetGroundReactions(void) const
Returns the FGGroundReactions pointer.
BrakeGroup
Brake grouping enumerators.
Base class for all scheduled JSBSim models.