ug4
|
Sequential subspace correction preconditioner. More...
#include <sequential_subspace_correction.h>
Public Types | |
typedef TAlgebra | algebra_type |
Algebra type. More... | |
typedef IPreconditioner< TAlgebra > | base_type |
Base type. More... | |
typedef GridFunction< TDomain, TAlgebra >::element_type | Element |
typedef IPreconditioner< TAlgebra >::matrix_operator_type | matrix_operator_type |
Matrix Operator type. More... | |
typedef TAlgebra::matrix_type | matrix_type |
Matrix type. More... | |
typedef ILocalSubspace< TDomain, TAlgebra, Vertex > | TVertexSubspace |
Subspace for vertices. More... | |
typedef TAlgebra::vector_type | vector_type |
Vector type. More... | |
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... | |
SequentialSubspaceCorrection () | |
default constructor More... | |
SequentialSubspaceCorrection (number relax) | |
constructor setting relaxation More... | |
void | set_relax (number omega) |
set relaxation parameter More... | |
void | set_type (const std::string &type) |
set type More... | |
void | set_vertex_subspace (SmartPtr< TVertexSubspace > spVertexSubspace) |
set subspace More... | |
virtual bool | supports_parallel () const |
returns if parallel solving is supported More... | |
virtual | ~SequentialSubspaceCorrection () |
Destructor. 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 > | |
virtual std::string | config_string () const |
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 void | set_debug (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter) |
set debug writer More... | |
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 Types | |
typedef GridFunction< TDomain, TAlgebra > | grid_function_type |
Protected Member Functions | |
virtual const char * | name () const |
Name of preconditioner. More... | |
virtual bool | postprocess () |
Postprocess routine. More... | |
virtual bool | preprocess (SmartPtr< MatrixOperator< matrix_type, vector_type > > pOp) |
Preprocess routine. 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... | |
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... | |
Sequential subspace correction preconditioner.
typedef TAlgebra ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::algebra_type |
Algebra type.
typedef IPreconditioner<TAlgebra> ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::base_type |
Base type.
typedef GridFunction<TDomain, TAlgebra>::element_type ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::Element |
|
protected |
typedef IPreconditioner<TAlgebra>::matrix_operator_type ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::matrix_operator_type |
Matrix Operator type.
typedef TAlgebra::matrix_type ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::matrix_type |
Matrix type.
typedef ILocalSubspace<TDomain, TAlgebra, Vertex> ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::TVertexSubspace |
Subspace for vertices.
typedef TAlgebra::vector_type ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::vector_type |
Vector type.
|
inline |
default constructor
|
inline |
constructor setting relaxation
|
inlinevirtual |
Destructor.
|
inlinevirtual |
Clone.
Implements ug::ILinearIterator< TAlgebra::vector_type >.
References ug::ILinearIterator< TAlgebra::vector_type >::damping(), ug::DebugWritingObject< TAlgebra >::debug_writer(), ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_relax, ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_spVertexSubspace, and ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_type.
|
inlineprotectedvirtual |
Name of preconditioner.
Implements ug::IPreconditioner< TAlgebra >.
|
inlineprotectedvirtual |
Postprocess routine.
Implements ug::IPreconditioner< TAlgebra >.
|
inlineprotectedvirtual |
Preprocess routine.
Implements ug::IPreconditioner< TAlgebra >.
References ug::CreateOverlap(), ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_A, ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_oC, ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_oD, pcl::NumProcs(), PROFILE_BEGIN_GROUP, THROW_IF_NOT_EQUAL, and UG_ASSERT.
|
inline |
set relaxation parameter
References ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_relax, and omega.
|
inline |
set type
References ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_type.
|
inline |
set subspace
References ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_spVertexSubspace.
|
inlineprotectedvirtual |
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::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_relax, ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_spVertexSubspace, ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::m_type, pcl::NumProcs(), PROFILE_BEGIN_GROUP, ug::PST_CONSISTENT, UG_ASSERT, UG_COND_THROW, and UG_THROW.
|
inlinevirtual |
returns if parallel solving is supported
Implements ug::ILinearIterator< TAlgebra::vector_type >.
|
protected |
matrix with overlap
Referenced by ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::preprocess().
|
protected |
|
protected |
for overlaps only
Referenced by ug::SequentialSubspaceCorrection< TDomain, TAlgebra >::preprocess().
|
protected |
|
protected |
|
protected |