15#ifndef dealii_precondition_selector_h
16#define dealii_precondition_selector_h
31template <
class number>
33template <
class number>
99template <
typename MatrixType = SparseMatrix<
double>,
100 typename VectorType = ::Vector<
double>>
114 const typename VectorType::value_type &
omega = 1.);
147 vmult(VectorType &dst,
const VectorType &src)
const;
154 Tvmult(VectorType &dst,
const VectorType &src)
const;
199 const typename VectorType::value_type
omega;
206template <
typename MatrixType,
typename VectorType>
209 const typename VectorType::value_type &
omega)
215template <
typename MatrixType,
typename VectorType>
223template <
typename MatrixType,
typename VectorType>
231template <
typename MatrixType,
typename VectorType>
240template <
typename MatrixType,
typename VectorType>
250template <
typename MatrixType,
typename VectorType>
253 const VectorType &src)
const
265 A->precondition_Jacobi(dst, src,
omega);
269 A->precondition_SOR(dst, src,
omega);
273 A->precondition_SSOR(dst, src,
omega);
281template <
typename MatrixType,
typename VectorType>
285 const VectorType &src)
const
297 A->precondition_Jacobi(dst, src,
omega);
301 A->precondition_TSOR(dst, src,
omega);
305 A->precondition_SSOR(dst, src,
omega);
313template <
typename MatrixType,
typename VectorType>
317 return "none|jacobi|sor|ssor";
friend class ObserverPointer
virtual void vmult(VectorType &dst, const VectorType &src) const
virtual void Tvmult(VectorType &dst, const VectorType &src) const
typename MatrixType::size_type size_type
const VectorType::value_type omega
static std::string get_precondition_names()
void use_matrix(const MatrixType &M)
std::string preconditioning
virtual ~PreconditionSelector() override
PreconditionSelector(const std::string &preconditioning, const typename VectorType::value_type &omega=1.)
ObserverPointer< const MatrixType, PreconditionSelector< MatrixType, VectorType > > A
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_NOT_IMPLEMENTED()
static ::ExceptionBase & ExcNoMatrixGivenToUse()
#define DeclException0(Exception0)
#define Assert(cond, exc)