DiFfRG
Loading...
Searching...
No Matches
DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver > Class Template Reference

#include <trbdf2.hh>

Inheritance diagram for DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >:
DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >

Public Types

using NumberType = typename Base::NumberType
 
using InverseSparseMatrixType = typename Base::InverseSparseMatrixType
 
using BlockVectorType = typename Base::BlockVectorType
 

Public Member Functions

virtual void run (AbstractFlowingVariables< NumberType > *initial_condition, const double t_start, const double t_stop) override
 Any derived class must implement this method to run the timestepping algorithm.
 
uint get_jacobians ()
 
double get_error ()
 
void set_ignore_nonconv (bool x)
 
- Public Member Functions inherited from DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >
 AbstractTimestepper (const JSONValue &json, AbstractAssembler< VectorType, SparseMatrixType, dim > *assembler, DataOutput< dim, VectorType > *data_out=nullptr, AbstractAdaptor< VectorType > *adaptor=nullptr)
 Construct a new Abstract Timestepper object.
 
DataOutput< dim, VectorType > * get_data_out ()
 Utility function to obtain a DataOutput object. If no DataOutput object is provided, a default one is created.
 
AbstractAdaptor< VectorType > * get_adaptor ()
 Utility function to obtain an Adaptor object. If no Adaptor object is provided, a default one is created, which is the NoAdaptivity object, i.e. no mesh adaptivity is used.
 

Private Types

using Base = AbstractTimestepper<VectorType, SparseMatrixType, dim>
 

Private Attributes

std::shared_ptr< Newton< VectorType > > ptr_newton_TR
 
std::shared_ptr< Newton< VectorType > > ptr_newton_BDF2
 

Additional Inherited Members

- Protected Types inherited from DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >
using VectorType
 
using NumberType
 
using SparseMatrixType
 
using InverseSparseMatrixType
 
using BlockVectorType
 
- Protected Member Functions inherited from DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >
void console_out (const double t, const std::string name, const int verbosity_level, const double calc_dt_ms=-1.0) const
 Pretty-print the status of the timestepping algorithm to the console.
 
- Protected Attributes inherited from DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >
const JSONValue json
 
AbstractAssembler< VectorType, SparseMatrixType, dim > * assembler
 
DataOutput< dim, VectorType > * data_out
 
AbstractAdaptor< VectorType > * adaptor
 
const std::chrono::time_point< std::chrono::high_resolution_clock > start_time
 
std::shared_ptr< NoAdaptivity< VectorType > > adaptor_default
 
std::shared_ptr< DataOutput< dim, VectorType > > data_out_default
 
double Lambda
 
int verbosity
 
double output_dt
 
struct DiFfRG::AbstractTimestepper::implicitParameters impl
 
struct DiFfRG::AbstractTimestepper::explicitParameters expl
 
- Static Protected Attributes inherited from DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >
static constexpr uint dim
 

Member Typedef Documentation

◆ Base

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
using DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::Base = AbstractTimestepper<VectorType, SparseMatrixType, dim>
private

◆ BlockVectorType

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
using DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::BlockVectorType = typename Base::BlockVectorType

◆ InverseSparseMatrixType

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
using DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::InverseSparseMatrixType = typename Base::InverseSparseMatrixType

◆ NumberType

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
using DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::NumberType = typename Base::NumberType

Member Function Documentation

◆ get_error()

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
double DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::get_error ( )

◆ get_jacobians()

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
uint DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::get_jacobians ( )

◆ run()

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
virtual void DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::run ( AbstractFlowingVariables< NumberType > * initial_condition,
const double t_start,
const double t_stop )
overridevirtual

Any derived class must implement this method to run the timestepping algorithm.

Parameters
initial_conditionA pointer to a flowing variables object that contains the initial condition.
t_startThe start time of the simulation.
t_stopThe run method will evolve the system from t_start to t_stop.

Implements DiFfRG::AbstractTimestepper< VectorType, SparseMatrixType, dim >.

◆ set_ignore_nonconv()

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
void DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::set_ignore_nonconv ( bool x)

Member Data Documentation

◆ ptr_newton_BDF2

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
std::shared_ptr<Newton<VectorType> > DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::ptr_newton_BDF2
private

◆ ptr_newton_TR

template<typename VectorType , typename SparseMatrixType , uint dim, template< typename, typename > typename LinearSolver>
std::shared_ptr<Newton<VectorType> > DiFfRG::TimeStepperTRBDF2< VectorType, SparseMatrixType, dim, LinearSolver >::ptr_newton_TR
private

The documentation for this class was generated from the following file: