16 #ifndef dealii_sparse_mic_h 17 #define dealii_sparse_mic_h 48 template <
typename number>
98 template <
typename somenumber>
109 template <
typename somenumber>
111 vmult(Vector<somenumber> &dst,
const Vector<somenumber> &src)
const;
122 template <
typename somenumber>
124 Tvmult(Vector<somenumber> &dst,
const Vector<somenumber> &src)
const;
147 <<
"The strengthening parameter " << arg1
148 <<
" is not greater or equal than zero!");
155 <<
"The diagonal element (" << arg1 <<
"," << arg1 <<
") is " 156 << arg2 <<
", but must be positive");
#define DeclException2(Exception2, type1, type2, outsequence)
std::vector< number > inner_sums
Contents is actually a matrix.
void vmult(Vector< somenumber > &dst, const Vector< somenumber > &src) const
static ::ExceptionBase & ExcDecompositionNotStable(int arg1, double arg2)
void Tvmult(Vector< somenumber > &dst, const Vector< somenumber > &src) const
void initialize(const SparseMatrix< somenumber > &matrix, const AdditionalData ¶meters=AdditionalData())
std::vector< number > diag
number get_rowsum(const size_type row) const
#define DeclException1(Exception1, type1, outsequence)
virtual ~SparseMIC() override
typename SparseMatrix< number >::size_type size_type
#define DeclException0(Exception0)
#define DEAL_II_NAMESPACE_CLOSE
std::vector< number > inv_diag
unsigned int global_dof_index
std::size_t memory_consumption() const override
#define DEAL_II_NAMESPACE_OPEN
virtual void clear() override
static ::ExceptionBase & ExcInvalidStrengthening(double arg1)
typename SparseLUDecomposition< number >::AdditionalData AdditionalData
static ::ExceptionBase & ExcStrengthenDiagonalTooSmall()