JSBSim Flight Dynamics Model 1.2.2 (22 Mar 2025)
An Open Source Flight Dynamics and Control Software Library in C++
Loading...
Searching...
No Matches
FGNozzle.cpp
1/*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2
3 Module: FGNozzle.cpp
4 Author: Jon S. Berndt
5 Date started: 08/24/00
6 Purpose: Encapsulates the nozzle object
7
8 ------------- Copyright (C) 2000 Jon S. Berndt (jon@jsbsim.org) -------------
9
10 This program is free software; you can redistribute it and/or modify it under
11 the terms of the GNU Lesser General Public License as published by the Free Software
12 Foundation; either version 2 of the License, or (at your option) any later
13 version.
14
15 This program is distributed in the hope that it will be useful, but WITHOUT
16 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17 FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
18 details.
19
20 You should have received a copy of the GNU Lesser General Public License along with
21 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
22 Place - Suite 330, Boston, MA 02111-1307, USA.
23
24 Further information about the GNU Lesser General Public License can also be found on
25 the world wide web at http://www.gnu.org.
26
27FUNCTIONAL DESCRIPTION
28--------------------------------------------------------------------------------
29
30HISTORY
31--------------------------------------------------------------------------------
3208/24/00 JSB Created
33
34%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
35INCLUDES
36%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
37
38#include <iostream>
39#include <sstream>
40#include <cstdlib>
41
42#include "FGNozzle.h"
43#include "input_output/FGXMLElement.h"
44
45using namespace std;
46
47namespace JSBSim {
48
49/*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
50CLASS IMPLEMENTATION
51%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
52
53
54FGNozzle::FGNozzle(FGFDMExec* FDMExec, Element* nozzle_element, int num)
55 : FGThruster(FDMExec, nozzle_element, num)
56{
57 if (nozzle_element->FindElement("area"))
58 Area = nozzle_element->FindElementValueAsNumberConvertTo("area", "FT2");
59 else {
60 const string s("Fatal Error: Nozzle exit area must be given in nozzle config file.");
61 cerr << s << endl;
62 throw BaseException(s);
63 }
64
65 Thrust = 0;
66 Type = ttNozzle;
67
68 Debug(0);
69}
70
71//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
72
74{
75 Debug(1);
76}
77
78//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
79
80double FGNozzle::Calculate(double vacThrust)
81{
82 Thrust = max((double)0.0, vacThrust - in.Pressure*Area);
83
84 vFn(1) = Thrust * cos(ReverserAngle);
85
86 return Thrust;
87}
88
89//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
90
91string FGNozzle::GetThrusterLabels(int id, const string& delimeter)
92{
93 std::ostringstream buf;
94
95 buf << Name << " Thrust (engine " << id << " in lbs)";
96
97 return buf.str();
98}
99
100//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
101
102string FGNozzle::GetThrusterValues(int id, const string& delimeter)
103{
104 std::ostringstream buf;
105
106 buf << Thrust;
107
108 return buf.str();
109}
110
111//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
112// The bitmasked value choices are as follows:
113// unset: In this case (the default) JSBSim would only print
114// out the normally expected messages, essentially echoing
115// the config files as they are read. If the environment
116// variable is not set, debug_lvl is set to 1 internally
117// 0: This requests JSBSim not to output any messages
118// whatsoever.
119// 1: This value explicity requests the normal JSBSim
120// startup messages
121// 2: This value asks for a message to be printed out when
122// a class is instantiated
123// 4: When this value is set, a message is displayed when a
124// FGModel object executes its Run() method
125// 8: When this value is set, various runtime state variables
126// are printed out periodically
127// 16: When set various parameters are sanity checked and
128// a message is printed out when they go out of bounds
129
130void FGNozzle::Debug(int from)
131{
132 if (debug_lvl <= 0) return;
133
134 if (debug_lvl & 1) { // Standard console startup message output
135 if (from == 0) { // Constructor
136 cout << " Nozzle Name: " << Name << endl;
137 cout << " Nozzle Exit Area = " << Area << endl;
138 }
139 }
140 if (debug_lvl & 2 ) { // Instantiation/Destruction notification
141 if (from == 0) cout << "Instantiated: FGNozzle" << endl;
142 if (from == 1) cout << "Destroyed: FGNozzle" << endl;
143 }
144 if (debug_lvl & 4 ) { // Run() method entry print for FGModel-derived objects
145 }
146 if (debug_lvl & 8 ) { // Runtime state variables
147 }
148 if (debug_lvl & 16) { // Sanity checking
149 }
150 if (debug_lvl & 64) {
151 if (from == 0) { // Constructor
152 }
153 }
154}
155}
Element * FindElement(const std::string &el="")
Searches for a specified element.
double FindElementValueAsNumberConvertTo(const std::string &el, const std::string &target_units)
Searches for the named element and converts and returns the data belonging to it.
Encapsulates the JSBSim simulation executive.
Definition FGFDMExec.h:184
~FGNozzle()
Destructor.
Definition FGNozzle.cpp:73
FGNozzle(FGFDMExec *exec, Element *el, int num=0)
Constructor.
Definition FGNozzle.cpp:54
Base class for specific thrusting devices such as propellers, nozzles, etc.
Definition FGThruster.h:77