]> git.mxchange.org Git - flightgear.git/blob - src/FDM/JSBSim/FGState.h
Updates from the Jon and Tony show.
[flightgear.git] / src / FDM / JSBSim / FGState.h
1 /*******************************************************************************
2  
3  Header:       FGState.h
4  Author:       Jon S. Berndt
5  Date started: 11/17/98
6  
7  ------------- Copyright (C) 1999  Jon S. Berndt (jsb@hal-pc.org) -------------
8  
9  This program is free software; you can redistribute it and/or modify it under
10  the terms of the GNU General Public License as published by the Free Software
11  Foundation; either version 2 of the License, or (at your option) any later
12  version.
13  
14  This program is distributed in the hope that it will be useful, but WITHOUT
15  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
17  details.
18  
19  You should have received a copy of the GNU General Public License along with
20  this program; if not, write to the Free Software Foundation, Inc., 59 Temple
21  Place - Suite 330, Boston, MA  02111-1307, USA.
22  
23  Further information about the GNU General Public License can also be found on
24  the world wide web at http://www.gnu.org.
25  
26 FUNCTIONAL DESCRIPTION
27 --------------------------------------------------------------------------------
28  
29 Based on Flightgear code, which is based on LaRCSim. This class wraps all
30 global state variables (such as velocity, position, orientation, etc.).
31  
32 HISTORY
33 --------------------------------------------------------------------------------
34 11/17/98   JSB   Created
35  
36 ********************************************************************************
37 SENTRY
38 *******************************************************************************/
39
40 #ifndef FGSTATE_H
41 #define FGSTATE_H
42
43 /*******************************************************************************
44 INCLUDES
45 *******************************************************************************/
46
47 #ifdef FGFS
48 #  include <simgear/compiler.h>
49 #  ifdef FG_HAVE_STD_INCLUDES
50 #    include <fstream>
51 #  else
52 #    include <fstream.h>
53 #  endif
54 #else
55 #  include <fstream>
56 #endif
57
58 #include <string>
59 #include <map>
60 #include "FGDefs.h"
61 #include "FGInitialCondition.h"
62 #include "FGMatrix.h"
63
64 /*******************************************************************************
65 DEFINES
66 *******************************************************************************/
67
68 /*******************************************************************************
69 CLASS DECLARATION
70 *******************************************************************************/
71
72 class FGFDMExec;
73
74 class FGState {
75 public:
76   FGState(FGFDMExec*);
77   ~FGState(void);
78
79   bool Reset(string, string, string);
80   void Initialize(float, float, float, float, float, float, float, float, float);
81   void Initialize(FGInitialCondition *FGIC);
82   bool StoreData(string);
83
84   inline float Getadot(void) { return adot; }
85   inline float Getbdot(void) { return bdot; }
86
87   inline float GetLocalAltitudeOverRunway(void) { return LocalAltitudeOverRunway; }
88   inline float Geta(void) { return a; }
89
90   inline float Getsim_time(void) { return sim_time; }
91   inline float Getdt(void) { return dt; }
92
93   float GetParameter(int val_idx);
94   float GetParameter(string val_string);
95   int GetParameterIndex(string val_string);
96
97   inline void Setadot(float tt) { adot = tt; }
98   inline void Setbdot(float tt) { bdot = tt; }
99
100   inline void SetLocalAltitudeOverRunway(float tt) { LocalAltitudeOverRunway = tt; }
101   inline void Seta(float tt) { a = tt; }
102
103   inline float Setsim_time(float tt) {
104     sim_time = tt;
105     return sim_time;
106   }
107   inline void  Setdt(float tt) { dt = tt; }
108
109   void SetParameter(int, float);
110
111   inline float IncrTime(void) {
112     sim_time+=dt;
113     return sim_time;
114   }
115   void InitMatrices(float phi, float tht, float psi);
116   void CalcMatrices(void);
117   void IntegrateQuat(FGColumnVector vPQR, int rate);
118   FGColumnVector CalcEuler(void);
119   FGMatrix GetTs2b(float alpha, float beta);
120   FGMatrix GetTl2b(void) { return mTl2b; }
121   FGMatrix GetTb2l(void) { return mTb2l; }
122
123 private:
124
125   float adot, bdot;                 // alpha dot and beta dot
126   float a;                          // speed of sound
127   float sim_time, dt;
128
129   FGFDMExec* FDMExec;
130   float LocalAltitudeOverRunway;
131   FGMatrix mTb2l;
132   FGMatrix mTl2b;
133   FGMatrix mTs2b;
134   FGColumnVector vQtrn;
135
136   typedef map<string, long> CoeffMap;
137   CoeffMap coeffdef;
138
139 protected:
140   enum {ePhi=1, eTht, ePsi};
141   enum {eP=1, eQ, eR};
142 };
143
144 /******************************************************************************/
145 #endif