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"
65 const std::vector<std::string>& scheme_in,
const std::vector<std::string>& scheme_out,
66 const std::map<std::string, std::vector<size_t>>& scheme,
const std::vector<std::string>& aux);
90 virtual int set_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
91 const double* values,
size_t n_values)
const = 0;
94 virtual int get_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
95 double* values,
size_t n_values)
const = 0;
99 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
100 double* sensitivity,
size_t n_sensitivity)
const = 0;
103 virtual int get_adjoint_derivative(
void* instance,
const unsigned int* vr_out,
size_t n_out,
104 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
105 double* sensitivity,
size_t n_sensitivity)
const;
119 void disp(std::ostream& stream,
bool more)
const override;
124 size_t n_in()
const {
return iind_.size();}
129 size_t n_out()
const {
return oind_.size();}
132 size_t index_in(
const std::string& n)
const;
135 size_t index_out(
const std::string& n)
const;
138 Sparsity jac_sparsity(
const std::vector<size_t>& osub,
const std::vector<size_t>& isub)
const;
141 Sparsity hess_sparsity(
const std::vector<size_t>& r,
const std::vector<size_t>& c)
const;
147 std::vector<double> all_nominal_in(
size_t i)
const;
148 std::vector<double> all_nominal_out(
size_t i)
const;
152 std::string desc_in(
FmuMemory* m,
size_t id,
bool more =
true)
const;
158 static std::string dll_suffix();
162 T* load_function(
const std::string& symname);
165 int discrete_states_iter(
void* instance)
const;
179 void set(
FmuMemory* m,
size_t ind,
const double* value)
const;
182 void request(
FmuMemory* m,
size_t ind)
const;
188 void get(
FmuMemory* m,
size_t id,
double* value)
const;
191 void set_fwd(
FmuMemory* m, casadi_int nseed,
192 const casadi_int*
id,
const double* v)
const;
195 void set_fwd(
FmuMemory* m,
size_t ind,
const double* v)
const;
198 void request_fwd(
FmuMemory* m, casadi_int nsens,
const casadi_int*
id,
199 const casadi_int* wrt_id)
const;
202 void request_fwd(
FmuMemory* m, casadi_int ind)
const;
205 int eval_fwd(
FmuMemory* m,
bool independent_seeds)
const;
211 int eval_fd(
FmuMemory* m,
bool independent_seeds)
const;
214 void get_fwd(
FmuMemory* m, casadi_int nsens,
215 const casadi_int*
id,
double* v)
const;
218 void get_fwd(
FmuMemory* m,
size_t ind,
double* v)
const;
221 void set_adj(
FmuMemory* m, casadi_int nseed,
222 const casadi_int*
id,
const double* v)
const;
225 void set_adj(
FmuMemory* m,
size_t ind,
const double* v)
const;
228 void request_adj(
FmuMemory* m, casadi_int nsens,
const casadi_int*
id,
229 const casadi_int* wrt_id)
const;
232 void request_adj(
FmuMemory* m, casadi_int ind)
const;
238 void get_adj(
FmuMemory* m, casadi_int nsens,
239 const casadi_int*
id,
double* v)
const;
242 void get_adj(
FmuMemory* m,
size_t ind,
double* v)
const;
257 const std::vector<std::string>& name_in,
const InputStruct* in)
const = 0;
278 std::map<std::string, std::vector<size_t>>
scheme_;
311 std::vector<size_t>
iind_, iind_map_, oind_, oind_map_;
320 std::vector<std::string>
vn_in_, vn_out_;
321 std::vector<unsigned int>
vr_in_, vr_out_;
327 std::vector<std::vector<size_t>>
ired_, ored_;
338 casadi_assert(f != 0,
"Cannot retrieve '" + symname +
"'");
340 return reinterpret_cast<T*
>(f);
Helper class for Serialization.
std::string instantiation_token_
std::vector< double > max_in_
std::string name_
Instance name.
virtual int get_directional_derivative(void *instance, const unsigned int *vr_out, size_t n_out, const unsigned int *vr_in, size_t n_in, const double *seed, size_t n_seed, double *sensitivity, size_t n_sensitivity) const =0
bool provides_adjoint_derivatives_
virtual void free_instance(void *c) const =0
std::vector< size_t > iind_
std::vector< std::vector< size_t > > ired_
std::vector< std::string > aux_
std::map< std::string, std::vector< size_t > > scheme_
virtual int get_aux(void *instance)=0
virtual int get_real(void *instance, const unsigned int *vr, size_t n_vr, double *values, size_t n_values) const =0
std::vector< std::string > vn_in_
virtual void load_functions()=0
virtual int update_discrete_states(void *instance, EventMemory *eventmem) const =0
virtual void get_stats(FmuMemory *m, Dict *stats, const std::vector< std::string > &name_in, const InputStruct *in) const =0
Get stats.
std::vector< unsigned int > vr_in_
virtual void * instantiate() const =0
virtual int exit_initialization_mode(void *instance) const =0
virtual int set_values(void *instance) const =0
bool can_be_instantiated_only_once_per_process_
T * load_function(const std::string &symname)
size_t n_in() const
Get the number of scheme inputs.
std::vector< double > nominal_in_
std::string resource_loc_
std::vector< double > min_in_
std::vector< double > value_in_
virtual int set_real(void *instance, const unsigned int *vr, size_t n_vr, const double *values, size_t n_values) const =0
casadi_int number_of_event_indicators_
size_t n_out() const
Get the number of scheme outputs.
virtual int enter_continuous_time_mode(void *instance) const =0
virtual int enter_initialization_mode(void *instance) const =0
std::vector< std::string > scheme_in_
std::string instance_name_
virtual std::string system_infix() const =0
signal_t get_function(const std::string &symname)
Get a function pointer for numerical evaluation.
RAII class for reading from a zip file.
Helper class for Serialization.
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.
void(* signal_t)(void)
Function pointer types for the C API.
bool discrete_states_need_update
bool terminate_simulation
bool next_event_time_defined
bool nominals_of_continuous_states_changed
bool values_of_continuous_states_changed