25 #ifndef CASADI_FMU_IMPL_HPP
26 #define CASADI_FMU_IMPL_HPP
29 #include "importer.hpp"
30 #include "shared_object.hpp"
31 #include "resource.hpp"
39 bool discrete_states_need_update;
40 bool terminate_simulation;
41 bool nominals_of_continuous_states_changed;
42 bool values_of_continuous_states_changed;
43 bool next_event_time_defined;
44 double next_event_time;
48 class DaeBuilderInternal;
61 class CASADI_EXPORT FmuInternal :
public SharedObjectInternal {
65 FmuInternal(
const std::string& name,
66 const std::vector<std::string>& scheme_in,
const std::vector<std::string>& scheme_out,
67 const std::map<std::string, std::vector<size_t>>& scheme,
const std::vector<std::string>& aux);
70 ~FmuInternal()
override;
73 virtual void init(
const DaeBuilderInternal* dae);
76 virtual void load_functions() = 0;
79 virtual int enter_initialization_mode(
void* instance)
const = 0;
82 virtual int exit_initialization_mode(
void* instance)
const = 0;
85 virtual int enter_continuous_time_mode(
void* instance)
const = 0;
88 virtual int update_discrete_states(
void* instance, EventMemory* eventmem)
const = 0;
90 virtual int get_derivatives(
void* instance,
double* derivatives,
size_t nx)
const = 0;
93 virtual int set_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
94 const double* values,
size_t n_values)
const = 0;
97 virtual int get_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
98 double* values,
size_t n_values)
const = 0;
101 virtual int get_directional_derivative(
void* instance,
const unsigned int* vr_out,
size_t n_out,
102 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
103 double* sensitivity,
size_t n_sensitivity)
const = 0;
106 virtual int get_adjoint_derivative(
void* instance,
const unsigned int* vr_out,
size_t n_out,
107 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
108 double* sensitivity,
size_t n_sensitivity)
const;
111 virtual int set_values(
void* instance)
const = 0;
114 virtual int get_aux(
void* instance) = 0;
117 virtual void finalize();
122 void disp(std::ostream& stream,
bool more)
const override;
127 size_t n_in()
const {
return iind_.size();}
132 size_t n_out()
const {
return oind_.size();}
135 size_t index_in(
const std::string& n)
const;
138 size_t index_out(
const std::string& n)
const;
141 Sparsity jac_sparsity(
const std::vector<size_t>& osub,
const std::vector<size_t>& isub)
const;
144 Sparsity hess_sparsity(
const std::vector<size_t>& r,
const std::vector<size_t>& c)
const;
150 std::vector<double> all_nominal_in(
size_t i)
const;
151 std::vector<double> all_nominal_out(
size_t i)
const;
155 std::string desc_in(FmuMemory* m,
size_t id,
bool more =
true)
const;
158 virtual std::string system_infix()
const = 0;
161 static std::string dll_suffix();
165 T* load_function(
const std::string& symname);
168 int discrete_states_iter(
void* instance)
const;
173 virtual int init_mem(FmuMemory* m)
const;
178 virtual FmuMemory* alloc_mem(
const FmuFunction& f)
const = 0;
183 virtual void free_mem(
void *mem)
const = 0;
186 virtual void* instantiate()
const = 0;
189 virtual void free_instance(
void* c)
const = 0;
192 void set(FmuMemory* m,
size_t ind,
const double* value)
const;
195 void request(FmuMemory* m,
size_t ind)
const;
198 int eval(FmuMemory* m)
const;
201 void get(FmuMemory* m,
size_t id,
double* value)
const;
204 void set_fwd(FmuMemory* m, casadi_int nseed,
205 const casadi_int*
id,
const double* v)
const;
208 void set_fwd(FmuMemory* m,
size_t ind,
const double* v)
const;
211 void request_fwd(FmuMemory* m, casadi_int nsens,
const casadi_int*
id,
212 const casadi_int* wrt_id)
const;
215 void request_fwd(FmuMemory* m, casadi_int ind)
const;
218 int eval_fwd(FmuMemory* m,
bool independent_seeds)
const;
221 int eval_ad(FmuMemory* m)
const;
224 int eval_fd(FmuMemory* m,
bool independent_seeds)
const;
227 void get_fwd(FmuMemory* m, casadi_int nsens,
228 const casadi_int*
id,
double* v)
const;
231 void get_fwd(FmuMemory* m,
size_t ind,
double* v)
const;
234 void set_adj(FmuMemory* m, casadi_int nseed,
235 const casadi_int*
id,
const double* v)
const;
238 void set_adj(FmuMemory* m,
size_t ind,
const double* v)
const;
241 void request_adj(FmuMemory* m, casadi_int nsens,
const casadi_int*
id,
242 const casadi_int* wrt_id)
const;
245 void request_adj(FmuMemory* m, casadi_int ind)
const;
248 int eval_adj(FmuMemory* m)
const;
251 void get_adj(FmuMemory* m, casadi_int nsens,
252 const casadi_int*
id,
double* v)
const;
255 void get_adj(FmuMemory* m,
size_t ind,
double* v)
const;
258 void gather_fwd(FmuMemory* m)
const;
261 void gather_adj(FmuMemory* m)
const;
264 void gather_io(FmuMemory* m)
const;
269 virtual void get_stats(FmuMemory* m,
Dict* stats,
270 const std::vector<std::string>& name_in,
const InputStruct* in)
const = 0;
272 void serialize(SerializingStream& s)
const;
274 virtual void serialize_type(SerializingStream& s)
const;
275 virtual void serialize_body(SerializingStream& s)
const;
277 static FmuInternal* deserialize(DeserializingStream& s);
280 explicit FmuInternal(DeserializingStream& s);
290 std::vector<std::string> scheme_in_, scheme_out_;
291 std::map<std::string, std::vector<size_t>> scheme_;
294 std::vector<std::string> aux_;
297 std::string resource_loc_;
303 std::string instance_name_;
306 std::string instantiation_token_;
312 casadi_int number_of_event_indicators_;
315 bool provides_directional_derivatives_, provides_adjoint_derivatives_;
318 bool can_be_instantiated_only_once_per_process_;
324 std::vector<size_t> iind_, iind_map_, oind_, oind_map_;
327 bool has_independent_;
330 std::vector<double> nominal_in_, nominal_out_;
331 std::vector<double> min_in_, min_out_;
332 std::vector<double> max_in_, max_out_;
333 std::vector<std::string> vn_in_, vn_out_;
334 std::vector<unsigned int> vr_in_, vr_out_;
337 std::vector<double> value_in_;
340 std::vector<std::vector<size_t>> ired_, ored_;
343 Sparsity jac_sp_, hess_sp_;
345 mutable bool warning_fired_discrete_states_need_update_;
346 mutable bool warning_fired_terminate_simulation_;
347 mutable bool warning_fired_nominals_of_continuous_states_changed_;
348 mutable bool warning_fired_values_of_continuous_states_changed_;
349 mutable bool warning_fired_next_event_time_defined_;
353 bool do_evaluation_dance_;
357 T* FmuInternal::load_function(
const std::string& symname) {
359 signal_t f = li_.get_function(symname);
361 casadi_assert(f != 0,
"Cannot retrieve '" + symname +
"'");
363 return reinterpret_cast<T*
>(f);
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.