ug4
ug::SchurPrecond< TAlgebra > Class Template Reference

operator implementation of the DD Schur complement solver More...

#include <schur_precond.h>

+ Inheritance diagram for ug::SchurPrecond< TAlgebra >:

Public Types

typedef TAlgebra algebra_type
 
typedef IPreconditioner< TAlgebra > base_type
 Base type. More...
 
typedef TAlgebra::matrix_type matrix_type
 
typedef TAlgebra::vector_type vector_type
 
- Public Types inherited from ug::IPreconditioner< TAlgebra >
typedef TAlgebra algebra_type
 Algebra type. More...
 
typedef MatrixOperator< matrix_type, vector_typematrix_operator_type
 Matrix Operator type. More...
 
typedef TAlgebra::matrix_type matrix_type
 Matrix type. More...
 
typedef TAlgebra::vector_type vector_type
 Vector type. More...
 
- Public Types inherited from ug::ILinearIterator< TAlgebra::vector_type >
typedef TAlgebra::vector_type codomain_function_type
 Range space. More...
 
typedef TAlgebra::vector_type domain_function_type
 Domain space. More...
 
- Public Types inherited from ug::DebugWritingObject< TAlgebra >
typedef TAlgebra algebra_type
 type of algebra More...
 
typedef TAlgebra::matrix_type matrix_type
 type of matrix More...
 
typedef TAlgebra::vector_type vector_type
 type of vector More...
 
- Public Types inherited from ug::VectorDebugWritingObject< TAlgebra::vector_type >
typedef TAlgebra::vector_type vector_type
 type of vector More...
 

Public Member Functions

virtual SmartPtr< ILinearIterator< vector_type > > clone ()
 clone More...
 
virtual std::string config_string () const
 
size_t num_global_skeleton ()
 
size_t num_local_skeleton ()
 
 SchurPrecond ()
 constructor More...
 
 SchurPrecond (const SchurPrecond< TAlgebra > &parent)
 
void set_debug (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter)
 set debug writer More...
 
void set_dirichlet_solver (SmartPtr< ILinearOperatorInverse< vector_type > > dirichletSolver)
 sets the Dirichlet solver (forward to Schur complement) More...
 
void set_schur_complement_operator (SmartPtr< SchurComplementOperator< algebra_type > > scop)
 
void set_skeleton_solver (SmartPtr< ISchurComplementInverse< algebra_type > > skeletonSolver)
 sets the coarse problem solver More...
 
- Public Member Functions inherited from ug::IPreconditioner< TAlgebra >
virtual bool apply (vector_type &c, const vector_type &d)
 compute new correction c = B*d More...
 
virtual bool apply_update_defect (vector_type &c, vector_type &d)
 compute new correction c = B*d and update defect d:= d - L*c More...
 
SmartPtr< MatrixOperator< matrix_type, vector_type > > approx_operator ()
 underlying matrix based operator used for the preconditioner More...
 
SmartPtr< MatrixOperator< matrix_type, vector_type > > defect_operator ()
 underlying matrix based operator for calculation of defect More...
 
virtual bool init (SmartPtr< ILinearOperator< vector_type > > J, const vector_type &u)
 implements the ILinearIterator-interface for matrix based preconditioner More...
 
bool init (SmartPtr< ILinearOperator< vector_type > > L)
 implements the ILinearIterator-interface for matrix based preconditioner More...
 
bool init (SmartPtr< MatrixOperator< matrix_type, vector_type > > Op)
 initializes the preconditioner for a matrix based operator More...
 
 IPreconditioner ()
 default constructor More...
 
 IPreconditioner (const IPreconditioner< TAlgebra > &parent)
 clone constructor More...
 
 IPreconditioner (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter)
 constructor setting debug writer More...
 
virtual void set_approximation (SmartPtr< MatrixOperator< matrix_type, vector_type > > approx)
 
virtual ~IPreconditioner ()
 virtual destructor More...
 
- Public Member Functions inherited from ug::ILinearIterator< TAlgebra::vector_type >
SmartPtr< IDamping< TAlgebra::vector_type, TAlgebra::vector_type > > damping ()
 returns the scaling More...
 
 ILinearIterator ()
 constructor More...
 
 ILinearIterator (const ILinearIterator< TAlgebra::vector_type, TAlgebra::vector_type > &parent)
 copy constructor More...
 
virtual bool init (SmartPtr< ILinearOperator< TAlgebra::vector_type, TAlgebra::vector_type > > J, const TAlgebra::vector_type &u)=0
 initialize for operator J(u) and linearization point u More...
 
virtual bool init (SmartPtr< ILinearOperator< TAlgebra::vector_type, TAlgebra::vector_type > > L)=0
 initialize for linear operator L More...
 
void set_damp (number factor)
 sets the damping to a constant factor More...
 
