Cantera 2.6.0
|
Wrapper class for 'cvodes' integrator from LLNL. More...
#include <CVodesIntegrator.h>
Public Member Functions | |
CVodesIntegrator () | |
Constructor. More... | |
virtual void | setTolerances (double reltol, size_t n, double *abstol) |
Set error tolerances. More... | |
virtual void | setTolerances (double reltol, double abstol) |
Set error tolerances. More... | |
virtual void | setSensitivityTolerances (double reltol, double abstol) |
Set the sensitivity error tolerances. More... | |
virtual void | setProblemType (int probtype) |
Set the problem type. More... | |
virtual void | initialize (double t0, FuncEval &func) |
Initialize the integrator for a new problem. More... | |
virtual void | reinitialize (double t0, FuncEval &func) |
virtual void | integrate (double tout) |
Integrate the system of equations. More... | |
virtual doublereal | step (double tout) |
Integrate the system of equations. More... | |
virtual double & | solution (size_t k) |
The current value of the solution of equation k. More... | |
virtual double * | solution () |
The current value of the solution of the system of equations. More... | |
virtual double * | derivative (double tout, int n) |
n-th derivative of the output function at time tout. More... | |
virtual int | lastOrder () const |
Order used during the last solution step. More... | |
virtual int | nEquations () const |
The number of equations. More... | |
virtual int | nEvals () const |
The number of function evaluations. More... | |
virtual void | setMaxOrder (int n) |
Set the maximum integration order that will be used. More... | |
virtual void | setMethod (MethodType t) |
Set the solution method. More... | |
virtual void | setMaxStepSize (double hmax) |
Set the maximum step size. More... | |
virtual void | setMinStepSize (double hmin) |
Set the minimum step size. More... | |
virtual void | setMaxSteps (int nmax) |
Set the maximum number of time-steps the integrator can take before reaching the next output time. More... | |
virtual int | maxSteps () |
Returns the maximum number of time-steps the integrator can take before reaching the next output time. More... | |
virtual void | setMaxErrTestFails (int n) |
Set the maximum permissible number of error test failures. More... | |
virtual void | setBandwidth (int N_Upper, int N_Lower) |
virtual int | nSensParams () |
virtual double | sensitivity (size_t k, size_t p) |
virtual std::string | getErrorInfo (int N) |
Returns a string listing the weighted error estimates associated with each solution component. More... | |
Public Member Functions inherited from Integrator | |
Integrator () | |
Default Constructor. More... | |
virtual | ~Integrator () |
Destructor. More... | |
Public Attributes | |
std::string | m_error_message |
Error message information provide by CVodes. More... | |
Protected Member Functions | |
void | applyOptions () |
Applies user-specified options to the underlying CVODES solver. More... | |
Private Member Functions | |
void | sensInit (double t0, FuncEval &func) |
Private Attributes | |
size_t | m_neq |
void * | m_cvode_mem |
SundialsContext | m_sundials_ctx |
SUNContext object for Sundials>=6.0. More... | |
void * | m_linsol |
Sundials linear solver object. More... | |
void * | m_linsol_matrix |
matrix used by Sundials More... | |
FuncEval * | m_func |
double | m_t0 |
double | m_time |
The current integrator time. More... | |
N_Vector | m_y |
N_Vector | m_abstol |
N_Vector | m_dky |
int | m_type |
int | m_itol |
int | m_method |
int | m_maxord |
double | m_reltol |
double | m_abstols |
double | m_reltolsens |
double | m_abstolsens |
size_t | m_nabs |
double | m_hmax |
double | m_hmin |
int | m_maxsteps |
int | m_maxErrTestFails |
N_Vector * | m_yS |
size_t | m_np |
int | m_mupper |
int | m_mlower |
bool | m_sens_ok |
Indicates whether the sensitivities stored in m_yS have been updated for at the current integrator time. More... | |
Wrapper class for 'cvodes' integrator from LLNL.
Definition at line 26 of file CVodesIntegrator.h.
CVodesIntegrator | ( | ) |
Constructor.
Default settings: dense Jacobian, no user-supplied Jacobian function, Newton iteration.
Definition at line 92 of file CVodesIntegrator.cpp.
|
virtual |
Definition at line 122 of file CVodesIntegrator.cpp.
|
virtual |
Set error tolerances.
reltol | scalar relative tolerance |
n | Number of equations |
abstol | array of N absolute tolerance values |
Reimplemented from Integrator.
Definition at line 165 of file CVodesIntegrator.cpp.
|
virtual |
Set error tolerances.
reltol | scalar relative tolerance |
abstol | scalar absolute tolerance |
Reimplemented from Integrator.
Definition at line 181 of file CVodesIntegrator.cpp.
|
virtual |
Set the sensitivity error tolerances.
reltol | scalar relative tolerance |
abstol | scalar absolute tolerance |
Reimplemented from Integrator.
Definition at line 188 of file CVodesIntegrator.cpp.
|
virtual |
Set the problem type.
probtype | Type of the problem |
Reimplemented from Integrator.
Definition at line 194 of file CVodesIntegrator.cpp.
|
virtual |
Initialize the integrator for a new problem.
Call after all options have been set.
t0 | initial time |
func | RHS evaluator object for system of equations. |
Reimplemented from Integrator.
Definition at line 278 of file CVodesIntegrator.cpp.
References FuncEval::clearErrors(), CVodesIntegrator::m_sundials_ctx, CVodesIntegrator::m_time, and FuncEval::neq().
|
virtual |
Reimplemented from Integrator.
Definition at line 373 of file CVodesIntegrator.cpp.
|
virtual |
Integrate the system of equations.
tout | Integrate to this time. Note that this is the absolute time value, not a time interval. |
Reimplemented from Integrator.
Definition at line 526 of file CVodesIntegrator.cpp.
References CVodesIntegrator::getErrorInfo(), FuncEval::getErrors(), CVodesIntegrator::m_error_message, CVodesIntegrator::m_sens_ok, and CVodesIntegrator::m_time.
|
virtual |
Integrate the system of equations.
tout | integrate to this time. Note that this is the absolute time value, not a time interval. |
Reimplemented from Integrator.
Definition at line 546 of file CVodesIntegrator.cpp.
References CVodesIntegrator::getErrorInfo(), FuncEval::getErrors(), CVodesIntegrator::m_error_message, CVodesIntegrator::m_sens_ok, and CVodesIntegrator::m_time.
|
virtual |
The current value of the solution of equation k.
Reimplemented from Integrator.
Definition at line 155 of file CVodesIntegrator.cpp.
|
virtual |
The current value of the solution of the system of equations.
Reimplemented from Integrator.
Definition at line 160 of file CVodesIntegrator.cpp.
|
virtual |
n-th derivative of the output function at time tout.
Reimplemented from Integrator.
Definition at line 565 of file CVodesIntegrator.cpp.
References FuncEval::getErrors(), and CVodesIntegrator::m_error_message.
|
virtual |
Order used during the last solution step.
Reimplemented from Integrator.
Definition at line 581 of file CVodesIntegrator.cpp.
|
inlinevirtual |
The number of equations.
Reimplemented from Integrator.
Definition at line 47 of file CVodesIntegrator.h.
|
virtual |
The number of function evaluations.
Reimplemented from Integrator.
Definition at line 588 of file CVodesIntegrator.cpp.
|
inlinevirtual |
Set the maximum integration order that will be used.
Reimplemented from Integrator.
Definition at line 51 of file CVodesIntegrator.h.
|
virtual |
Set the solution method.
Reimplemented from Integrator.
Definition at line 199 of file CVodesIntegrator.cpp.
References Cantera::Adams_Method, and Cantera::BDF_Method.
|
virtual |
Set the maximum step size.
Reimplemented from Integrator.
Definition at line 210 of file CVodesIntegrator.cpp.
|
virtual |
Set the minimum step size.
Reimplemented from Integrator.
Definition at line 218 of file CVodesIntegrator.cpp.
|
virtual |
Set the maximum number of time-steps the integrator can take before reaching the next output time.
nmax | The maximum number of steps, setting this value to zero disables this option. |
Reimplemented from Integrator.
Definition at line 226 of file CVodesIntegrator.cpp.
|
virtual |
Returns the maximum number of time-steps the integrator can take before reaching the next output time.
Reimplemented from Integrator.
Definition at line 234 of file CVodesIntegrator.cpp.
|
virtual |
Set the maximum permissible number of error test failures.
Reimplemented from Integrator.
Definition at line 239 of file CVodesIntegrator.cpp.
|
inlinevirtual |
Reimplemented from Integrator.
Definition at line 60 of file CVodesIntegrator.h.
|
inlinevirtual |
Reimplemented from Integrator.
Definition at line 64 of file CVodesIntegrator.h.
|
virtual |
Reimplemented from Integrator.
Definition at line 595 of file CVodesIntegrator.cpp.
|
virtual |
Returns a string listing the weighted error estimates associated with each solution component.
This information can be used to identify which variables are responsible for integrator failures or unexpected small timesteps.
Definition at line 621 of file CVodesIntegrator.cpp.
References CVodesIntegrator::m_sundials_ctx.
Referenced by CVodesIntegrator::integrate(), and CVodesIntegrator::step().
|
protected |
Applies user-specified options to the underlying CVODES solver.
Called during integrator initialization or reinitialization.
Definition at line 389 of file CVodesIntegrator.cpp.
References CVodesIntegrator::m_linsol, CVodesIntegrator::m_linsol_matrix, and CVodesIntegrator::m_sundials_ctx.
|
private |
Definition at line 247 of file CVodesIntegrator.cpp.
std::string m_error_message |
Error message information provide by CVodes.
Definition at line 76 of file CVodesIntegrator.h.
Referenced by Cantera::cvodes_err(), CVodesIntegrator::derivative(), CVodesIntegrator::integrate(), and CVodesIntegrator::step().
|
private |
Definition at line 86 of file CVodesIntegrator.h.
|
private |
Definition at line 87 of file CVodesIntegrator.h.
|
private |
SUNContext object for Sundials>=6.0.
Definition at line 88 of file CVodesIntegrator.h.
Referenced by CVodesIntegrator::applyOptions(), CVodesIntegrator::getErrorInfo(), and CVodesIntegrator::initialize().
|
private |
Sundials linear solver object.
Definition at line 89 of file CVodesIntegrator.h.
Referenced by CVodesIntegrator::applyOptions().
|
private |
matrix used by Sundials
Definition at line 90 of file CVodesIntegrator.h.
Referenced by CVodesIntegrator::applyOptions().
|
private |
Definition at line 91 of file CVodesIntegrator.h.
|
private |
Definition at line 92 of file CVodesIntegrator.h.
|
private |
The current integrator time.
Definition at line 93 of file CVodesIntegrator.h.
Referenced by CVodesIntegrator::initialize(), CVodesIntegrator::integrate(), and CVodesIntegrator::step().
|
private |
Definition at line 94 of file CVodesIntegrator.h.
|
private |
Definition at line 94 of file CVodesIntegrator.h.
|
private |
Definition at line 95 of file CVodesIntegrator.h.
|
private |
Definition at line 96 of file CVodesIntegrator.h.
|
private |
Definition at line 97 of file CVodesIntegrator.h.
|
private |
Definition at line 98 of file CVodesIntegrator.h.
|
private |
Definition at line 99 of file CVodesIntegrator.h.
|
private |
Definition at line 100 of file CVodesIntegrator.h.
|
private |
Definition at line 101 of file CVodesIntegrator.h.
|
private |
Definition at line 102 of file CVodesIntegrator.h.
|
private |
Definition at line 102 of file CVodesIntegrator.h.
|
private |
Definition at line 103 of file CVodesIntegrator.h.
|
private |
Definition at line 104 of file CVodesIntegrator.h.
|
private |
Definition at line 104 of file CVodesIntegrator.h.
|
private |
Definition at line 105 of file CVodesIntegrator.h.
|
private |
Definition at line 106 of file CVodesIntegrator.h.
|
private |
Definition at line 107 of file CVodesIntegrator.h.
|
private |
Definition at line 108 of file CVodesIntegrator.h.
|
private |
Definition at line 109 of file CVodesIntegrator.h.
|
private |
Definition at line 109 of file CVodesIntegrator.h.
|
private |
Indicates whether the sensitivities stored in m_yS have been updated for at the current integrator time.
Definition at line 113 of file CVodesIntegrator.h.
Referenced by CVodesIntegrator::integrate(), and CVodesIntegrator::step().