OMSimulatorLib
The OMSimulator project is a FMI-based co-simulation environment that supports ordinary (i.e., non-delayed) and TLM connections.
System.h
Go to the documentation of this file.
1 /*
2  * This file is part of OpenModelica.
3  *
4  * Copyright (c) 1998-CurrentYear, Open Source Modelica Consortium (OSMC),
5  * c/o Linköpings universitet, Department of Computer and Information Science,
6  * SE-58183 Linköping, Sweden.
7  *
8  * All rights reserved.
9  *
10  * THIS PROGRAM IS PROVIDED UNDER THE TERMS OF GPL VERSION 3 LICENSE OR
11  * THIS OSMC PUBLIC LICENSE (OSMC-PL) VERSION 1.2.
12  * ANY USE, REPRODUCTION OR DISTRIBUTION OF THIS PROGRAM CONSTITUTES
13  * RECIPIENT'S ACCEPTANCE OF THE OSMC PUBLIC LICENSE OR THE GPL VERSION 3,
14  * ACCORDING TO RECIPIENTS CHOICE.
15  *
16  * The OpenModelica software and the Open Source Modelica
17  * Consortium (OSMC) Public License (OSMC-PL) are obtained
18  * from OSMC, either from the above address,
19  * from the URLs: http://www.ida.liu.se/projects/OpenModelica or
20  * http://www.openmodelica.org, and in the OpenModelica distribution.
21  * GNU version 3 is obtained from: http://www.gnu.org/copyleft/gpl.html.
22  *
23  * This program is distributed WITHOUT ANY WARRANTY; without
24  * even the implied warranty of MERCHANTABILITY or FITNESS
25  * FOR A PARTICULAR PURPOSE, EXCEPT AS EXPRESSLY SET FORTH
26  * IN THE BY RECIPIENT SELECTED SUBSIDIARY LICENSE CONDITIONS OF OSMC-PL.
27  *
28  * See the full OSMC Public License conditions for more details.
29  *
30  */
31 
32 #ifndef _OMS_SYSTEM_H_
33 #define _OMS_SYSTEM_H_
34 
35 #include "AlgLoop.h"
36 #include "BusConnector.h"
37 #include "Clock.h"
38 #include "ComRef.h"
39 #include "Connection.h"
40 #include "DirectedGraph.h"
41 #include "Element.h"
42 #include "ExternalModel.h"
43 #include "Values.h"
44 #include "ResultWriter.h"
45 #include "ssd/ConnectorGeometry.h"
46 #if !defined(NO_TLM)
47 #include "TLMBusConnector.h"
48 #endif
49 #include "Types.h"
50 #include <map>
51 #include <pugixml.hpp>
52 #include <unordered_map>
53 
54 #if (BOOST_VERSION >= 105300)
55 #include <ctpl.h>
56 #else // use the standard queue
57 #include <ctpl_stl.h>
58 #endif
59 
60 namespace oms
61 {
62  class AlgLoop;
63  class Component;
64  class Model;
65  class Variable;
66 
67  class System
68  {
69  public:
70  virtual ~System();
71 
73  System* getSystem(const ComRef& cref);
74  Component* getComponent(const ComRef& cref);
75  System* getSubSystem(const ComRef& cref);
76  Variable* getVariable(const ComRef& cref);
77  const ComRef& getCref() const {return cref;}
78  ComRef getFullCref() const;
79  Element* getElement() {return &element;}
80  oms_status_enu_t listUnconnectedConnectors(char** contents) const;
81  oms_system_enu_t getType() const {return type;}
83  oms_status_enu_t addSubModel(const ComRef& cref, const std::string& fmuPath);
84  bool validCref(const ComRef& cref);
85  oms_status_enu_t exportToSSD(pugi::xml_node& node, pugi::xml_node& ssvNode) const;
86  oms_status_enu_t importFromSSD(const pugi::xml_node& node, const std::string& sspVersion);
87  virtual oms_status_enu_t exportToSSD_SimulationInformation(pugi::xml_node& node) const = 0;
88  virtual oms_status_enu_t importFromSSD_SimulationInformation(const pugi::xml_node& node, const std::string& sspVersion) = 0;
89  void setGeometry(const ssd::ElementGeometry& geometry) {element.setGeometry(&geometry);}
91  Connector* getConnector(const ComRef& cref);
92  std::string getConnectorOwner(const ComRef& cref) const;
94  BusConnector* getBusConnector(const ComRef& cref);
95  oms_status_enu_t addTLMConnection(const ComRef& crefA, const ComRef& crefB, double delay, double alpha, double linearimpedance, double angularimpedance);
97  oms_status_enu_t addTLMBus(const ComRef& cref, oms_tlm_domain_t domain, const int dimensions, const oms_tlm_interpolation_t interpolation);
98  oms_status_enu_t addConnectorToTLMBus(const ComRef& busCref, const ComRef& connectorCref, const std::string type);
99  oms_status_enu_t deleteConnectorFromTLMBus(const ComRef& busCref, const ComRef& connectorCref);
101 #if !defined(NO_TLM)
104 #endif
105  Connection* getConnection(const ComRef& crefA, const ComRef& crefB);
106  Connection** getConnections(const ComRef &cref);
107  oms_status_enu_t addConnection(const ComRef& crefA, const ComRef& crefB);
108  oms_status_enu_t deleteConnection(const ComRef& crefA, const ComRef& crefB);
110  oms_status_enu_t setConnectionGeometry(const ComRef &crefA, const ComRef &crefB, const oms::ssd::ConnectionGeometry* geometry);
111  oms_status_enu_t addBus(const ComRef& cref);
112  oms_status_enu_t addConnectorToBus(const ComRef& busCref, const ComRef& connectorCref);
113  oms_status_enu_t deleteConnectorFromBus(const ComRef& busCref, const ComRef& connectorCref);
115  oms_status_enu_t addExternalModel(const ComRef &cref, std::string path, std::string startscript);
116  oms_status_enu_t delete_(const ComRef& cref);
118  bool isConnected(const ComRef& cref) const;
119  Model* getModel();
121  bool copyResources();
122  oms_status_enu_t getAllResources(std::vector<std::string>& resources);
123  const std::map<ComRef, System*>& getSubSystems() {return subsystems;}
124  const std::map<ComRef, Component*>& getComponents() {return components;}
128  oms_status_enu_t exportDependencyGraphs(const std::string& pathInitialization, const std::string& pathEvent, const std::string& pathSimulation);
129  oms_status_enu_t setFaultInjection(const ComRef& signal, oms_fault_type_enu_t faultType, double faultValue);
130 
131  virtual oms_status_enu_t instantiate() = 0;
132  virtual oms_status_enu_t initialize() = 0;
133  virtual oms_status_enu_t terminate() = 0;
134  virtual oms_status_enu_t reset() = 0;
135  virtual oms_status_enu_t stepUntil(double stopTime, void (*cb)(const char* ident, double time, oms_status_enu_t status)) = 0;
136 
137  double getTime() const {return time;}
138 
139  oms_status_enu_t getBoolean(const ComRef& cref, bool& value);
140  oms_status_enu_t getInteger(const ComRef& cref, int& value);
141  oms_status_enu_t getReal(const ComRef& cref, double& value);
142  oms_status_enu_t setBoolean(const ComRef& cref, bool value);
143  oms_status_enu_t setInteger(const ComRef& cref, int value);
144  oms_status_enu_t setReal(const ComRef& cref, double value);
145 
146  oms_status_enu_t getReals(const std::vector<ComRef> &crefs, std::vector<double> &values);
147  oms_status_enu_t setReals(const std::vector<ComRef> &crefs, std::vector<double> values);
148  oms_status_enu_t setRealInputDerivatives(const ComRef &cref, int order, double value);
149 
150  bool isTopLevelSystem() const {return (parentSystem == NULL);}
151 
153  virtual oms_status_enu_t updateSignals(ResultWriter& resultFile);
154  oms_status_enu_t addSignalsToResults(const char* regex);
155  oms_status_enu_t removeSignalsFromResults(const char* regex);
156 
158 
159  void getTolerance(double* absoluteTolerance, double* relativeTolerance) const {if (absoluteTolerance) *absoluteTolerance=this->absoluteTolerance; if (relativeTolerance) *relativeTolerance=this->relativeTolerance;}
160  void getStepSize(double* initialStepSize, double* minimumStepSize, double* maximumStepSize) const {if (initialStepSize) *initialStepSize=this->initialStepSize; if (minimumStepSize) *minimumStepSize=this->minimumStepSize; if (maximumStepSize) *maximumStepSize=this->maximumStepSize;}
161  oms_status_enu_t setTolerance(double absoluteTolerance, double relativeTolerance) {this->absoluteTolerance=absoluteTolerance; this->relativeTolerance=relativeTolerance; return oms_status_ok;}
162  oms_status_enu_t setFixedStepSize(double stepSize) {this->minimumStepSize=this->maximumStepSize=this->initialStepSize=stepSize; return oms_status_ok;}
163  oms_status_enu_t setVariableStepSize(double initialStepSize, double minimumStepSize, double maximumStepSize) {this->minimumStepSize=minimumStepSize; this->maximumStepSize=maximumStepSize; this->initialStepSize=initialStepSize; return oms_status_ok;}
166 
167  AlgLoop* getAlgLoop(const int systemNumber);
168  oms_status_enu_t addAlgLoop(oms_ssc_t SCC, const int algLoopNum);
169  oms_status_enu_t updateAlgebraicLoops(const std::vector< oms_ssc_t >& sortedConnections);
170  oms_status_enu_t solveAlgLoop(DirectedGraph& graph, int loopNumber);
171 
172  bool useThreadPool();
173  ctpl::thread_pool& getThreadPool();
174 
175  std::string getUniqueID() const;
176  std::map<std::string, std::string> startValuesFileSources;
177  protected:
178  double time;
179  System(const ComRef& cref, oms_system_enu_t type, Model* parentModel, System* parentSystem, oms_solver_enu_t solverMethod);
180 
181  // stop the compiler generating methods copying the object
182  System(System const& copy);
183  System& operator=(System const& copy);
184 
188 
190  unsigned int clock_id;
191 
193 
194  double absoluteTolerance = 1e-4;
195  double relativeTolerance = 1e-4;
196  double minimumStepSize = 1e-4;
197  double maximumStepSize = 1e-1;
198  double initialStepSize = 1e-4;
199 
200  std::unordered_map<unsigned int /*result file var ID*/, unsigned int /*allVariables ID*/> resultFileMapping;
201  std::unordered_map<ComRef, bool> exportConnectors;
202 
203  protected:
204  bool loopsNeedUpdate = true;
205 
206  private:
211  std::map<ComRef, System*> subsystems;
212  std::map<ComRef, Component*> components;
213 
215 
217  std::vector<Connector*> connectors;
218  std::vector<oms_element_t*> subelements;
219  std::vector<BusConnector*> busconnectors;
220 #if !defined(NO_TLM)
221  std::vector<TLMBusConnector*> tlmbusconnectors;
222 #endif
223  std::vector<Connection*> connections;
224 
225  oms_status_enu_t importFromSSD_ConnectionGeometry(const pugi::xml_node& node, const ComRef& crefA, const ComRef& crefB);
226  oms::ComRef getValidCref(const ComRef& cref);
227  oms_status_enu_t importTLMBus(const pugi::xml_node& node, Component* component);
228  oms_status_enu_t importBusConnectorSignals(const pugi::xml_node& node);
229  oms_status_enu_t importBusConnectorGeometry(const pugi::xml_node& node);
231  oms_status_enu_t importStartValuesFromSSVHelper(std::string fileName, std::multimap<ComRef, ComRef> &mappedEntry);
232  oms_status_enu_t importParameterMappingFromSSM(std::string fileName, std::multimap<ComRef, ComRef> &mappedEntry);
233 
234  std::vector<AlgLoop> algLoops;
235  };
236 }
237 
238 #endif
TLMBusConnector * getTLMBusConnector(const ComRef &cref)
Definition: System.cpp:960
oms_status_enu_t addSignalsToResults(const char *regex)
Definition: System.cpp:2162
Definition: Types.h:97
virtual oms_status_enu_t initialize()=0
oms_status_enu_t setFaultInjection(const ComRef &signal, oms_fault_type_enu_t faultType, double faultValue)
Definition: System.cpp:2249
ComRef getFullCref() const
Definition: System.cpp:160
double getTime() const
Definition: System.h:137
oms_solver_enu_t
Definition: Types.h:96
Definition: Types.h:44
oms_solver_enu_t solverMethod
Definition: System.h:192
Definition: ResultWriter.h:68
Definition: Model.h:54
std::vector< AlgLoop > algLoops
Vector of algebraic loop objects.
Definition: System.h:234
std::string getUniqueID() const
Definition: System.cpp:2238
Definition: ElementGeometry.h:45
std::vector< oms_element_t * > subelements
last element is always NULL; don&#39;t free it
Definition: System.h:218
oms_status_enu_t setTLMBusGeometry(const ComRef &cref, const oms::ssd::ConnectorGeometry *geometry)
Definition: System.cpp:1498
Definition: Clock.h:38
oms_status_enu_t setConnectionGeometry(const ComRef &crefA, const ComRef &crefB, const oms::ssd::ConnectionGeometry *geometry)
Definition: System.cpp:1424
oms_status_enu_t addAlgLoop(oms_ssc_t SCC, const int algLoopNum)
Definition: System.cpp:2385
Element element
Definition: System.h:216
oms_system_enu_t type
Definition: System.h:208
void setGeometry(const oms::ssd::ElementGeometry *newGeometry)
Definition: Element.cpp:84
Clock clock
Definition: System.h:189
oms_status_enu_t addBus(const ComRef &cref)
Definition: System.cpp:1191
oms_status_enu_t removeSignalsFromResults(const char *regex)
Definition: System.cpp:2195
oms_status_enu_t importStartValuesFromSSV()
Definition: System.cpp:2397
Definition: Variable.h:44
double initialStepSize
Definition: System.h:198
System & operator=(System const &copy)
not implemented
std::vector< std::pair< int, int > > oms_ssc_t
Strong connected components data type.
Definition: DirectedGraph.h:51
Definition: AlgLoop.h:88
oms_status_enu_t deleteAllConectionsTo(const ComRef &cref)
Definition: System.cpp:1534
DirectedGraph simulationGraph
filtered dependency graph, with connections of type Real, solved at continuous time mode; ...
Definition: System.h:187
std::unordered_map< unsigned int, unsigned int > resultFileMapping
Definition: System.h:200
DirectedGraph initializationGraph
dependency graph, with all connections, solved at initialization
Definition: System.h:185
virtual oms_status_enu_t updateSignals(ResultWriter &resultFile)
Definition: System.cpp:2117
virtual ~System()
Definition: System.cpp:72
oms_causality_enu_t
Definition: Types.h:61
oms_status_enu_t importStartValuesFromSSVHelper(std::string fileName, std::multimap< ComRef, ComRef > &mappedEntry)
Definition: System.cpp:2420
oms_tlm_interpolation_t
Definition: Types.h:70
oms_status_enu_t getBoolean(const ComRef &cref, bool &value)
Definition: System.cpp:1757
oms_status_enu_t setBoolean(const ComRef &cref, bool value)
Definition: System.cpp:1920
oms_status_enu_t getReals(const std::vector< ComRef > &crefs, std::vector< double > &values)
Definition: System.cpp:2024
TLMBusConnector ** getTLMBusConnectors()
Definition: System.h:103
std::unordered_map< ComRef, bool > exportConnectors
Definition: System.h:201
oms_status_enu_t
Definition: Types.h:43
void getTolerance(double *absoluteTolerance, double *relativeTolerance) const
Definition: System.h:159
TLMBusConnector.
Definition: TLMBusConnector.h:96
bool isTopLevelSystem() const
Definition: System.h:150
virtual oms_status_enu_t exportToSSD_SimulationInformation(pugi::xml_node &node) const =0
oms_status_enu_t exportToSSD(pugi::xml_node &node, pugi::xml_node &ssvNode) const
Definition: System.cpp:395
ComRef cref
Definition: System.h:207
bool loopsNeedUpdate
Definition: System.h:204
oms_status_enu_t addTLMConnection(const ComRef &crefA, const ComRef &crefB, double delay, double alpha, double linearimpedance, double angularimpedance)
Definition: System.cpp:1135
oms_solver_enu_t getSolver()
Definition: System.h:165
bool useThreadPool()
Definition: System.cpp:2228
System(const ComRef &cref, oms_system_enu_t type, Model *parentModel, System *parentSystem, oms_solver_enu_t solverMethod)
Definition: System.cpp:52
oms_status_enu_t setFixedStepSize(double stepSize)
Definition: System.h:162
oms_status_enu_t deleteConnection(const ComRef &crefA, const ComRef &crefB)
Definition: System.cpp:1102
oms_status_enu_t getReal(const ComRef &cref, double &value)
Definition: System.cpp:1835
oms_status_enu_t setInteger(const ComRef &cref, int value)
Definition: System.cpp:1955
Connector * getConnector(const ComRef &cref)
Definition: System.cpp:913
virtual oms_status_enu_t stepUntil(double stopTime, void(*cb)(const char *ident, double time, oms_status_enu_t status))=0
oms_status_enu_t updateDependencyGraphs()
Definition: System.cpp:1700
static System * NewSystem(const ComRef &cref, oms_system_enu_t type, Model *parentModel, System *parentSystem)
Definition: System.cpp:99
BusConnector * getBusConnector(const ComRef &cref)
Definition: System.cpp:938
System * getSubSystem(const ComRef &cref)
Definition: System.cpp:204
Definition: Types.h:47
Values values
system level connectors, parameters and their start values defined before instantiating the FMU and e...
Definition: System.h:214
void setGeometry(const ssd::ElementGeometry &geometry)
Definition: System.h:89
oms_status_enu_t getInteger(const ComRef &cref, int &value)
Definition: System.cpp:1796
oms_status_enu_t listUnconnectedConnectors(char **contents) const
Definition: System.cpp:315
Model * getModel()
Definition: System.cpp:1527
const std::map< ComRef, Component * > & getComponents()
Definition: System.h:124
std::vector< TLMBusConnector * > tlmbusconnectors
Definition: System.h:221
oms_status_enu_t addConnector(const ComRef &cref, oms_causality_enu_t causality, oms_signal_type_enu_t type)
Definition: System.cpp:890
ComRef - component reference.
Definition: ComRef.h:43
void getStepSize(double *initialStepSize, double *minimumStepSize, double *maximumStepSize) const
Definition: System.h:160
unsigned int clock_id
Definition: System.h:190
oms_status_enu_t setBusGeometry(const ComRef &cref, const oms::ssd::ConnectorGeometry *geometry)
Definition: System.cpp:1481
oms_system_enu_t
Definition: Types.h:121
const char * parameters
Definition: Tags.cpp:79
AlgLoop * getAlgLoop(const int systemNumber)
Definition: System.cpp:2374
Definition: Component.h:56
std::vector< BusConnector * > busconnectors
Definition: System.h:219
oms_status_enu_t setReals(const std::vector< ComRef > &crefs, std::vector< double > values)
Definition: System.cpp:2035
Connection * getConnection(const ComRef &crefA, const ComRef &crefB)
Definition: System.cpp:1519
oms_status_enu_t updateAlgebraicLoops(const std::vector< oms_ssc_t > &sortedConnections)
Definition: System.cpp:2521
oms_status_enu_t setVariableStepSize(double initialStepSize, double minimumStepSize, double maximumStepSize)
Definition: System.h:163
Connector.
Definition: Connector.h:48
oms_status_enu_t importFromSSD(const pugi::xml_node &node, const std::string &sspVersion)
Definition: System.cpp:505
double relativeTolerance
Definition: System.h:195
oms_status_enu_t deleteConnectorFromBus(const ComRef &busCref, const ComRef &connectorCref)
Definition: System.cpp:1275
oms_status_enu_t deleteConnectorFromTLMBus(const ComRef &busCref, const ComRef &connectorCref)
Definition: System.cpp:1338
BusConnector.
Definition: BusConnector.h:20
virtual oms_status_enu_t setSolver(oms_solver_enu_t solver)
Definition: System.h:157
oms_status_enu_t setTLMConnectionParameters(const ComRef &crefA, const ComRef &crefB, const oms_tlm_connection_parameters_t *parameters)
Definition: System.cpp:1451
oms_status_enu_t addConnectorToBus(const ComRef &busCref, const ComRef &connectorCref)
Definition: System.cpp:1251
Definition: Values.h:42
oms_signal_type_enu_t
Definition: Types.h:135
std::vector< Connector * > connectors
last element is always NULL
Definition: System.h:217
oms_status_enu_t addConnectorToTLMBus(const ComRef &busCref, const ComRef &connectorCref, const std::string type)
Definition: System.cpp:1299
oms_status_enu_t importFromSSD_ConnectionGeometry(const pugi::xml_node &node, const ComRef &crefA, const ComRef &crefB)
Definition: System.cpp:2051
Definition: AlgLoop.h:44
oms_system_enu_t getType() const
Definition: System.h:81
oms_status_enu_t importBusConnectorGeometry(const pugi::xml_node &node)
Definition: System.cpp:2343
oms_status_enu_t delete_(const ComRef &cref)
Definition: System.cpp:1560
double absoluteTolerance
Definition: System.h:194
oms_fault_type_enu_t
Definition: Types.h:76
virtual oms_status_enu_t instantiate()=0
oms_status_enu_t getAllResources(std::vector< std::string > &resources)
Definition: System.cpp:1677
oms_status_enu_t setTolerance(double absoluteTolerance, double relativeTolerance)
Definition: System.h:161
Parameters for TLM connection.
Definition: Types.h:360
bool isConnected(const ComRef &cref) const
Definition: System.cpp:1551
const std::map< ComRef, System * > & getSubSystems()
Definition: System.h:123
double time
Definition: System.h:178
const ComRef & getCref() const
Definition: System.h:77
Element * getElement()
Definition: System.h:79
oms_tlm_domain_t
Definition: Types.h:87
const char * signal
Definition: Tags.cpp:38
DirectedGraph eventGraph
filtered dependency graph, without parameters, solved at event mode
Definition: System.h:186
bool copyResources()
Definition: System.cpp:1670
std::string getConnectorOwner(const ComRef &cref) const
Definition: System.cpp:933
virtual oms_status_enu_t reset()=0
oms_status_enu_t solveAlgLoop(DirectedGraph &graph, int loopNumber)
Definition: System.cpp:2581
oms_status_enu_t importBusConnectorSignals(const pugi::xml_node &node)
Definition: System.cpp:2315
oms_status_enu_t addSubSystem(const ComRef &cref, oms_system_enu_t type)
Definition: System.cpp:238
oms_status_enu_t setReal(const ComRef &cref, double value)
Definition: System.cpp:1990
double minimumStepSize
Definition: System.h:196
Model * parentModel
Definition: System.h:209
Element.
Definition: Element.h:52
Definition: ConnectionGeometry.h:45
oms_status_enu_t importTLMBus(const pugi::xml_node &node, Component *component)
Definition: System.cpp:2267
**
Definition: Connection.h:47
oms_status_enu_t importParameterMappingFromSSM(std::string fileName, std::multimap< ComRef, ComRef > &mappedEntry)
Definition: System.cpp:2541
const DirectedGraph & getOutputsGraph()
Definition: System.h:127
std::map< ComRef, Component * > components
Definition: System.h:212
ctpl::thread_pool & getThreadPool()
Definition: System.cpp:2233
System * getParentSystem() const
Definition: System.h:120
double maximumStepSize
Definition: System.h:197
Variable * getVariable(const ComRef &cref)
Definition: System.cpp:1899
oms_status_enu_t addSubModel(const ComRef &cref, const std::string &fmuPath)
Definition: System.cpp:270
oms_status_enu_t addTLMBus(const ComRef &cref, oms_tlm_domain_t domain, const int dimensions, const oms_tlm_interpolation_t interpolation)
Definition: System.cpp:1218
Definition: ConnectorGeometry.h:45
oms_status_enu_t setRealInputDerivatives(const ComRef &cref, int order, double value)
Definition: System.cpp:2046
const DirectedGraph & getInitialUnknownsGraph()
Definition: System.h:126
oms_status_enu_t addConnection(const ComRef &crefA, const ComRef &crefB)
Definition: System.cpp:999
const char * component
Definition: Tags.cpp:45
Component * getComponent(const ComRef &cref)
Definition: System.cpp:186
bool validCref(const ComRef &cref)
Definition: System.cpp:213
Connection ** getConnections(const ComRef &cref)
Definition: System.cpp:985
oms_status_enu_t setConnectorGeometry(const ComRef &cref, const oms::ssd::ConnectorGeometry *geometry)
Definition: System.cpp:1393
Definition: System.h:67
System * parentSystem
Definition: System.h:210
Connector ** getConnectors()
Definition: System.h:93
Definition: DirectedGraph.h:55
oms_status_enu_t addExternalModel(const ComRef &cref, std::string path, std::string startscript)
Definition: System.cpp:1369
System * getSystem(const ComRef &cref)
Definition: System.cpp:171
std::map< ComRef, System * > subsystems
Definition: System.h:211
std::map< std::string, std::string > startValuesFileSources
ssvFileSource mapped with ssmFilesource if mapping is provided, otherwise only ssvFilesource entry is...
Definition: System.h:176
virtual oms_status_enu_t terminate()=0
double getMaximumStepSize()
Definition: System.h:164
virtual oms_status_enu_t registerSignalsForResultFile(ResultWriter &resultFile)
Definition: System.cpp:2071
oms_status_enu_t exportDependencyGraphs(const std::string &pathInitialization, const std::string &pathEvent, const std::string &pathSimulation)
Definition: System.cpp:1690
oms::ComRef getValidCref(const ComRef &cref)
Definition: System.cpp:1879
std::vector< Connection * > connections
last element is always NULL
Definition: System.h:223
virtual oms_status_enu_t importFromSSD_SimulationInformation(const pugi::xml_node &node, const std::string &sspVersion)=0