void set_damp (SmartPtr< IDamping< TAlgebra::vector_type, TAlgebra::vector_type > > spScaling)
 sets a scaling for the correction More...
 
virtual ~ILinearIterator ()
 virtual destructor More...
 
- Public Member Functions inherited from ug::DebugWritingObject< TAlgebra >
SmartPtr< IDebugWriter< algebra_type > > debug_writer ()
 returns the debug writer More...
 
ConstSmartPtr< IDebugWriter< algebra_type > > debug_writer () const
 
bool debug_writer_valid () const
 returns true if the debug writer is set More...
 
 DebugWritingObject ()
 
 DebugWritingObject (const DebugWritingObject< algebra_type > &parent)
 clone constructor More...
 
 DebugWritingObject (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter)
 
virtual ~DebugWritingObject ()
 virtual destructor More...
 
- Public Member Functions inherited from ug::VectorDebugWritingObject< TAlgebra::vector_type >
virtual void set_debug (SmartPtr< IVectorDebugWriter< vector_type > > spDebugWriter)
 set debug writer More...
 
SmartPtr< IVectorDebugWriter< vector_type > > vector_debug_writer ()
 returns the debug writer More...
 
ConstSmartPtr< IVectorDebugWriter< vector_type > > vector_debug_writer () const
 
bool vector_debug_writer_valid () const
 returns true if the debug writer is set More...
 
 VectorDebugWritingObject ()
 
 VectorDebugWritingObject (SmartPtr< IVectorDebugWriter< vector_type > > spDebugWriter)
 
void write_debug (const vector_type &vec, const char *filename)
 writing debug output for a vector (if debug writer set) More...
 
virtual ~VectorDebugWritingObject ()
 virtual destructor More...
 

Protected Member Functions

virtual const char * name () const
 name of solver More...
 
virtual bool postprocess ()
 cleans the operator More...
 
virtual bool preprocess (SmartPtr< MatrixOperator< matrix_type, vector_type > > pOp)
 initializes the preconditioner More...
 
virtual bool step (SmartPtr< MatrixOperator< matrix_type, vector_type > > pOp, vector_type &c, const vector_type &d)
 computes a new correction c = B*d More...
 
virtual bool supports_parallel () const
 returns if parallel solving is supported More...
 
- Protected Member Functions inherited from ug::DebugWritingObject< TAlgebra >
void enter_debug_writer_section (const char *secDir)
 enters a debugging section More...
 
void enter_debug_writer_section (std::string secDir)
 enters a debugging section More...
 
void leave_debug_writer_section ()
 leaves a debugging section More...
 
void write_debug (const matrix_type &mat, const char *filename)
 write debug output for a matrix (if debug writer set) More...
 
void write_debug (const matrix_type &mat, std::string name)
 write debug output for a matrix (if debug writer set) More...
 
- Protected Member Functions inherited from ug::VectorDebugWritingObject< TAlgebra::vector_type >
void enter_vector_debug_writer_section (const char *secDir)
 enters a debugging section More...
 
void enter_vector_debug_writer_section (std::string secDir)
 enters a debugging section More...
 
void leave_vector_debug_writer_section ()
 leaves a debugging section More...
 
void print_debugger_message (const char *msg)
 prints a debugger message (listing all the sections) More...
 
void print_debugger_message (std::string msg)
 prints a debugger message (listing all the sections) More...
 
virtual void write_debug (const vector_type &vec, std::string name)
 writing debug output for a vector (if debug writer set) More...
 

Protected Attributes

SmartPtr< vector_typem_aux_rhs [2]
 
SmartPtr< vector_typem_aux_sol [2]
 
size_t m_myMasterSkeleton
 
size_t m_myTotalSkeleton
 
SmartPtr< MatrixOperator< matrix_type, vector_type > > m_pA
 
SmartPtr< ILinearOperatorInverse< vector_type > > m_spDirichletSolver
 Solver Dirichlet problems \(A_{II}\) (also used in Schur complement) More...
 
SmartPtr< SchurComplementOperator< algebra_type > > m_spSchurComplementOp
 Local Schur complement for each subdomain. More...
 
SmartPtr< ISchurComplementInverse< TAlgebra > > m_spSkeletonSolver
 Solver for coarse (skeleton) problem. More...
 
- Protected Attributes inherited from ug::IPreconditioner< TAlgebra >
bool m_bInit
 init flag indicating if init has been called More...
 
bool m_bOtherApproxOperator
 
SmartPtr< MatrixOperator< matrix_type, vector_type > > m_spApproxOperator
 underlying matrix based operator used for the preconditioner More...
 
SmartPtr< ILinearOperator< vector_type > > m_spDefectOperator
 underlying matrix based operator for calculation of defect More...
 
