]> git.mxchange.org Git - flightgear.git/blob - src/FDM/JSBSim/FGModel.h
Encapsulate the interpolstion version of FGEnvironment and fix some bugs
[flightgear.git] / src / FDM / JSBSim / FGModel.h
1 /*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2
3  Header:       FGModel.h
4  Author:       Jon Berndt
5  Date started: 11/21/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 HISTORY
27 --------------------------------------------------------------------------------
28 11/22/98   JSB   Created
29
30 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
31 SENTRY
32 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
33
34 #ifndef FGMODEL_H
35 #define FGMODEL_H
36
37 /*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
38 INCLUDES
39 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
40
41 #include "FGJSBBase.h"
42 #include "FGPropertyManager.h"
43
44 #ifdef FGFS
45 #  include <simgear/compiler.h>
46 #  ifdef SG_HAVE_STD_INCLUDES
47 #    include <iostream>
48 #  else
49 #    include <iostream.h>
50 #  endif
51 #else
52 #  if defined(sgi) && !defined(__GNUC__) && (_COMPILER_VERSION < 740)
53 #    include <iostream.h>
54 #  else
55 #    include <iostream>
56 #  endif
57 #endif
58
59 #include <string>
60
61 /*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
62 DEFINITIONS
63 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
64
65 #define ID_MODEL "$Id$"
66
67 using namespace std;
68
69 /*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
70 FORWARD DECLARATIONS
71 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
72
73 namespace JSBSim {
74
75 class FGFDMExec;
76 class FGState;
77 class FGAtmosphere;
78 class FGFCS;
79 class FGPropulsion;
80 class FGMassBalance;
81 class FGAerodynamics;
82 class FGInertial;
83 class FGGroundReactions;
84 class FGAircraft;
85 class FGTranslation;
86 class FGRotation;
87 class FGPosition;
88 class FGAuxiliary;
89 class FGOutput;
90 class FGConfigFile;
91
92 /*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
93 CLASS DOCUMENTATION
94 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
95
96 /** Base class for all scheduled JSBSim models
97     @author Jon S. Berndt
98   */
99
100 /*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
101 CLASS DECLARATION
102 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
103
104 class FGModel : public FGJSBBase
105 {
106 public:
107
108   /// Constructor
109   FGModel(FGFDMExec*);
110   /// Destructor
111   virtual ~FGModel();
112
113   /** Loads this model.
114       @param Config a pointer to the config file instance
115       @return true if model is successfully loaded*/
116   virtual bool Load(FGConfigFile* Config) {return true;}
117  
118   FGModel* NextModel;
119   string Name;
120
121   /** Runs the model; called by the Executive
122       @see JSBSim.cpp documentation
123       @return false if no error */
124   virtual bool Run(void);
125   virtual bool InitModel(void);
126   virtual void SetRate(int tt) {rate = tt;}
127   virtual int  GetRate(void)   {return rate;}
128   
129   void SetPropertyManager(FGPropertyManager *fgpm) { PropertyManager=fgpm;}
130
131 protected:
132   int exe_ctr;
133   int rate;
134   
135   virtual void Debug(int from);
136
137   FGFDMExec*         FDMExec;
138   FGState*           State;
139   FGAtmosphere*      Atmosphere;
140   FGFCS*             FCS;
141   FGPropulsion*      Propulsion;
142   FGMassBalance*     MassBalance;
143   FGAerodynamics*    Aerodynamics;
144   FGInertial*        Inertial;
145   FGGroundReactions* GroundReactions;
146   FGAircraft*        Aircraft;
147   FGTranslation*     Translation;
148   FGRotation*        Rotation;
149   FGPosition*        Position;
150   FGAuxiliary*       Auxiliary;
151   FGOutput*          Output;
152   FGPropertyManager* PropertyManager;
153 };
154 }
155 //%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
156 #endif
157