ug4
|
operator implementation of the DD Schur complement solver More...
#include <schur_precond.h>
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_type > | matrix_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... | |
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) |
operator implementation of the DD Schur complement solver
This operator implements a Schur complement solver
typedef TAlgebra ug::SchurPrecond< TAlgebra >::algebra_type |
typedef IPreconditioner<TAlgebra> ug::SchurPrecond< TAlgebra >::base_type |
Base type.
typedef TAlgebra::matrix_type ug::SchurPrecond< TAlgebra >::matrix_type |
typedef TAlgebra::vector_type ug::SchurPrecond< TAlgebra >::vector_type |
ug::SchurPrecond< TAlgebra >::SchurPrecond |
constructor
References ug::SchurPrecond< TAlgebra >::m_aux_rhs, ug::SchurPrecond< TAlgebra >::m_aux_sol, and SPNULL.
|
inline |
|
private |
References UG_LOG.
|
inlinevirtual |
|
inlinevirtual |
|
private |
References make_sp(), SCHUR_PROFILE_BEGIN, ug::SchurDebug, UG_ASSERT, UG_CATCH_THROW, and UG_DLOG.
|
private |
|
private |
References ug::MarkAllFromLayout(), ug::SD_INNER, and ug::SD_SKELETON.
|
private |
References SCHUR_PROFILE_BEGIN, UG_CATCH_THROW, and UG_THROW.
|
inlineprotectedvirtual |
name of solver
Implements ug::IPreconditioner< TAlgebra >.
Referenced by ug::SchurPrecond< TAlgebra >::config_string().
|
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.
|
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.
|
protectedvirtual |
|
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.
[in] | mat | underlying matrix (i.e. L in L*u = f) |
Implements ug::IPreconditioner< TAlgebra >.
References ug::SchurDebug, UG_CATCH_THROW, and UG_DLOG.
|
private |
References ug::PST_ADDITIVE, ug::PST_CONSISTENT, SCHUR_PROFILE_BEGIN, ug::SchurDebug, UG_DLOG, UG_LOG, and UG_THROW.
|
private |
References SCHUR_PROFILE_BEGIN, ug::SchurDebug, ug::SD_INNER, ug::SD_SKELETON, UG_DLOG, and UG_LOG.
|
private |
f_skeleton *= -1.0;
References SCHUR_PROFILE_BEGIN, ug::SchurDebug, and UG_DLOG.
|
inlinevirtual |
set debug writer
Reimplemented from ug::DebugWritingObject< TAlgebra >.
References ug::DebugWritingObject< TAlgebra >::set_debug().
|
inline |
sets the Dirichlet solver (forward to Schur complement)
References ug::SchurPrecond< TAlgebra >::m_spDirichletSolver.
|
inline |
|
inline |
sets the coarse problem solver
References ug::SchurPrecond< TAlgebra >::m_spSkeletonSolver.
|
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.
[in] | mat | underlying matrix (i.e. L in L*u = f) |
[out] | c | correction |
[in] | d | defect |
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.
|
inlineprotectedvirtual |
returns if parallel solving is supported
Implements ug::ILinearIterator< TAlgebra::vector_type >.
References ug::SchurPrecond< TAlgebra >::m_spDirichletSolver, and ug::SchurPrecond< TAlgebra >::m_spSkeletonSolver.
|
protected |
Referenced by ug::SchurPrecond< TAlgebra >::SchurPrecond().
|
protected |
Referenced by ug::SchurPrecond< TAlgebra >::SchurPrecond().
|
protected |
Referenced by ug::SchurPrecond< TAlgebra >::num_global_skeleton().
|
protected |
Referenced by ug::SchurPrecond< TAlgebra >::num_local_skeleton().
|
protected |
Referenced by ug::SchurPrecond< TAlgebra >::num_global_skeleton().
|
protected |
Solver Dirichlet problems \(A_{II}\) (also used in Schur complement)
Referenced by ug::SchurPrecond< TAlgebra >::config_string(), ug::SchurPrecond< TAlgebra >::SchurPrecond(), ug::SchurPrecond< TAlgebra >::set_dirichlet_solver(), and ug::SchurPrecond< TAlgebra >::supports_parallel().
|
protected |
Local Schur complement for each subdomain.
Referenced by ug::SchurPrecond< TAlgebra >::SchurPrecond(), and ug::SchurPrecond< TAlgebra >::set_schur_complement_operator().
|
protected |
Solver for coarse (skeleton) problem.
Referenced by ug::SchurPrecond< TAlgebra >::config_string(), ug::SchurPrecond< TAlgebra >::SchurPrecond(), ug::SchurPrecond< TAlgebra >::set_skeleton_solver(), and ug::SchurPrecond< TAlgebra >::supports_parallel().