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
FGSummer.cpp
1/*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2
3 Module: FGSummer.cpp
4 Author: Jon S. Berndt
5 Date started: 4/2000
6
7 ------------- Copyright (C) 2000 -------------
8
9 This program is free software; you can redistribute it and/or modify it under
10 the terms of the GNU Lesser General Public License as published by the Free
11 Software Foundation; either version 2 of the License, or (at your option) any
12 later 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 Lesser General Public License for more
17 details.
18
19 You should have received a copy of the GNU Lesser General Public License along
20 with this program; if not, write to the Free Software Foundation, Inc., 59
21 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22
23 Further information about the GNU Lesser General Public License can also be
24 found on the world wide web at http://www.gnu.org.
25
26FUNCTIONAL DESCRIPTION
27--------------------------------------------------------------------------------
28
29HISTORY
30--------------------------------------------------------------------------------
31
32%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
33COMMENTS, REFERENCES, and NOTES
34%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
35
36%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
37INCLUDES
38%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
39
40#include "FGSummer.h"
41#include "models/FGFCS.h"
42#include "input_output/FGXMLElement.h"
43
44using namespace std;
45
46namespace JSBSim {
47
48/*%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
49CLASS IMPLEMENTATION
50%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%*/
51
52FGSummer::FGSummer(FGFCS* fcs, Element* element) : FGFCSComponent(fcs, element)
53{
54 Bias = 0.0;
55
56 if (element->FindElement("bias"))
57 Bias = element->FindElementValueAsNumber("bias");
58
59 bind(element, fcs->GetPropertyManager().get());
60 Debug(0);
61}
62
63//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
64
66{
67 Debug(1);
68}
69
70//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
71
72bool FGSummer::Run(void)
73{
74 Output = 0.0;
75
76 for (auto node: InputNodes)
77 Output += node->getDoubleValue();
78
79 Output += Bias;
80
81 Clip();
82 SetOutput();
83
84 return true;
85}
86
87//%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
88// The bitmasked value choices are as follows:
89// unset: In this case (the default) JSBSim would only print
90// out the normally expected messages, essentially echoing
91// the config files as they are read. If the environment
92// variable is not set, debug_lvl is set to 1 internally
93// 0: This requests JSBSim not to output any messages
94// whatsoever.
95// 1: This value explicity requests the normal JSBSim
96// startup messages
97// 2: This value asks for a message to be printed out when
98// a class is instantiated
99// 4: When this value is set, a message is displayed when a
100// FGModel object executes its Run() method
101// 8: When this value is set, various runtime state variables
102// are printed out periodically
103// 16: When set various parameters are sanity checked and
104// a message is printed out when they go out of bounds
105
106void FGSummer::Debug(int from)
107{
108 if (debug_lvl <= 0) return;
109
110 if (debug_lvl & 1) { // Standard console startup message output
111 if (from == 0) { // Constructor
112 cout << " INPUTS: " << endl;
113 for (auto node: InputNodes)
114 cout << " " << node->GetNameWithSign() << endl;
115 if (Bias != 0.0) cout << " Bias: " << Bias << endl;
116 for (auto node: OutputNodes)
117 cout << " OUTPUT: " << node->GetName() << endl;
118 }
119 }
120 if (debug_lvl & 2 ) { // Instantiation/Destruction notification
121 if (from == 0) cout << "Instantiated: FGSummer" << endl;
122 if (from == 1) cout << "Destroyed: FGSummer" << endl;
123 }
124 if (debug_lvl & 4 ) { // Run() method entry print for FGModel-derived objects
125 }
126 if (debug_lvl & 8 ) { // Runtime state variables
127 }
128 if (debug_lvl & 16) { // Sanity checking
129 }
130 if (debug_lvl & 64) {
131 if (from == 0) { // Constructor
132 }
133 }
134}
135
136} //namespace JSBSim
137
Element * FindElement(const std::string &el="")
Searches for a specified element.
double FindElementValueAsNumber(const std::string &el="")
Searches for the named element and returns the data belonging to it as a number.
Base class for JSBSim Flight Control System Components.
Encapsulates the Flight Control System (FCS) functionality.
Definition FGFCS.h:189
FGSummer(FGFCS *fcs, Element *element)
Constructor.
Definition FGSummer.cpp:52
~FGSummer()
Destructor.
Definition FGSummer.cpp:65
bool Run(void) override
The execution method for this FCS component.
Definition FGSummer.cpp:72