25 #ifndef CASADI_FMU3_HPP
26 #define CASADI_FMU3_HPP
28 #include "fmu_impl.hpp"
30 #include <fmi3Functions.h>
45 Fmu3(
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 "Fmu3";}
61 void load_functions()
override;
64 std::vector<fmi3ValueReference> vr_real_, vr_integer_,
vr_boolean_, vr_string_;
71 std::vector<std::string> vn_aux_real_, vn_aux_integer_,
vn_aux_boolean_, vn_aux_string_;
72 std::vector<fmi3ValueReference> vr_aux_real_, vr_aux_integer_,
vr_aux_boolean_, vr_aux_string_;
107 std::string system_infix()
const override;
110 void* instantiate()
const override;
113 void free_instance(
void* instance)
const override;
116 int reset(
void* instance);
119 int enter_initialization_mode(
void* instance)
const override;
122 int exit_initialization_mode(
void* instance)
const override;
125 int enter_continuous_time_mode(
void* instance)
const override;
128 int update_discrete_states(
void* instance,
EventMemory* eventmem)
const override;
131 int set_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
132 const double* values,
size_t n_values)
const override;
135 int get_real(
void* instance,
const unsigned int* vr,
size_t n_vr,
136 double* values,
size_t n_values)
const override;
139 int get_directional_derivative(
void* instance,
const unsigned int* vr_out,
size_t n_out,
140 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
141 double* sensitivity,
size_t n_sensitivity)
const override;
144 int get_adjoint_derivative(
void* instance,
const unsigned int* vr_out,
size_t n_out,
145 const unsigned int* vr_in,
size_t n_in,
const double* seed,
size_t n_seed,
146 double* sensitivity,
size_t n_sensitivity)
const override;
149 int set_values(
void* instance)
const override;
152 int get_aux(
void* instance)
override;
158 const std::vector<std::string>& name_in,
const InputStruct* in)
const override;
161 static void log_message_callback(fmi3InstanceEnvironment instanceEnvironment,
162 fmi3Status status, fmi3String category, fmi3String message);
Interface to a binary FMU, adhering to FMI version 2.0.
fmi3InstantiateModelExchangeTYPE * instantiate_model_exchange_
fmi3ExitInitializationModeTYPE * exit_initialization_mode_
std::vector< std::string > vn_aux_boolean_
std::vector< fmi3ValueReference > vr_boolean_
fmi3GetStringTYPE * get_string_
fmi3SetFloat64TYPE * set_float64_
std::vector< fmi3Boolean > init_boolean_
fmi3SetInt32TYPE * set_int32_
std::vector< fmi3Int32 > init_integer_
fmi3EnterContinuousTimeModeTYPE * enter_continuous_time_mode_
std::vector< std::string > init_string_
fmi3GetInt32TYPE * get_int32_
fmi3SetStringTYPE * set_string_
fmi3SetTimeTYPE * set_time_
fmi3GetFloat64TYPE * get_float64_
fmi3SetBooleanTYPE * set_boolean_
std::vector< fmi3ValueReference > vr_aux_boolean_
fmi3GetDirectionalDerivativeTYPE * get_directional_derivative_
fmi3GetBooleanTYPE * get_boolean_
std::vector< fmi3Float64 > init_real_
fmi3GetAdjointDerivativeTYPE * get_adjoint_derivative_
fmi3UpdateDiscreteStatesTYPE * update_discrete_states_
std::string class_name() const override
Get type name.
fmi3FreeInstanceTYPE * free_instance_
fmi3EnterInitializationModeTYPE * enter_initialization_mode_
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.
std::vector< fmi3Float64 > v_real
std::vector< std::string > v_string
std::vector< fmi3Boolean > v_boolean
std::vector< fmi3Int32 > v_integer