|
SmartPtr< ILinearIterator< vector_type > > | clone () |
| clone
|
|
| PILUTPreconditioner (double eps=0) |
|
void | set_info (bool info) |
| sets storage information output to true or false
|
|
void | set_show_progress (bool s) |
| set whether the progress meter should be shown
|
|
void | set_threshold (number thresh) |
| sets threshold for incomplete LU factorisation (added 01122010ih)
|
|
virtual | ~PILUTPreconditioner () |
|
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
|
|
virtual std::string | config_string () const |
|
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 bool | supports_parallel () const=0 |
| returns if parallel solving is supported
|
|
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
|
|
|
size_t | eliminate_row (std::vector< typename matrix_type::connection > &con, size_t start, size_t stop, double dmax) |
|
virtual const char * | name () const |
| returns the name of iterator
|
|
virtual bool | postprocess () |
| cleans the operator
|
|
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)
|
|
template<typename TAlgebra >
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] | mat | underlying matrix (i.e. L in L*u = f) |
- Returns
- bool success flag
Implements ug::IPreconditioner< TAlgebra >.
References ug::BlockNorm(), ug::PILUTPreconditioner< TAlgebra >::eliminate_row(), ug::PILUTPreconditioner< TAlgebra >::m_eps, ug::PILUTPreconditioner< TAlgebra >::m_info, ug::PILUTPreconditioner< TAlgebra >::m_L, ug::PILUTPreconditioner< TAlgebra >::m_show_progress, ug::PILUTPreconditioner< TAlgebra >::m_U, PROFILE_BEGIN, PROFILE_END, PROGRESS_FINISH, PROGRESS_START_WITH, PROGRESS_UPDATE, ug::reset_floats(), STATIC_ASSERT, and UG_LOG.