ug4
|
#include <block_gauss_seidel.h>
Public Types | |
typedef TAlgebra | algebra_type |
typedef IBlockJacobiPreconditioner< TAlgebra > | base_type |
Base type. | |
typedef matrix_type::const_row_iterator | const_row_iterator |
typedef IPreconditioner< TAlgebra >::matrix_operator_type | matrix_operator_type |
Matrix Operator type. | |
typedef TAlgebra::matrix_type | matrix_type |
typedef matrix_type::value_type | smallmat_type |
typedef vector_type::value_type | smallvec_type |
typedef BlockGaussSeidel< algebra_type, backward, forward > | this_type |
typedef TAlgebra::vector_type | vector_type |
![]() | |
typedef TAlgebra | algebra_type |
typedef IPreconditioner< TAlgebra >::matrix_operator_type | matrix_operator_type |
Matrix Operator type. | |
typedef TAlgebra::matrix_type | matrix_type |
typedef TAlgebra::vector_type | vector_type |
![]() | |
typedef TAlgebra | algebra_type |
Algebra type. | |
typedef MatrixOperator< matrix_type, vector_type > | matrix_operator_type |
Matrix Operator type. | |
typedef TAlgebra::matrix_type | matrix_type |
Matrix type. | |
typedef TAlgebra::vector_type | vector_type |
Vector type. | |
![]() | |
typedef TAlgebra::vector_type | codomain_function_type |
Range space. | |
typedef TAlgebra::vector_type | domain_function_type |
Domain space. | |
![]() | |
typedef TAlgebra | algebra_type |
type of algebra | |
typedef TAlgebra::matrix_type | matrix_type |
type of matrix | |
typedef TAlgebra::vector_type | vector_type |
type of vector | |
![]() | |
typedef TAlgebra::vector_type | vector_type |
type of vector | |
Public Member Functions | |
BlockGaussSeidel () | |
BlockGaussSeidel (const this_type &parent) | |
BlockGaussSeidel (int depth) | |
virtual SmartPtr< ILinearIterator< vector_type > > | clone () |
clone | |
void | set_depth (size_t d) |
![]() | |
IBlockJacobiPreconditioner () | |
IBlockJacobiPreconditioner (const IBlockJacobiPreconditioner &parent) | |
![]() | |
virtual bool | apply (vector_type &c, const vector_type &d) |
compute new correction c = B*d | |
virtual bool | apply_update_defect (vector_type &c, vector_type &d) |
compute new correction c = B*d and update defect d:= d - L*c | |
SmartPtr< MatrixOperator< matrix_type, vector_type > > | approx_operator () |
underlying matrix based operator used for the preconditioner | |
SmartPtr< MatrixOperator< matrix_type, vector_type > > | defect_operator () |
underlying matrix based operator for calculation of defect | |
virtual bool | init (SmartPtr< ILinearOperator< vector_type > > J, const vector_type &u) |
implements the ILinearIterator-interface for matrix based preconditioner | |
bool | init (SmartPtr< ILinearOperator< vector_type > > L) |
implements the ILinearIterator-interface for matrix based preconditioner | |
bool | init (SmartPtr< MatrixOperator< matrix_type, vector_type > > Op) |
initializes the preconditioner for a matrix based operator | |
IPreconditioner () | |
default constructor | |
IPreconditioner (const IPreconditioner< TAlgebra > &parent) | |
clone constructor | |
IPreconditioner (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter) | |
constructor setting debug writer | |
virtual void | set_approximation (SmartPtr< MatrixOperator< matrix_type, vector_type > > approx) |
virtual | ~IPreconditioner () |
virtual destructor | |
![]() | |
SmartPtr< IDamping< TAlgebra::vector_type, TAlgebra::vector_type > > | damping () |
returns the scaling | |
ILinearIterator () | |
constructor | |
ILinearIterator (const ILinearIterator< TAlgebra::vector_type, TAlgebra::vector_type > &parent) | |
copy constructor | |
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 | |
virtual bool | init (SmartPtr< ILinearOperator< TAlgebra::vector_type, TAlgebra::vector_type > > L)=0 |
initialize for linear operator L | |
void | set_damp (number factor) |
sets the damping to a constant factor | |
void | set_damp (SmartPtr< IDamping< TAlgebra::vector_type, TAlgebra::vector_type > > spScaling) |
sets a scaling for the correction | |
virtual | ~ILinearIterator () |
virtual destructor | |
![]() | |
SmartPtr< IDebugWriter< algebra_type > > | debug_writer () |
returns the debug writer | |
ConstSmartPtr< IDebugWriter< algebra_type > > | debug_writer () const |
bool | debug_writer_valid () const |
returns true if the debug writer is set | |
DebugWritingObject () | |
DebugWritingObject (const DebugWritingObject< algebra_type > &parent) | |
clone constructor | |
DebugWritingObject (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter) | |
virtual void | set_debug (SmartPtr< IDebugWriter< algebra_type > > spDebugWriter) |
set debug writer | |
virtual | ~DebugWritingObject () |
virtual destructor | |
![]() | |
virtual void | set_debug (SmartPtr< IVectorDebugWriter< vector_type > > spDebugWriter) |
set debug writer | |
SmartPtr< IVectorDebugWriter< vector_type > > | vector_debug_writer () |
returns the debug writer | |
ConstSmartPtr< IVectorDebugWriter< vector_type > > | vector_debug_writer () const |
bool | vector_debug_writer_valid () const |
returns true if the debug writer is set | |
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) | |
virtual | ~VectorDebugWritingObject () |
virtual destructor | |
Public Attributes | |
std::vector< DenseMatrix< VariableArray2< double > > > | AlocInv |
std::vector< std::vector< size_t > > | indices |
size_t | m_depth |
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 | |
virtual bool | postprocess () |
cleans the operator | |
virtual bool | supports_parallel () const |
returns if parallel solving is supported | |
![]() | |
virtual bool | preprocess (SmartPtr< MatrixOperator< matrix_type, vector_type > > pOp) |
initializes the preconditioner | |
virtual bool | step (SmartPtr< MatrixOperator< matrix_type, vector_type > > pOp, vector_type &c, const vector_type &d) |
computes a new correction c = B*d | |
![]() | |
void | enter_debug_writer_section (const char *secDir) |
enters a debugging section | |
void | enter_debug_writer_section (std::string secDir) |
enters a debugging section | |
void | leave_debug_writer_section () |
leaves a debugging section | |
void | write_debug (const matrix_type &mat, const char *filename) |
write debug output for a matrix (if debug writer set) | |
void | write_debug (const matrix_type &mat, std::string name) |
write debug output for a matrix (if debug writer set) | |
![]() | |
void | enter_vector_debug_writer_section (const char *secDir) |
enters a debugging section | |
void | enter_vector_debug_writer_section (std::string secDir) |
enters a debugging section | |
void | leave_vector_debug_writer_section () |
leaves a debugging section | |
void | print_debugger_message (const char *msg) |
prints a debugger message (listing all the sections) | |
void | print_debugger_message (std::string msg) |
prints a debugger message (listing all the sections) | |
virtual void | write_debug (const vector_type &vec, std::string name) |
writing debug output for a vector (if debug writer set) | |
Additional Inherited Members | |
![]() | |
matrix_type | A |
SmartPtr< vector_type > | m_spDtmp |
![]() | |
bool | m_bInit |
init flag indicating if init has been called | |
bool | m_bOtherApproxOperator |
SmartPtr< MatrixOperator< matrix_type, vector_type > > | m_spApproxOperator |
underlying matrix based operator used for the preconditioner | |
SmartPtr< ILinearOperator< vector_type > > | m_spDefectOperator |
underlying matrix based operator for calculation of defect | |
![]() | |
SmartPtr< IDamping< TAlgebra::vector_type, TAlgebra::vector_type > > | m_spDamping |
the scaling | |
![]() | |
SmartPtr< IDebugWriter< algebra_type > > | m_spDebugWriter |
Debug Writer. | |
![]() | |
SmartPtr< IVectorDebugWriter< vector_type > > | m_spVectorDebugWriter |
Debug Writer. | |
BlockGaussSeidel use the constructor or set_depth to set the depth depth = 0 -> GS depth = 1 -> Block i and neighbors of i depth = 2 -> Block i and neighbors of i and their neighbors depth = 3 ...
typedef TAlgebra ug::BlockGaussSeidel< TAlgebra, backward, forward >::algebra_type |
typedef IBlockJacobiPreconditioner<TAlgebra> ug::BlockGaussSeidel< TAlgebra, backward, forward >::base_type |
Base type.
|
protected |
typedef matrix_type::const_row_iterator ug::BlockGaussSeidel< TAlgebra, backward, forward >::const_row_iterator |
|
protected |
typedef IPreconditioner<TAlgebra>::matrix_operator_type ug::BlockGaussSeidel< TAlgebra, backward, forward >::matrix_operator_type |
Matrix Operator type.
|
protected |
typedef TAlgebra::matrix_type ug::BlockGaussSeidel< TAlgebra, backward, forward >::matrix_type |
typedef matrix_type::value_type ug::BlockGaussSeidel< TAlgebra, backward, forward >::smallmat_type |
typedef vector_type::value_type ug::BlockGaussSeidel< TAlgebra, backward, forward >::smallvec_type |
typedef BlockGaussSeidel<algebra_type, backward, forward> ug::BlockGaussSeidel< TAlgebra, backward, forward >::this_type |
typedef TAlgebra::vector_type ug::BlockGaussSeidel< TAlgebra, backward, forward >::vector_type |
|
inline |
|
inline |
|
inline |
|
inlineprotectedvirtual |
Implements ug::IBlockJacobiPreconditioner< TAlgebra >.
References ug::IBlockJacobiPreconditioner< TAlgebra >::A, ug::BlockGaussSeidel< TAlgebra, backward, forward >::AlocInv, ug::GetNeighborhood(), ug::GetSliceDenseInverse(), ug::BlockGaussSeidel< TAlgebra, backward, forward >::indices, ug::BlockGaussSeidel< TAlgebra, backward, forward >::m_depth, num_rows(), PROGRESS_FINISH, PROGRESS_START, PROGRESS_UPDATE, and UG_LOG.
|
inlineprotectedvirtual |
Implements ug::IBlockJacobiPreconditioner< TAlgebra >.
References ug::IBlockJacobiPreconditioner< TAlgebra >::A, ug::BlockGaussSeidel< TAlgebra, backward, forward >::AlocInv, ug::GetBlockGSCorrection(), ug::BlockGaussSeidel< TAlgebra, backward, forward >::indices, PROFILE_BEGIN, and ug::PST_CONSISTENT.
|
inlinevirtual |
|
inlineprotectedvirtual |
Reimplemented from ug::ILinearIterator< TAlgebra::vector_type >.
References ug::BlockGaussSeidel< 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::vector< DenseMatrix<VariableArray2<double> > > ug::BlockGaussSeidel< TAlgebra, backward, forward >::AlocInv |
std::vector<std::vector<size_t> > ug::BlockGaussSeidel< TAlgebra, backward, forward >::indices |
size_t ug::BlockGaussSeidel< TAlgebra, backward, forward >::m_depth |
Referenced by ug::BlockGaussSeidel< TAlgebra, backward, forward >::block_preprocess(), ug::BlockGaussSeidel< TAlgebra, backward, forward >::BlockGaussSeidel(), ug::BlockGaussSeidel< TAlgebra, backward, forward >::BlockGaussSeidel(), ug::BlockGaussSeidel< TAlgebra, backward, forward >::BlockGaussSeidel(), ug::BlockGaussSeidel< TAlgebra, backward, forward >::config_string(), and ug::BlockGaussSeidel< TAlgebra, backward, forward >::set_depth().