- Protected Attributes inherited from ug::ILinearIterator< TAlgebra::vector_type >
SmartPtr< IDamping< TAlgebra::vector_type, TAlgebra::vector_type > > m_spDamping
 the scaling More...
 
- Protected Attributes inherited from ug::DebugWritingObject< TAlgebra >
SmartPtr< IDebugWriter< algebra_type > > m_spDebugWriter
 Debug Writer. More...
 
- Protected Attributes inherited from ug::VectorDebugWritingObject< TAlgebra::vector_type >
SmartPtr< IVectorDebugWriter< vector_type > > m_spVectorDebugWriter
 Debug Writer. More...
 

Private Member Functions

bool check_requirements ()
 
bool create_and_init_local_schur_complement (SmartPtr< MatrixOperator< matrix_type, vector_type > > A, std::vector< schur_slice_desc_type > &skeletonMark)
 
void create_aux_vectors (const vector_type &d)
 
void get_skeleton_slicing (SmartPtr< MatrixOperator< matrix_type, vector_type > > A, std::vector< schur_slice_desc_type > &skeletonMark)
 
void init_skeleton_solver ()
 
void schur_solve_skeleton (vector_type &u_skeleton, const vector_type &f_skeleton)
 
void schur_solver_backward (vector_type &u_inner, vector_type &f_inner, vector_type &u_skeleton)
 
void schur_solver_forward (vector_type &u_inner, vector_type &f_inner)
 

Detailed Description

template<typename TAlgebra>
class ug::SchurPrecond< TAlgebra >

operator implementation of the DD Schur complement solver

This operator implements a Schur complement solver

Member Typedef Documentation

◆ algebra_type

template<typename TAlgebra >
typedef TAlgebra ug::SchurPrecond< TAlgebra >::algebra_type

◆ base_type

template<typename TAlgebra >
typedef IPreconditioner<TAlgebra> ug::SchurPrecond< TAlgebra >::base_type

Base type.

◆ matrix_type

template<typename TAlgebra >
typedef TAlgebra::matrix_type ug::SchurPrecond< TAlgebra >::matrix_type

◆ vector_type

template<typename TAlgebra >
typedef TAlgebra::vector_type ug::SchurPrecond< TAlgebra >::vector_type

Constructor & Destructor Documentation

◆ SchurPrecond() [1/2]

template<typename TAlgebra >
ug::SchurPrecond< TAlgebra >::SchurPrecond

◆ SchurPrecond() [2/2]

Member Function Documentation

◆ check_requirements()

template<typename TAlgebra >
bool ug::SchurPrecond< TAlgebra >::check_requirements
private

References UG_LOG.

◆ clone()

template<typename TAlgebra >
virtual SmartPtr<ILinearIterator<vector_type> > ug::SchurPrecond< TAlgebra >::clone ( )
inlinevirtual

◆ config_string()

template<typename TAlgebra >
virtual std::string ug::SchurPrecond< TAlgebra >::config_string ( ) const
inlinevirtual

◆ create_and_init_local_schur_complement()

template<typename TAlgebra >
bool ug::SchurPrecond< TAlgebra >::create_and_init_local_schur_complement ( SmartPtr< MatrixOperator< matrix_type, vector_type > >  A,
std::vector< schur_slice_desc_type > &  skeletonMark 
)
private

◆ create_aux_vectors()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::create_aux_vectors ( const vector_type d)
private

◆ get_skeleton_slicing()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::get_skeleton_slicing ( SmartPtr< MatrixOperator< matrix_type, vector_type > >  A,
std::vector< schur_slice_desc_type > &  skeletonMark 
)
private

◆ init_skeleton_solver()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::init_skeleton_solver
private

◆ name()

template<typename TAlgebra >
virtual const char* ug::SchurPrecond< TAlgebra >::name ( ) const
inlineprotectedvirtual

◆ num_global_skeleton()

template<typename TAlgebra >
size_t ug::SchurPrecond< TAlgebra >::num_global_skeleton ( )
inline

returns the size of the skeleton problem note that this is the global size, i.e. without counting slaves

References ug::SchurPrecond< TAlgebra >::m_myMasterSkeleton, ug::SchurPrecond< TAlgebra >::m_pA, and PCL_RO_SUM.

◆ num_local_skeleton()

template<typename TAlgebra >
size_t ug::SchurPrecond< TAlgebra >::num_local_skeleton ( )
inline

returns the local skeleton size. note that the sum over these is bigger than num_global_skeleton, since this function includes also slaves

References ug::SchurPrecond< TAlgebra >::m_myTotalSkeleton.

◆ postprocess()

template<typename TAlgebra >
bool ug::SchurPrecond< TAlgebra >::postprocess ( )
protectedvirtual

cleans the operator

Implements ug::IPreconditioner< TAlgebra >.

References SPNULL.

