32 #ifndef _OMS_ALGLOOP_H_
33 #define _OMS_ALGLOOP_H_
37 #include "OMSimulator/Types.h"
40 #include <kinsol/kinsol.h>
41 #include <nvector/nvector_serial.h>
42 #include <sunlinsol/sunlinsol_dense.h>
84 static int nlsKinsolJac(N_Vector u, N_Vector fu, SUNMatrix
J,
void *
user_data, N_Vector tmp1, N_Vector tmp2);
std::string getAlgSolverName()
Return solver method.
Definition: AlgLoop.cpp:621
oms_alg_solver_enu_t algSolverMethod
Definition: AlgLoop.h:101
const int systNumber
Definition: AlgLoop.h:108
double relativeTolerance
Definition: AlgLoop.h:109
const scc_t SCC
Strong connected components.
Definition: AlgLoop.h:107
scc_t getSCC()
Definition: AlgLoop.h:95
oms_status_enu_t solveAlgLoop(System &syst, DirectedGraph &graph)
Solve algebraic loop.
Definition: AlgLoop.cpp:506
AlgLoop(oms_alg_solver_enu_t method, double relativeTolerance, scc_t SCC, const int systNumber, const bool useDirectionalDerivative)
Construct a new oms::AlgLoop::AlgLoop object.
Definition: AlgLoop.cpp:472
KinsolSolver * kinsolData
Definition: AlgLoop.h:104
oms_status_enu_t fixPointIteration(System &syst, DirectedGraph &graph)
Fixed-point-iteration to solve algebraic loop.
Definition: AlgLoop.cpp:530
std::string dumpLoopVars(DirectedGraph &graph)
Dump variables of algebraic loop.
Definition: AlgLoop.cpp:643
Definition: DirectedGraph.h:65
static void sundialsErrorHandlerFunction(int error_code, const char *module, const char *function, char *msg, void *user_data)
Error handler function given to KINSOL.
Definition: AlgLoop.cpp:69
SUNLinearSolver linSol
Definition: AlgLoop.h:79
static int nlsKinsolResiduals(N_Vector u, N_Vector fval, void *user_data)
Residual function for KINSOL.
Definition: AlgLoop.cpp:191
void * kinsolMemory
Definition: AlgLoop.h:74
static void sundialsInfoHandlerFunction(const char *module, const char *function, char *msg, void *user_data)
Info handler function given to KINSOL.
Definition: AlgLoop.cpp:98
N_Vector initialGuess
Definition: AlgLoop.h:68
~KinsolSolver()
Destroy the oms::KinsolSolver::KinsolSolver object.
Definition: AlgLoop.cpp:271
double fnormtol
Definition: AlgLoop.h:65
static KinsolSolver * NewKinsolSolver(const int algLoopNum, const unsigned int size, double relativeTolerance, const bool useDirectionalDerivative)
Create new oms::KinsolSolver::KinsolSolver object.
Definition: AlgLoop.cpp:295
N_Vector y
Definition: AlgLoop.h:80
static int nlsKinsolJac(N_Vector u, N_Vector fu, SUNMatrix J, void *user_data, N_Vector tmp1, N_Vector tmp2)
Jacobian function for KINSOL.
Definition: AlgLoop.cpp:132
N_Vector fScale
Definition: AlgLoop.h:70
SUNMatrix J
Definition: AlgLoop.h:81
oms_status_enu_t kinsolSolve(System &syst, DirectedGraph &graph)
Solve algebraic system with KINSOL.
Definition: AlgLoop.cpp:403
void * user_data
Definition: AlgLoop.h:75
int size
Definition: AlgLoop.h:76
N_Vector uScale
Definition: AlgLoop.h:69
N_Vector fTmp
Definition: AlgLoop.h:71
struct oms::KINSOL_USER_DATA KINSOL_USER_DATA
System * syst
Definition: AlgLoop.h:50
DirectedGraph * graph
Definition: AlgLoop.h:51
unsigned int iteration
Definition: AlgLoop.h:53
const int algLoopNumber
Definition: AlgLoop.h:52
Strong connected components data type.
Definition: DirectedGraph.h:54