43#ifndef FGINITIALCONDITION_H
44#define FGINITIALCONDITION_H
52#include "math/FGLocation.h"
53#include "math/FGQuaternion.h"
54#include "simgear/misc/sg_path.hxx"
67class FGPropertyManager;
70typedef enum { setvt, setvc, setve, setmach, setuvw, setned, setvg } speedset;
71typedef enum { setasl, setagl } altitudeset;
72typedef enum { setgeoc, setgeod } latitudeset;
236 void SetVcalibratedKtsIC(
double vc);
240 void SetVequivalentKtsIC(
double ve);
252 void SetMachIC(
double mach);
268 void ResetIC(
double u0,
double v0,
double w0,
double p0,
double q0,
double r0,
269 double alpha0,
double beta0,
double phi0,
double theta0,
double psi0,
270 double latitudeRad0,
double longitudeRad0,
double altitudeAGL0,
288 { SetClimbRateFpsIC(vt*sin(gamma*degtorad)); }
292 void SetAltitudeASLFtIC(
double altitudeASL);
296 void SetAltitudeAGLFtIC(
double agl);
300 void SetTerrainElevationFtIC(
double elev);
311 { SetGeodLatitudeRadIC(glat*degtorad); }
319 double GetVcalibratedKtsIC(
void)
const;
323 double GetVequivalentKtsIC(
void)
const;
335 double GetMachIC(
void)
const;
340 {
return GetClimbRateFpsIC()*60; }
345 {
return GetFlightPathAngleRadIC()*radtodeg; }
361 double GetPhiDegIC(
void)
const {
return orientation.GetEulerDeg(ePhi); }
365 double GetPsiDegIC(
void)
const {
return orientation.GetEulerDeg(ePsi); }
374 {
return position.GetGeodLatitudeDeg(); }
382 double GetAltitudeASLFtIC(
void)
const;
386 double GetAltitudeAGLFtIC(
void)
const;
390 double GetTerrainElevationFtIC(
void)
const;
398 void SetVgroundFpsIC(
double vg);
402 void SetVtrueFpsIC(
double vt);
444 void SetWindNEDFpsIC(
double wN,
double wE,
double wD);
452 void SetWindMagKtsIC(
double mag);
456 void SetWindDirDegIC(
double dir);
460 void SetHeadWindKtsIC(
double head);
464 void SetCrossWindKtsIC(
double cross);
468 void SetWindDownKtsIC(
double wD);
472 void SetClimbRateFpsIC(
double roc);
512 double GetWindMagFpsIC(
void)
const;
516 double GetWindDirDegIC(
void)
const;
522 const FGMatrix33& Tb2l = orientation.GetTInv();
531 return Tl2b * vUVW_NED;
577 { SetClimbRateFpsIC(vt*sin(gamma)); }
581 void SetAlphaRadIC(
double alpha);
585 void SetBetaRadIC(
double beta);
601 void SetLatitudeRadIC(
double lat);
607 void SetGeodLatitudeRadIC(
double glat);
611 void SetLongitudeRadIC(
double lon);
621 {
return (vt == 0.0)?0.0:asin(GetClimbRateFpsIC() / vt); }
642 {
return position.GetGeodLatitudeRad(); }
654 double GetPhiRadIC(
void)
const {
return orientation.GetEuler(ePhi); }
662 double GetPsiRadIC(
void)
const {
return orientation.GetEuler(ePsi); }
676 bool Load(
const SGPath& rstname,
bool useAircraftPath =
true );
681 bool IsEngineRunning(
unsigned int n)
const {
return (enginesRunning & (1 << n)) != 0; }
688 void InitializeIC(
void);
705 speedset lastSpeedSet;
706 altitudeset lastAltitudeSet;
707 latitudeset lastLatitudeSet;
708 unsigned int enginesRunning;
712 std::shared_ptr<FGAircraft> Aircraft;
713 std::shared_ptr<FGAuxiliary> Auxiliary;
715 bool Load_v1(
Element* document);
716 bool Load_v2(
Element* document);
718 void SetEulerAngleRadIC(
int idx,
double angle);
719 void SetBodyVelFpsIC(
int idx,
double vel);
720 void SetNEDVelFpsIC(
int idx,
double vel);
721 double GetBodyWindFpsIC(
int idx)
const;
722 double GetBodyVelFpsIC(
int idx)
const;
725 double ComputeGeodAltitude(
double geodLatitude);
726 bool LoadLatitude(
Element* position_el);
727 void SetTrimRequest(std::string trim);
728 void Debug(
int from);
This class implements a 3 element column vector.
Encapsulates the JSBSim simulation executive.
Initializes the simulation run.
void SetPsiRadIC(double psi)
Sets the initial heading angle.
double GetPRadpsIC() const
Gets the initial body axis roll rate.
double GetVNorthFpsIC(void) const
Gets the initial local frame X (North) velocity.
void SetThetaDegIC(double theta)
Sets pitch angle initial condition in degrees.
double GetPhiRadIC(void) const
Gets the initial roll angle.
double GetVBodyFpsIC(void) const
Gets the initial body axis Y velocity.
double GetVEastFpsIC(void) const
Gets the initial local frame Y (East) velocity.
double GetLatitudeDegIC(void) const
Gets the initial latitude.
double GetVgroundFpsIC(void) const
Gets the initial ground velocity.
double GetLongitudeRadIC(void) const
Gets the initial longitude.
double GetFlightPathAngleDegIC(void) const
Gets the initial flight path angle.
double GetThetaDegIC(void) const
Gets the initial pitch angle.
double GetVgroundKtsIC(void) const
Gets the initial ground speed.
void SetUBodyFpsIC(double ubody)
Sets the initial body axis X velocity.
double GetPhiDegIC(void) const
Gets the initial roll angle.
void SetClimbRateFpmIC(double roc)
Sets the climb rate initial condition in feet/minute.
double GetWindNFpsIC(void) const
Gets the initial wind velocity in local frame.
void SetFlightPathAngleRadIC(double gamma)
Sets the initial flight path angle.
void SetWBodyFpsIC(double wbody)
Sets the initial body axis Z velocity.
double GetTargetNlfIC(void) const
Gets the target normal load factor set from IC.
void SetVtrueKtsIC(double vtrue)
Set true airspeed initial condition in knots.
const FGColumnVector3 GetUVWFpsIC(void) const
Gets the initial body velocity.
const FGQuaternion & GetOrientation(void) const
Gets the initial orientation.
double GetWindEFpsIC(void) const
Gets the initial wind velocity in local frame.
void SetVBodyFpsIC(double vbody)
Sets the initial body axis Y velocity.
void SetAlphaDegIC(double a)
Sets angle of attack initial condition in degrees.
void SetPRadpsIC(double P)
Sets the initial body axis roll rate.
double GetVDownFpsIC(void) const
Gets the initial local frame Z (Down) velocity.
void SetFlightPathAngleDegIC(double gamma)
Sets the flight path angle initial condition in degrees.
double GetWBodyFpsIC(void) const
Gets the initial body axis Z velocity.
double GetBetaDegIC(void) const
Gets the initial sideslip angle.
void SetVgroundKtsIC(double vg)
Set ground speed initial condition in knots.
void SetLongitudeDegIC(double lon)
Sets the initial longitude.
double GetClimbRateFpsIC(void) const
Gets the initial climb rate.
bool IsEngineRunning(unsigned int n) const
Is an engine running ?
void SetThetaRadIC(double theta)
Sets the initial pitch angle.
double GetVtrueFpsIC(void) const
Gets the initial true velocity.
double GetGeodLatitudeDegIC(void) const
Gets the initial geodetic latitude.
double GetRRadpsIC() const
Gets the initial body axis yaw rate.
double GetEarthPositionAngleIC(void) const
Gets the initial Earth position angle.
double GetAlphaRadIC(void) const
Gets the initial angle of attack.
double GetAlphaDegIC(void) const
Gets the initial angle of attack.
void SetTargetNlfIC(double nlf)
Sets the target normal load factor.
void SetPsiDegIC(double psi)
Sets the heading angle initial condition in degrees.
double GetGeodLatitudeRadIC(void) const
Gets the initial geodetic latitude.
void SetRRadpsIC(double R)
Sets the initial body axis yaw rate.
void SetQRadpsIC(double Q)
Sets the initial body axis pitch rate.
double GetUBodyFpsIC(void) const
Gets the initial body axis X velocity.
double GetQRadpsIC() const
Gets the initial body axis pitch rate.
const FGColumnVector3 GetPQRRadpsIC(void) const
Gets the initial body rotation rate.
void SetVDownFpsIC(double vd)
Sets the initial local axis down velocity.
void SetGeodLatitudeDegIC(double glat)
Sets the initial geodetic latitude.
void SetPhiDegIC(double phi)
Sets the roll angle initial condition in degrees.
void SetBetaDegIC(double b)
Sets angle of sideslip initial condition in degrees.
double GetFlightPathAngleRadIC(void) const
Gets the initial flight path angle.
double GetPsiRadIC(void) const
Gets the initial heading angle.
const FGLocation & GetPosition(void) const
Gets the initial position.
double GetClimbRateFpmIC(void) const
Gets the initial climb rate.
double GetThetaRadIC(void) const
Gets the initial pitch angle.
void SetVNorthFpsIC(double vn)
Sets the initial local axis north velocity.
void SetPhiRadIC(double phi)
Sets the initial roll angle.
double GetWindUFpsIC(void) const
Gets the initial body axis X wind velocity.
void SetLatitudeDegIC(double lat)
Sets the initial latitude.
double GetWindVFpsIC(void) const
Gets the initial body axis Y wind velocity.
void SetWindMagFpsIC(double mag)
Sets the initial total wind speed.
double GetVtrueKtsIC(void) const
Gets the initial true velocity.
double GetPsiDegIC(void) const
Gets the initial heading angle.
double GetLatitudeRadIC(void) const
Gets the initial latitude.
double GetWindDFpsIC(void) const
Gets the initial wind velocity in local frame.
void SetVEastFpsIC(double ve)
Sets the initial local axis east velocity.
speedset GetSpeedSet(void) const
Gets the initial speedset.
double GetWindWFpsIC(void) const
Gets the initial body axis Z wind velocity.
int TrimRequested(void) const
Does initialization file call for trim ?
double GetBetaRadIC(void) const
Gets the initial angle of sideslip.
double GetLongitudeDegIC(void) const
Gets the initial longitude.
FGLocation holds an arbitrary location in the Earth centered Earth fixed reference frame (ECEF).
Handles matrix math operations.
Models the Quaternion representation of rotations.