◆ preprocess()

template<typename TAlgebra >
bool ug::SchurPrecond< TAlgebra >::preprocess ( SmartPtr< MatrixOperator< matrix_type, vector_type > >  pOp)
protectedvirtual

initializes the preconditioner

This method is used to initialize the preconditioner. Usually, here are performed computationally expensive operations, that should only be computed once for an underlying matrix (e.g. LU factorization), while the preconditioner will by applied (using 'step'-method) several times.

Parameters
[in]matunderlying matrix (i.e. L in L*u = f)
Returns
bool success flag

Implements ug::IPreconditioner< TAlgebra >.

References ug::SchurDebug, UG_CATCH_THROW, and UG_DLOG.

◆ schur_solve_skeleton()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::schur_solve_skeleton ( vector_type u_skeleton,
const vector_type f_skeleton 
)
private

◆ schur_solver_backward()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::schur_solver_backward ( vector_type u_inner,
vector_type f_inner,
vector_type u_skeleton 
)
private

◆ schur_solver_forward()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::schur_solver_forward ( vector_type u_inner,
vector_type f_inner 
)
private

f_skeleton *= -1.0;

References SCHUR_PROFILE_BEGIN, ug::SchurDebug, and UG_DLOG.

◆ set_debug()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::set_debug ( SmartPtr< IDebugWriter< algebra_type > >  spDebugWriter)
inlinevirtual

◆ set_dirichlet_solver()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::set_dirichlet_solver ( SmartPtr< ILinearOperatorInverse< vector_type > >  dirichletSolver)
inline

sets the Dirichlet solver (forward to Schur complement)

References ug::SchurPrecond< TAlgebra >::m_spDirichletSolver.

◆ set_schur_complement_operator()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::set_schur_complement_operator ( SmartPtr< SchurComplementOperator< algebra_type > >  scop)
inline

◆ set_skeleton_solver()

template<typename TAlgebra >
void ug::SchurPrecond< TAlgebra >::set_skeleton_solver ( SmartPtr< ISchurComplementInverse< algebra_type > >  skeletonSolver)
inline

sets the coarse problem solver

References ug::SchurPrecond< TAlgebra >::m_spSkeletonSolver.

◆ step()

template<typename TAlgebra >
bool ug::SchurPrecond< TAlgebra >::step ( SmartPtr< MatrixOperator< matrix_type, vector_type > >  pOp,
vector_type c,
const vector_type d 
)
protectedvirtual

computes a new correction c = B*d

This method computes a new correction c = B*d. It can only be called, when the preprocess has been done.

Parameters
[in]matunderlying matrix (i.e. L in L*u = f)
[out]ccorrection
[in]ddefect
Returns
bool success flag

Implements ug::IPreconditioner< TAlgebra >.

References ug::SlicingData< TVec, N >::get_vector_slice(), PROFILE_BEGIN, ug::PST_ADDITIVE, ug::PST_CONSISTENT, ug::PST_UNIQUE, ug::SchurDebug, ug::SD_INNER, ug::SD_SKELETON, ug::SlicingData< TVec, N >::set_vector_slice(), ug::SlicingData< TVec, N >::subtract_vector_slice(), UG_ASSERT, UG_CATCH_THROW, UG_DLOG, and UG_LOG.

◆ supports_parallel()

template<typename TAlgebra >
virtual bool ug::SchurPrecond< TAlgebra >::supports_parallel ( ) const
inlineprotectedvirtual

Member Data Documentation

◆ m_aux_rhs

template<typename TAlgebra >
SmartPtr<vector_type> ug::SchurPrecond< TAlgebra >::m_aux_rhs[2]
protected

◆ m_aux_sol

template<typename TAlgebra >
SmartPtr<vector_type> ug::SchurPrecond< TAlgebra >::m_aux_sol[2]
protected

◆ m_myMasterSkeleton

template<typename TAlgebra >
size_t ug::SchurPrecond< TAlgebra >::m_myMasterSkeleton
protected

◆ m_myTotalSkeleton

template<typename TAlgebra >
size_t ug::SchurPrecond< TAlgebra >::m_myTotalSkeleton
protected

◆ m_pA

template<typename TAlgebra >
SmartPtr<MatrixOperator<matrix_type, vector_type> > ug::SchurPrecond< TAlgebra >::m_pA
protected

◆ m_spDirichletSolver

template<typename TAlgebra >
SmartPtr<ILinearOperatorInverse<vector_type> > ug::SchurPrecond< TAlgebra >::m_spDirichletSolver
protected

◆ m_spSchurComplementOp

template<typename TAlgebra >
SmartPtr<SchurComplementOperator<algebra_type> > ug::SchurPrecond< TAlgebra >::m_spSchurComplementOp
protected

◆ m_spSkeletonSolver


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