Template Numerical Library version\ main:978fbd2
|
Public Types | |
using | IndexType = std::size_t |
Type for indexing. | |
using | RealType = GetValueType_t< Vector > |
Type of floating-point arithemtics. | |
using | SolverMonitorType = SolverMonitor |
Type of object used for monitoring the convergence. | |
using | ValueType = typename VectorType::ValueType |
using | VectorType = Vector |
Public Types inherited from TNL::Solvers::ODE::StaticExplicitSolver< GetValueType_t< Vector >, std::size_t > | |
using | IndexType |
Indexing type. | |
using | RealType |
Type of the floating-point arithmetics or static vector. | |
Public Member Functions | |
__cuda_callable__ | ODESolver () |
Default constructor. | |
__cuda_callable__ | ODESolver (const ODESolver &solver) |
__cuda_callable__ RealType | getAdaptivity () const |
Getter of the parameter controlling the adaptive choice of the integration time step. | |
__cuda_callable__ Method & | getMethod () |
Gives reference to the underlying method. | |
__cuda_callable__ const Method & | getMethod () const |
Gives constant reference to the underlying method. | |
void __cuda_callable__ | init (const VectorType &u) |
Setup auxiliary vectors of the solver. | |
template<typename RHSFunction , typename... Params> | |
void __cuda_callable__ | iterate (VectorType &u, RealType &time, RealType &tau, RHSFunction &&f, Params &&... params) |
Performs one iteration of the solver. | |
void __cuda_callable__ | reset () |
This method is just for consistency with the ODE solver for dynamic vectors. | |
__cuda_callable__ void | setAdaptivity (const RealType &adaptivity) |
Setter of the parameter controlling the adaptive choice of the integration time step. | |
bool | setup (const Config::ParameterContainer ¶meters, const String &prefix="") |
Method for setup of the explicit solver based on configuration parameters. | |
template<typename RHSFunction , typename... Params> | |
__cuda_callable__ bool | solve (VectorType &u, RHSFunction &&f, Params &&... params) |
Solve ODE given by a lambda function. | |
Public Member Functions inherited from TNL::Solvers::ODE::StaticExplicitSolver< GetValueType_t< Vector >, std::size_t > | |
__cuda_callable__ | StaticExplicitSolver ()=default |
Default constructor. | |
bool __cuda_callable__ | checkNextIteration () |
Checks if the solver is allowed to do the next iteration. | |
__cuda_callable__ const RealType & | getMaxTau () const |
Getter of maximal value of the time step. | |
__cuda_callable__ const RealType & | getStopTime () const |
Getter of the time where the evolution computation shall by stopped. | |
__cuda_callable__ const RealType & | getTau () const |
Getter of the time step used for the computation. | |
__cuda_callable__ const RealType & | getTime () const |
Getter of the current time of the evolution computed by the solver. | |
__cuda_callable__ void | setMaxTau (const RealType &maxTau) |
Setter of maximal value of the time step. | |
__cuda_callable__ void | setStopTime (const RealType &stopTime) |
Setter of the time where the evolution computation shall by stopped. | |
__cuda_callable__ void | setTau (const RealType &tau) |
Setter of the time step used for the computation. | |
__cuda_callable__ void | setTestingMode (bool testingMode) |
__cuda_callable__ void | setTime (const RealType &t) |
Settter of the current time of the evolution computed by the solver. | |
bool | setup (const Config::ParameterContainer ¶meters, const std::string &prefix="") |
Method for setup of the iterative solver based on configuration parameters. | |
Public Member Functions inherited from TNL::Solvers::StaticIterativeSolver< GetValueType_t< Vector >, std::size_t > | |
__cuda_callable__ | StaticIterativeSolver ()=default |
Default constructor. | |
__cuda_callable__ bool | checkConvergence () |
Checks whether the convergence occurred already. | |
__cuda_callable__ bool | checkNextIteration () |
Checks if the solver is allowed to do the next iteration. | |
__cuda_callable__ const GetValueType_t< Vector > & | getConvergenceResidue () const |
Gets the the convergence threshold. | |
__cuda_callable__ const GetValueType_t< Vector > & | getDivergenceResidue () const |
Gets the limit for the divergence criterion. | |
__cuda_callable__ const std::size_t & | getIterations () const |
Gets the number of iterations performed by the solver so far. | |
__cuda_callable__ const std::size_t & | getMaxIterations () const |
Gets the maximal number of iterations the solver is allowed to perform. | |
__cuda_callable__ const std::size_t & | getMinIterations () const |
Gets the minimal number of iterations the solver is supposed to do. | |
__cuda_callable__ const GetValueType_t< Vector > & | getResidue () const |
Gets the residue reached at the current iteration. | |
__cuda_callable__ bool | nextIteration () |
Proceeds to the next iteration. | |
__cuda_callable__ void | resetIterations () |
Sets the the number of the current iterations to zero. | |
__cuda_callable__ void | setConvergenceResidue (const GetValueType_t< Vector > &convergenceResidue) |
Sets the threshold for the convergence. | |
__cuda_callable__ void | setDivergenceResidue (const GetValueType_t< Vector > &divergenceResidue) |
Sets the residue limit for the divergence criterion. | |
__cuda_callable__ void | setMaxIterations (const std::size_t &maxIterations) |
Sets the maximal number of iterations the solver is allowed to perform. | |
__cuda_callable__ void | setMinIterations (const std::size_t &minIterations) |
Sets the minimal number of iterations the solver is supposed to do. | |
__cuda_callable__ void | setResidue (const GetValueType_t< Vector > &residue) |
Sets the residue reached at the current iteration. | |
bool | setup (const Config::ParameterContainer ¶meters, const std::string &prefix="") |
Method for setup of the iterative solver based on configuration parameters. | |
Static Public Member Functions | |
static void | configSetup (Config::ConfigDescription &config, const String &prefix="") |
Static method for setup of configuration parameters. | |
static constexpr bool | isStatic () |
Static Public Member Functions inherited from TNL::Solvers::ODE::StaticExplicitSolver< GetValueType_t< Vector >, std::size_t > | |
static void | configSetup (Config::ConfigDescription &config, const std::string &prefix="") |
This method defines configuration entries for setup of the iterative solver. | |
Static Public Member Functions inherited from TNL::Solvers::StaticIterativeSolver< GetValueType_t< Vector >, std::size_t > | |
static void | configSetup (Config::ConfigDescription &config, const std::string &prefix="") |
This method defines configuration entries for setup of the iterative solver. | |
Static Public Attributes | |
static constexpr int | Stages = Method::getStages() |
Protected Attributes | |
RealType | adaptivity = 0.00001 |
std::array< VectorType, Stages > | k_vectors |
VectorType | kAux |
Method | method |
Protected Attributes inherited from TNL::Solvers::ODE::StaticExplicitSolver< GetValueType_t< Vector >, std::size_t > | |
RealType | maxTau |
bool | stopOnSteadyState |
RealType | stopTime |
RealType | tau |
bool | testingMode |
RealType | time |
Protected Attributes inherited from TNL::Solvers::StaticIterativeSolver< GetValueType_t< Vector >, std::size_t > | |
GetValueType_t< Vector > | convergenceResidue |
std::size_t | currentIteration |
GetValueType_t< Vector > | currentResidue |
GetValueType_t< Vector > | divergenceResidue |
std::size_t | maxIterations |
std::size_t | minIterations |
std::size_t | refreshRate |
using TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::SolverMonitorType = SolverMonitor |
Type of object used for monitoring the convergence.
|
static |
Static method for setup of configuration parameters.
config | is the config description. |
prefix | is the prefix of the configuration parameters for this solver. |
|
inline |
Getter of the parameter controlling the adaptive choice of the integration time step.
__cuda_callable__ Method & TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::getMethod | ( | ) |
Gives reference to the underlying method.
__cuda_callable__ const Method & TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::getMethod | ( | ) | const |
Gives constant reference to the underlying method.
void __cuda_callable__ TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::init | ( | const VectorType & | u | ) |
void __cuda_callable__ TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::iterate | ( | VectorType & | u, |
RealType & | time, | ||
RealType & | tau, | ||
RHSFunction && | f, | ||
Params &&... | params ) |
Performs one iteration of the solver.
This method can be used for hybrid solvers which combine various ODE solvers. Otherwise, use of solve is recommended. Before the first call of this method, the method init has to be called.
RHSFunction | is type of a lambda function representing the right-hand side of the ODE system. |
Params | are the parameters which are supposed to be passed to the lambda function f. |
u | is a variable/static vector representing the solution of the ODE system at current time. |
time | is the current time of the evolution. The variable is increased by tau. |
tau | is the current time step. It can be changed by the solver if the adaptive time step control is used. |
f | is the lambda function representing the right-hand side of the ODE system. The definition of the lambda function is the same as in the method solve. |
params | are the parameters which are supposed to be passed to the lambda function f. |
|
inline |
Setter of the parameter controlling the adaptive choice of the integration time step.
The smaller the parameter is the smaller the integration time step tends to be. Reasonable values for this parameters are approximately from interval \( [10^{-12},10^{-2}] \).
adaptivity | new value of the parameter controlling the adaptive choice of integration time step. |
bool TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::setup | ( | const Config::ParameterContainer & | parameters, |
const String & | prefix = "" ) |
Method for setup of the explicit solver based on configuration parameters.
parameters | is the container for configuration parameters. |
prefix | is the prefix of the configuration parameters for this solver. |
__cuda_callable__ bool TNL::Solvers::ODE::ODESolver< Method, Vector, SolverMonitor, true >::solve | ( | VectorType & | u, |
RHSFunction && | f, | ||
Params &&... | params ) |
Solve ODE given by a lambda function.
RHSFunction | is type of a lambda function representing the right-hand side of the ODE system. The definition of the lambda function reads as: where t is the current time of the evolution, tau is the current time step, u is the solution at the current time, fu is variable/static vector into which the lambda function is suppsed to evaluate the function \( f(t, \vec x) \) at the current time \( t \). |
u | is a variable/static vector representing the solution of the ODE system at current time. |
f | is the lambda function representing the right-hand side of the ODE system. |
params | are the parameters which are supposed to be passed to the lambda function f. This is due to the fact that the CUDA compiler does not allow nested lambda functions: "An extended __host__ __device__ lambda cannot be defined inside an extended __host__ __device__ lambda expression". |
true
if steady state solution has been reached, false` otherwise..