32#ifndef _OMS_SYSTEM_SC_H_
33#define _OMS_SYSTEM_SC_H_
37#include "OMSimulator/Types.h"
39#include <cvode/cvode.h>
40#include <nvector/nvector_serial.h>
41#include <sunlinsol/sunlinsol_dense.h>
47 int cvode_rhs(realtype t, N_Vector y, N_Vector ydot,
void* user_data);
49 int cvode_roots(realtype t, N_Vector y, realtype *gout,
void* user_data);
63 oms_status_enu_t
reset();
65 oms_status_enu_t
stepUntil(
double stopTime);
72 oms_status_enu_t
setSolver(oms_solver_enu_t solver) {
if (solver > oms_solver_sc_min && solver < oms_solver_sc_max) {
solverMethod=solver;
return oms_status_ok;}
return oms_status_error;}
86 std::vector<ComponentFMUME*>
fmus;
121 friend int oms::cvode_rhs(realtype t, N_Vector y, N_Vector ydot,
void* user_data);
ComRef - component reference.
Definition ComRef.h:47
Definition DirectedGraph.h:65
oms_status_enu_t importFromSSD_SimulationInformation(const pugi::xml_node &node, const std::string &sspVersion)
Definition SystemSC.cpp:193
oms_status_enu_t setSolverMethod(std::string)
Definition SystemSC.cpp:160
oms_status_enu_t doStepEuler()
Definition SystemSC.cpp:549
std::vector< double * > event_indicators
Definition SystemSC.h:96
bool algebraic
Definition SystemSC.h:99
std::vector< ComponentFMUME * > fmus
Definition SystemSC.h:86
std::string getSolverName() const
Definition SystemSC.cpp:147
oms_status_enu_t terminate()
Definition SystemSC.cpp:422
static System * NewSystem(const oms::ComRef &cref, Model *parentModel, System *parentSystem)
Definition SystemSC.cpp:129
oms_status_enu_t reset()
Definition SystemSC.cpp:487
oms_status_enu_t setSolver(oms_solver_enu_t solver)
Definition SystemSC.h:72
oms_status_enu_t exportToSSD_SimulationInformation(pugi::xml_node &node) const
Definition SystemSC.cpp:172
union oms::SystemSC::SolverData_t solverData
~SystemSC()
Definition SystemSC.cpp:125
std::vector< double * > event_indicators_prev
Definition SystemSC.h:97
std::vector< size_t > nStates
Definition SystemSC.h:90
std::vector< double * > states
Definition SystemSC.h:93
SystemSC(SystemSC const ©)
not implemented
SystemSC & operator=(SystemSC const ©)
not implemented
oms_status_enu_t doStepCVODE()
Definition SystemSC.cpp:771
std::vector< fmi2Boolean > callEventUpdate
Definition SystemSC.h:88
oms_status_enu_t initialize()
Definition SystemSC.cpp:266
oms_status_enu_t instantiate()
Definition SystemSC.cpp:220
std::vector< double * > states_nominal
Definition SystemSC.h:95
oms_status_enu_t updateInputs(DirectedGraph &graph)
Definition SystemSC.cpp:956
oms_status_enu_t stepUntil(double stopTime)
Definition SystemSC.cpp:930
std::vector< double * > states_der
Definition SystemSC.h:94
oms_status_enu_t doStep()
Definition SystemSC.cpp:534
std::vector< fmi2Boolean > terminateSimulation
Definition SystemSC.h:89
std::vector< size_t > nEventIndicators
Definition SystemSC.h:91
ComRef cref
Definition System.h:225
oms_solver_enu_t solverMethod
Definition System.h:214
System * parentSystem
Definition System.h:228
Model * parentModel
Definition System.h:227
int cvode_rhs_algebraic(realtype t, N_Vector y, N_Vector ydot, void *user_data)
Definition SystemSC.cpp:77
int cvode_roots(realtype t, N_Vector y, realtype *gout, void *user_data)
Definition SystemSC.cpp:89
int cvode_rhs(realtype t, N_Vector y, N_Vector ydot, void *user_data)
Definition SystemSC.cpp:45
Definition SystemSC.h:106
SUNMatrix J
Definition SystemSC.h:110
SUNLinearSolver linSol
Definition SystemSC.h:109
N_Vector y
Definition SystemSC.h:108
N_Vector abstol
Definition SystemSC.h:112
void * mem
Definition SystemSC.h:107
N_Vector liny
Definition SystemSC.h:111
Definition SystemSC.h:102
Definition SystemSC.h:116
SolverDataEuler_t euler
Definition SystemSC.h:117
SolverDataCVODE_t cvode
Definition SystemSC.h:118