OMSimulatorLib
The OMSimulator project is a FMI-based co-simulation environment.
Loading...
Searching...
No Matches
Variable.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_VARIABLE_H_
33#define _OMS_VARIABLE_H_
34
35#include "ComRef.h"
36#include "Connector.h"
37#include "OMSimulator/Types.h"
38
39#include <fmi4c.h>
40#include <string>
41#include <vector>
42
43namespace oms
44{
46 {
47 public:
49 ~Variable();
50
51 void markAsState(size_t der_index) { is_state = true; this->der_index = der_index; }
52 void markAsContinuousTimeState(size_t der_index) { is_continuous_time_state = true; this->der_index = der_index; }
54
55 unsigned int getStateIndex() const { return state_index; }
56
57 bool isFmi2() const {return fmi2;}
58 bool isFmi3() const {return fmi3;}
59
60 // causality attribute
67
68 bool isState() const { return is_state; }
69 bool isDer() const { return is_der; }
72
73 // initial attribute
77
78 bool isInitialUnknown() const {
79 return (isOutput() && (isApprox() || isCalculated()))
82 || (isContinuousTimeDer() && (isApprox() || isCalculated()));
83 }
84
85 const ComRef& getCref() const { return cref; }
86 operator std::string() const { return std::string(cref); }
87
92 const std::string& getDescription() const { return description; }
93
94 bool isTypeBoolean() const { return oms_signal_type_boolean == type; }
96 bool isTypeReal() const { return oms_signal_type_real == type; }
97 bool isTypeString() const { return oms_signal_type_string == type; }
98
99 std::string getCausalityString() const;
101
102 unsigned int getIndex() const { return index; }
104
105 private:
106
109
111 std::string description;
113
114 // FMI 2.0 specific members
119
120 // FMI 3.0 specific members
125
127 bool is_der;
132 unsigned int index;
133 size_t state_index;
134 size_t der_index;
135 bool fmi2;
136 bool fmi3;
137 friend bool operator==(const oms::Variable& v1, const oms::Variable& v2);
138 friend bool operator!=(const oms::Variable& v1, const oms::Variable& v2);
139 };
140
141 bool operator==(const oms::Variable& v1, const oms::Variable& v2);
142 bool operator!=(const oms::Variable& v1, const oms::Variable& v2);
143}
144
145#endif
ComRef - component reference.
Definition ComRef.h:47
Connector.
Definition Connector.h:50
Definition Variable.h:46
friend bool operator==(const oms::Variable &v1, const oms::Variable &v2)
void markAsState(size_t der_index)
Definition Variable.h:51
unsigned int getStateIndex() const
Definition Variable.h:55
bool isLocal() const
Definition Variable.h:65
bool isFmi2() const
Definition Variable.h:57
const std::string & getDescription() const
Definition Variable.h:92
bool isDer() const
Definition Variable.h:69
oms_causality_enu_t getCausality() const
Definition Variable.cpp:204
unsigned int getIndex() const
Definition Variable.h:102
bool isInitialUnknown() const
Definition Variable.h:78
void configureFMI3Variable(fmiHandle *fmi4c, int index)
Definition Variable.cpp:113
oms_signal_type_enu_t type
Definition Variable.h:130
void markAsContinuousTimeDer()
Definition Variable.h:53
bool isTypeBoolean() const
Definition Variable.h:94
bool fmi3
Definition Variable.h:136
bool is_continuous_time_state
Definition Variable.h:128
bool isTypeReal() const
Definition Variable.h:96
ComRef cref
Definition Variable.h:110
fmi2Variability fmi2Variability_
Definition Variable.h:117
fmi2Causality fmi2Causality_
Definition Variable.h:116
bool isCalculated() const
Definition Variable.h:76
bool isCalculatedParameter() const
Definition Variable.h:62
std::string description
Definition Variable.h:111
void configureFMI2Variable(fmiHandle *fmi4c, int index)
Definition Variable.cpp:61
bool isTypeString() const
Definition Variable.h:97
oms_signal_numeric_type_enu_t getNumericType() const
Definition Variable.h:91
bool is_continuous_time_der
Definition Variable.h:129
std::string getCausalityString() const
Definition Variable.cpp:250
bool is_der
Definition Variable.h:127
const ComRef & getCref() const
Definition Variable.h:85
bool isState() const
Definition Variable.h:68
oms_signal_type_enu_t getType() const
Definition Variable.h:90
friend bool operator!=(const oms::Variable &v1, const oms::Variable &v2)
size_t der_index
index origin = 0
Definition Variable.h:134
oms::Connector makeConnector(const oms::ComRef &owner) const
Definition Variable.h:103
bool isApprox() const
Definition Variable.h:75
bool isContinuousTimeDer() const
Definition Variable.h:71
bool is_state
Definition Variable.h:126
size_t state_index
index origin = 0
Definition Variable.h:133
fmi3Causality fmi3Causality_
Definition Variable.h:122
unsigned int index
index origin = 0
Definition Variable.h:132
bool isIndependent() const
Definition Variable.h:66
fmi2ValueReference fmi2Vr
Definition Variable.h:115
oms_component_enu_t componentType
Definition Variable.h:112
void markAsContinuousTimeState(size_t der_index)
Definition Variable.h:52
fmi2ValueReference getValueReference() const
Definition Variable.h:88
bool isContinuousTimeState() const
Definition Variable.h:70
oms_signal_numeric_type_enu_t numericType
Definition Variable.h:131
bool isTypeInteger() const
Definition Variable.h:95
fmi3Initial fmi3InitialProperty
Definition Variable.h:124
~Variable()
Definition Variable.cpp:200
fmi3Variability fmi3Variability_
Definition Variable.h:123
bool isExact() const
Definition Variable.h:74
bool isParameter() const
Definition Variable.h:61
bool isFmi3() const
Definition Variable.h:58
bool isInput() const
Definition Variable.h:63
fmi3ValueReference getValueReferenceFMI3() const
Definition Variable.h:89
bool isOutput() const
Definition Variable.h:64
fmi3ValueReference fmi3Vr
Definition Variable.h:121
fmi2Initial fmi2InitialProperty
Definition Variable.h:118
bool fmi2
Definition Variable.h:135
Definition AlgLoop.h:45
bool operator==(const ComRef &lhs, const ComRef &rhs)
Definition ComRef.cpp:210
bool operator!=(const ComRef &lhs, const ComRef &rhs)
Definition ComRef.cpp:215