ug4
|
#include <block_gauss_seidel.h>
Public Types | |
typedef TAlgebra | algebra_type |
typedef IBlockJacobiPreconditioner< TAlgebra > | base_type |
Base type. More... | |
typedef matrix_type::const_row_iterator | const_row_iterator |
typedef IPreconditioner< TAlgebra >::matrix_operator_type | matrix_operator_type |
Matrix Operator type. More... | |
typedef TAlgebra::matrix_type | matrix_type |
typedef matrix_type::value_type | smallmat_type |
typedef vector_type::value_type | smallvec_type |
typedef SparseBlockGaussSeidel2< TAlgebra, backward, forward > | this_type |
typedef TAlgebra::vector_type | vector_type |
Public Types inherited from ug::IBlockJacobiPreconditioner< TAlgebra > | |
typedef TAlgebra | algebra_type |
typedef IPreconditioner< TAlgebra >::matrix_operator_type | matrix_operator_type |
Matrix Operator 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... | |
void | set_depth (size_t d) |
SparseBlockGaussSeidel2 () | |
SparseBlockGaussSeidel2 (const this_type &parent) | |
SparseBlockGaussSeidel2 (int depth) | |
Public Member Functions inherited from ug::IBlockJacobiPreconditioner< TAlgebra > | |
IBlockJacobiPreconditioner () | |
IBlockJacobiPreconditioner (const IBlockJacobiPreconditioner &parent) | |
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 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... | |
Public Attributes | |
std::map< size_t, SmartPtr< CPUAlgebra::matrix_type > > | Aloc |
std::vector< std::vector< size_t > > | indices |
size_t | m_depth |
std::map< size_t, SmartPtr< ILUTPreconditioner< CPUAlgebra > > > | m_ilut |
Protected Types | |
typedef matrix_type::value_type | block_type |
typedef matrix_type::const_row_iterator | matrix_const_row_iterator |
typedef matrix_type::row_iterator | matrix_row_iterator |
Protected Member Functions | |
virtual bool | block_preprocess (matrix_type &A) |
virtual bool | block_step (matrix_type &A, vector_type &c, const vector_type &d) |
virtual std::string | config_string () const |
virtual const char * | name () const |
returns the name of iterator More... | |
virtual bool | postprocess () |
cleans the operator More... | |
virtual bool | supports_parallel () const |
returns if parallel solving is supported More... | |
Protected Member Functions inherited from ug::IBlockJacobiPreconditioner< TAlgebra > | |
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... | |
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... | |
SparseBlockGaussSeidel experimental version a) can use bigger stencils since it uses SparseLU for solving blocks b) tries to use some overlapping blocks (BlockGaussSeidel always uses N blocks)
typedef TAlgebra ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::algebra_type |
typedef IBlockJacobiPreconditioner<TAlgebra> ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::base_type |
Base type.
|
protected |
typedef matrix_type::const_row_iterator ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::const_row_iterator |
|
protected |
typedef IPreconditioner<TAlgebra>::matrix_operator_type ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::matrix_operator_type |
Matrix Operator type.
|
protected |
typedef TAlgebra::matrix_type ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::matrix_type |
typedef matrix_type::value_type ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::smallmat_type |
typedef vector_type::value_type ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::smallvec_type |
typedef SparseBlockGaussSeidel2<TAlgebra, backward, forward> ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::this_type |
typedef TAlgebra::vector_type ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::vector_type |
|
inline |
|
inline |
|
inline |
|
inlineprotectedvirtual |
Implements ug::IBlockJacobiPreconditioner< TAlgebra >.
References ug::IBlockJacobiPreconditioner< TAlgebra >::A, ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::Aloc, ug::cgraph::begin_row(), ug::CreateStrongConnectionGraphForSystems(), ug::cgraph::end_row(), ug::GetSliceSparse(), ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::indices, ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::m_ilut, make_sp(), num_rows(), PRINT_VECTOR, PROGRESS_FINISH, PROGRESS_START, ug::cgraph::resize(), ug::cgraph::set_connection(), ug::cgraph::size(), UG_COND_THROW, and UG_LOG.
|
inlineprotectedvirtual |
Implements ug::IBlockJacobiPreconditioner< TAlgebra >.
References ug::IBlockJacobiPreconditioner< TAlgebra >::A, ug::GetBlockGSCorrectionILUT(), ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::indices, ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::m_ilut, PROGRESS_FINISH, PROGRESS_START, PROGRESS_UPDATE, and ug::PST_CONSISTENT.
|
inlinevirtual |
|
inlineprotectedvirtual |
Reimplemented from ug::ILinearIterator< TAlgebra::vector_type >.
References ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::m_depth.
|
inlineprotectedvirtual |
returns the name of iterator
This method returns the name of the iterator operator. This function is typically needed, when the iterator operator is used inside of another operator and some debug output should be printed
Implements ug::IPreconditioner< TAlgebra >.
|
inlineprotectedvirtual |
cleans the operator
Reimplemented from ug::IBlockJacobiPreconditioner< TAlgebra >.
|
inline |
|
inlineprotectedvirtual |
returns if parallel solving is supported
Reimplemented from ug::IBlockJacobiPreconditioner< TAlgebra >.
std::map<size_t, SmartPtr<CPUAlgebra::matrix_type> > ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::Aloc |
std::vector<std::vector<size_t> > ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::indices |
size_t ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::m_depth |
std::map<size_t, SmartPtr<ILUTPreconditioner<CPUAlgebra> > > ug::SparseBlockGaussSeidel2< TAlgebra, backward, forward >::m_ilut |