25 #ifndef CASADI_FMU2_HPP
26 #define CASADI_FMU2_HPP
28 #include "fmu_impl.hpp"
30 #include <fmi2Functions.h>
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);
55 std::string
class_name()
const override {
return "Fmu2";}
63 int init_mem(
FmuMemory* m)
const override;
73 void free_mem(
void *mem)
const override;
76 void finalize()
override;
79 void load_functions()
override;
82 std::vector<fmi2ValueReference> vr_real_, vr_integer_,
vr_boolean_, vr_string_;
89 std::vector<std::string> vn_aux_real_, vn_aux_integer_,
vn_aux_boolean_, vn_aux_string_;
90 std::vector<fmi2ValueReference> vr_aux_real_, vr_aux_integer_,
vr_aux_boolean_, vr_aux_string_;
129 std::string system_infix()
const override;
132 void* instantiate()
const override;
135 void free_instance(
void* instance)
const override;
138 int reset(
void* instance);
141 int enter_initialization_mode(
void* instance)
const override;
144 int exit_initialization_mode(
void* instance)
const override;
147 int enter_continuous_time_mode(
void* instance)
const override;
150 int update_discrete_states(
void* instance,
EventMemory* eventmem)
const override;
152 int get_derivatives(
void* instance,
double* derivatives,
size_t nx)
const override;
155 int set_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
156 const double* values,
size_t n_values)
const override;
159 int get_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
160 double* values,
size_t n_values)
const override;
163 int get_directional_derivative(
void* instance,
const unsigned int* vr_out,
size_t n_out,
164 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
165 double* sensitivity,
size_t n_sensitivity)
const override;
168 int set_values(
void* instance)
const override;
171 int get_aux(
void* instance)
override;
174 int get_aux_impl(
void* instance,
Value& aux_value)
const;
180 const std::vector<std::string>& name_in,
const InputStruct* in)
const override;
183 static void logger(fmi2ComponentEnvironment componentEnvironment,
184 fmi2String instanceName,
187 fmi2String message, ...);
Helper class for Serialization.
Interface to a binary FMU, adhering to FMI version 2.0.
fmi2ExitInitializationModeTYPE * exit_initialization_mode_
std::vector< fmi2Real > init_real_
std::vector< fmi2ValueReference > vr_boolean_
std::vector< fmi2Boolean > init_boolean_
fmi2CallbackFunctions functions_
fmi2SetupExperimentTYPE * setup_experiment_
std::vector< fmi2Integer > init_integer_
fmi2EnterInitializationModeTYPE * enter_initialization_mode_
fmi2InstantiateTYPE * instantiate_
fmi2GetIntegerTYPE * get_integer_
fmi2SetTimeTYPE * set_time_
fmi2GetBooleanTYPE * get_boolean_
fmi2SetBooleanTYPE * set_boolean_
fmi2SetStringTYPE * set_string_
fmi2SetIntegerTYPE * set_integer_
fmi2SetRealTYPE * set_real_
std::vector< std::string > vn_aux_boolean_
fmi2GetDirectionalDerivativeTYPE * get_directional_derivative_
fmi2GetDerivativesTYPE * get_derivatives_
fmi2FreeInstanceTYPE * free_instance_
fmi2EnterContinuousTimeModeTYPE * enter_continuous_time_mode_
std::string class_name() const override
Get type name.
fmi2NewDiscreteStatesTYPE * new_discrete_states_
fmi2GetRealTYPE * get_real_
fmi2GetStringTYPE * get_string_
std::vector< std::string > init_string_
std::vector< fmi2ValueReference > vr_aux_boolean_
Helper class for Serialization.
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.
std::vector< fmi2Boolean > v_boolean
std::vector< fmi2Real > v_real
std::vector< std::string > v_string
std::vector< fmi2Integer > v_integer