fmu2.hpp
1 /*
2  * This file is part of CasADi.
3  *
4  * CasADi -- A symbolic framework for dynamic optimization.
5  * Copyright (C) 2010-2023 Joel Andersson, Joris Gillis, Moritz Diehl,
6  * KU Leuven. All rights reserved.
7  * Copyright (C) 2011-2014 Greg Horn
8  *
9  * CasADi is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU Lesser General Public
11  * License as published by the Free Software Foundation; either
12  * version 3 of the License, or (at your option) any later version.
13  *
14  * CasADi is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  * Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with CasADi; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22  *
23  */
24 
25 #ifndef CASADI_FMU2_HPP
26 #define CASADI_FMU2_HPP
27 
28 #include "fmu_impl.hpp"
29 
30 #include <fmi2Functions.h>
31 
33 
34 namespace casadi {
35 
42 class CASADI_EXPORT Fmu2 : public FmuInternal {
43  public:
44  // Constructor
45  Fmu2(const std::string& name,
46  const std::vector<std::string>& scheme_in, const std::vector<std::string>& scheme_out,
47  const std::map<std::string, std::vector<size_t>>& scheme, const std::vector<std::string>& aux);
48 
50  ~Fmu2() override;
51 
55  std::string class_name() const override { return "Fmu2";}
56 
57  // Initialize
58  void init(const DaeBuilderInternal* dae) override;
59 
60  // Set C API functions
61  void load_functions() override;
62 
63  // Variables used for initialization, by type
64  std::vector<fmi2ValueReference> vr_real_, vr_integer_, vr_boolean_, vr_string_;
65  std::vector<fmi2Real> init_real_;
66  std::vector<fmi2Integer> init_integer_;
67  std::vector<fmi2Boolean> init_boolean_;
68  std::vector<std::string> init_string_;
69 
70  // Auxilliary variables, by type
71  std::vector<std::string> vn_aux_real_, vn_aux_integer_, vn_aux_boolean_, vn_aux_string_;
72  std::vector<fmi2ValueReference> vr_aux_real_, vr_aux_integer_, vr_aux_boolean_, vr_aux_string_;
73 
74  // Following members set in finalize
75 
76  // FMU C API function prototypes. Cf. FMI specification 2.0.2
77  fmi2InstantiateTYPE* instantiate_;
78  fmi2FreeInstanceTYPE* free_instance_;
79  fmi2ResetTYPE* reset_;
80  fmi2SetupExperimentTYPE* setup_experiment_;
81  fmi2EnterInitializationModeTYPE* enter_initialization_mode_;
82  fmi2ExitInitializationModeTYPE* exit_initialization_mode_;
83  fmi2EnterContinuousTimeModeTYPE* enter_continuous_time_mode_;
84  fmi2GetRealTYPE* get_real_;
85  fmi2SetRealTYPE* set_real_;
86  fmi2GetBooleanTYPE* get_boolean_;
87  fmi2SetBooleanTYPE* set_boolean_;
88  fmi2GetIntegerTYPE* get_integer_;
89  fmi2SetIntegerTYPE* set_integer_;
90  fmi2GetStringTYPE* get_string_;
91  fmi2SetStringTYPE* set_string_;
92  fmi2GetDirectionalDerivativeTYPE* get_directional_derivative_;
93  fmi2NewDiscreteStatesTYPE* new_discrete_states_;
94 
95  // Callback functions
96  fmi2CallbackFunctions functions_;
97 
98  // Collection of variable values, all types
99  struct Value {
100  std::vector<fmi2Real> v_real;
101  std::vector<fmi2Integer> v_integer;
102  std::vector<fmi2Boolean> v_boolean;
103  std::vector<std::string> v_string;
104  };
105 
107 
108  // Name of system, per the FMI specification
109  std::string system_infix() const override;
110 
111  // New memory object
112  void* instantiate() const override;
113 
114  // Free FMU instance
115  void free_instance(void* instance) const override;
116 
117  // Reset solver
118  int reset(void* instance);
119 
120  // Enter initialization mode
121  int enter_initialization_mode(void* instance) const override;
122 
123  // Exit initialization mode
124  int exit_initialization_mode(void* instance) const override;
125 
126  // Enter continuous-time mode
127  int enter_continuous_time_mode(void* instance) const override;
128 
129  // Update discrete states
130  int update_discrete_states(void* instance, EventMemory* eventmem) const override;
131 
132  // Set real values
133  int set_real(void* instance, const unsigned int* vr, size_t n_vr,
134  const double* values, size_t n_values) const override;
135 
136  // Get/evaluate real values
137  int get_real(void* instance, const unsigned int* vr, size_t n_vr,
138  double* values, size_t n_values) const override;
139 
140  // Forward mode AD
141  int get_directional_derivative(void* instance, const unsigned int* vr_out, size_t n_out,
142  const unsigned int* vr_in, size_t n_in, const double* seed, size_t n_seed,
143  double* sensitivity, size_t n_sensitivity) const override;
144 
145  // Copy values set in DaeBuilder to FMU
146  int set_values(void* instance) const override;
147 
148  // Retrieve auxilliary variables from FMU
149  int get_aux(void* instance) override;
150 
154  void get_stats(FmuMemory* m, Dict* stats,
155  const std::vector<std::string>& name_in, const InputStruct* in) const override;
156 
157  // Process message
158  static void logger(fmi2ComponentEnvironment componentEnvironment,
159  fmi2String instanceName,
160  fmi2Status status,
161  fmi2String category,
162  fmi2String message, ...);
163 
164  void serialize_body(SerializingStream& s) const override;
165 
166  static Fmu2* deserialize(DeserializingStream& s);
167 
168  protected:
169  explicit Fmu2(DeserializingStream& s);
170 };
171 
172 } // namespace casadi
173 
175 
176 #endif // CASADI_FMU2_HPP
Helper class for Serialization.
Interface to a binary FMU, adhering to FMI version 2.0.
Definition: fmu2.hpp:42
fmi2ExitInitializationModeTYPE * exit_initialization_mode_
Definition: fmu2.hpp:82
std::vector< fmi2Real > init_real_
Definition: fmu2.hpp:65
std::vector< fmi2ValueReference > vr_boolean_
Definition: fmu2.hpp:64
std::vector< fmi2Boolean > init_boolean_
Definition: fmu2.hpp:67
fmi2CallbackFunctions functions_
Definition: fmu2.hpp:96
fmi2SetupExperimentTYPE * setup_experiment_
Definition: fmu2.hpp:80
std::vector< fmi2Integer > init_integer_
Definition: fmu2.hpp:66
fmi2EnterInitializationModeTYPE * enter_initialization_mode_
Definition: fmu2.hpp:81
fmi2InstantiateTYPE * instantiate_
Definition: fmu2.hpp:77
fmi2GetIntegerTYPE * get_integer_
Definition: fmu2.hpp:88
fmi2GetBooleanTYPE * get_boolean_
Definition: fmu2.hpp:86
fmi2ResetTYPE * reset_
Definition: fmu2.hpp:79
fmi2SetBooleanTYPE * set_boolean_
Definition: fmu2.hpp:87
fmi2SetStringTYPE * set_string_
Definition: fmu2.hpp:91
fmi2SetIntegerTYPE * set_integer_
Definition: fmu2.hpp:89
fmi2SetRealTYPE * set_real_
Definition: fmu2.hpp:85
std::vector< std::string > vn_aux_boolean_
Definition: fmu2.hpp:71
fmi2GetDirectionalDerivativeTYPE * get_directional_derivative_
Definition: fmu2.hpp:92
fmi2FreeInstanceTYPE * free_instance_
Definition: fmu2.hpp:78
fmi2EnterContinuousTimeModeTYPE * enter_continuous_time_mode_
Definition: fmu2.hpp:83
Value aux_value_
Definition: fmu2.hpp:106
std::string class_name() const override
Get type name.
Definition: fmu2.hpp:55
fmi2NewDiscreteStatesTYPE * new_discrete_states_
Definition: fmu2.hpp:93
fmi2GetRealTYPE * get_real_
Definition: fmu2.hpp:84
fmi2GetStringTYPE * get_string_
Definition: fmu2.hpp:90
std::vector< std::string > init_string_
Definition: fmu2.hpp:68
std::vector< fmi2ValueReference > vr_aux_boolean_
Definition: fmu2.hpp:72
Interface to binary FMU.
Definition: fmu_impl.hpp:60
Helper class for Serialization.
The casadi namespace.
Definition: archiver.cpp:28
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.
std::vector< fmi2Boolean > v_boolean
Definition: fmu2.hpp:102
std::vector< fmi2Real > v_real
Definition: fmu2.hpp:100
std::vector< std::string > v_string
Definition: fmu2.hpp:103
std::vector< fmi2Integer > v_integer
Definition: fmu2.hpp:101