libode
Easy to compile, fast ODE integrators as C++ classes
|
Extension of OdeNewtonBridge class for fully implicit methods. More...
#include <ode_newton_bridge.h>
Public Member Functions | |
OdeNewtonIRK (unsigned long neq, int nk, Integrator *integrator) | |
constructs | |
![]() | |
OdeNewtonBridge (unsigned long neq, unsigned long nnew, Integrator *integrator) | |
constructs | |
~OdeNewtonBridge () | |
destructs | |
![]() | |
OdeNewton (unsigned long n) | |
constructs | |
virtual | ~OdeNewton () |
destructs | |
unsigned long | get_n () |
gets the size of the system | |
double | get_tol_Newton () |
gets the L infinity tolerance | |
unsigned long | get_iter_Newton () |
gets iteration counter | |
int | get_iJLU () |
gets the LU decomposition interval | |
unsigned long | get_nJLU () |
gets the LU decomposition counter | |
unsigned long | get_n_solve_LU () |
gets the LU solve counter | |
bool | get_modified () |
gets whether modified Newtion's is being used | |
bool | get_ignore_JLU () |
gets whether no LU decompositions should be done | |
void | set_tol_Newton (double tol_Newton) |
sets the L infinity tolerance | |
void | set_iter_Newton (unsigned long iter_Newton) |
sets the iteration counter | |
void | set_iJLU (int iJLU) |
sets the LU decomposition interval | |
void | set_modified (bool modified) |
sets whether modified Newtion's is being used | |
void | set_ignore_JLU (bool ignore_JLU) |
sets whether no LU decompositions should be done | |
int | solve_Newton (double *x) |
Solve the system of equations. | |
Protected Attributes | |
int | nk_ |
number of stages or k vectors | |
double ** | k_ |
pointer to the stage slopes of RK methods | |
double ** | a |
pointer to tableau coefficients | |
double * | b |
pointer to tableau coefficients | |
![]() | |
unsigned long | neq_ |
ODE system size. | |
unsigned long | nnew_ |
Newton system size. | |
Integrator * | integrator_ |
storage of a pointer to the solver class | |
double * | sol_ |
pointer to the solver's solution vector | |
double ** | Jac_ |
pointer to the solver's Jacobian matrix | |
double * | dt_ |
pointer to time step member | |
double * | ftemp_ |
temporary values for evaluation of Newton function | |
double * | soltemp_ |
temporary solution values | |
Additional Inherited Members | |
![]() | |
void | fun (double *solin, double *fout) |
wrapper around system evaluation function | |
void | jac (double *solin, double **Jout) |
wrapper around Jacobian evaluation function | |
![]() | |
virtual void | f_Newton (double *x, double *f)=0 |
evaluates the function being zeroed | |
virtual void | J_Newton (double *x, double **J)=0 |
evaluates the Jacobian matrix of the function being zeroed | |
Extension of OdeNewtonBridge class for fully implicit methods.
This class extends the bridge class by storing pointers to the integrator class's k vectors and tableau/coefficients, which are needed for newton iterations
Definition at line 93 of file ode_newton_bridge.h.
|
inline |
constructs
[in] | neq | size of system of ODEs |
[in] | nk | number of stages |
[in] | integrator | pointer to integrator object |
Definition at line 102 of file ode_newton_bridge.h.
|
protected |
pointer to tableau coefficients
Definition at line 121 of file ode_newton_bridge.h.
|
protected |
pointer to tableau coefficients
Definition at line 123 of file ode_newton_bridge.h.
|
protected |
pointer to the stage slopes of RK methods
Definition at line 119 of file ode_newton_bridge.h.
|
protected |
number of stages or k vectors
Definition at line 117 of file ode_newton_bridge.h.