16 #ifndef dealii_block_sparse_matrix_h 17 #define dealii_block_sparse_matrix_h 49 template <
typename number>
220 template <
typename block_number>
229 template <
typename block_number,
typename nonblock_number>
232 const Vector<nonblock_number> &src)
const;
238 template <
typename block_number,
typename nonblock_number>
240 vmult(Vector<nonblock_number> & dst,
247 template <
typename nonblock_number>
249 vmult(Vector<nonblock_number> &dst,
const Vector<nonblock_number> &src)
const;
256 template <
typename block_number>
265 template <
typename block_number,
typename nonblock_number>
268 const Vector<nonblock_number> &src)
const;
274 template <
typename block_number,
typename nonblock_number>
276 Tvmult(Vector<nonblock_number> & dst,
283 template <
typename nonblock_number>
285 Tvmult(Vector<nonblock_number> & dst,
286 const Vector<nonblock_number> &src)
const;
300 template <
class BlockVectorType>
303 const BlockVectorType &src,
304 const number omega = 1.)
const;
311 template <
typename number2>
314 const Vector<number2> &src,
315 const number omega = 1.)
const;
344 const unsigned int precision = 3,
345 const bool scientific =
true,
346 const unsigned int width = 0,
347 const char * zero_string =
" ",
348 const double denominator = 1.)
const;
378 template <
typename number>
393 template <
typename number>
394 template <
typename block_number>
404 template <
typename number>
405 template <
typename block_number,
typename nonblock_number>
408 const Vector<nonblock_number> &src)
const 415 template <
typename number>
416 template <
typename block_number,
typename nonblock_number>
426 template <
typename number>
427 template <
typename nonblock_number>
430 const Vector<nonblock_number> &src)
const 437 template <
typename number>
438 template <
typename block_number>
448 template <
typename number>
449 template <
typename block_number,
typename nonblock_number>
452 const Vector<nonblock_number> &src)
const 459 template <
typename number>
460 template <
typename block_number,
typename nonblock_number>
470 template <
typename number>
471 template <
typename nonblock_number>
474 const Vector<nonblock_number> &src)
const 481 template <
typename number>
482 template <
class BlockVectorType>
485 const BlockVectorType &src,
486 const number omega)
const 502 template <
typename number>
503 template <
typename number2>
506 const Vector<number2> &src,
507 const number omega)
const 513 ExcMessage(
"This function only works if the matrix has " 516 ExcMessage(
"This function only works if the matrix has " 527 #endif // dealii_block_sparse_matrix_h SmartPointer< const BlockSparsityPattern, BlockSparseMatrix< number > > sparsity_pattern
void vmult_block_nonblock(BlockVectorType &dst, const VectorType &src) const
types::global_dof_index size_type
const value_type & const_reference
virtual ~BlockSparseMatrix() override
static ::ExceptionBase & ExcScalarAssignmentOnlyForZeroValue()
typename BaseClass::const_pointer const_pointer
void vmult_nonblock_block(VectorType &dst, const BlockVectorType &src) const
MatrixIterator< BlockMatrixIterators::Accessor< BlockMatrixBase, true > > const_iterator
void Tvmult_block_nonblock(BlockVectorType &dst, const VectorType &src) const
void Tvmult(BlockVector< block_number > &dst, const BlockVector< block_number > &src) const
BlockSparseMatrix & operator=(const BlockSparseMatrix &)
void Tvmult_block_block(BlockVectorType &dst, const BlockVectorType &src) const
void Tvmult_nonblock_block(VectorType &dst, const BlockVectorType &src) const
const BlockSparsityPattern & get_sparsity_pattern() const
void vmult_block_block(BlockVectorType &dst, const BlockVectorType &src) const
typename BlockType::value_type value_type
void Tvmult_nonblock_nonblock(VectorType &dst, const VectorType &src) const
SparseMatrix< number > BlockType
unsigned int n_block_cols() const
static ::ExceptionBase & ExcMessage(std::string arg1)
typename BaseClass::BlockType BlockType
#define Assert(cond, exc)
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
#define DeclException0(Exception0)
#define DEAL_II_NAMESPACE_CLOSE
const value_type * const_pointer
std::size_t memory_consumption() const
typename BaseClass::size_type size_type
typename BaseClass::iterator iterator
size_type n_actually_nonzero_elements(const double threshold=0.0) const
SymmetricTensor< 2, dim, Number > d(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
typename BaseClass::reference reference
typename BaseClass::pointer pointer
static ::ExceptionBase & ExcNotQuadratic()
MatrixIterator< BlockMatrixIterators::Accessor< BlockMatrixBase, false > > iterator
BlockSparseMatrix()=default
void vmult_nonblock_nonblock(VectorType &dst, const VectorType &src) const
#define DEAL_II_NAMESPACE_OPEN
BlockType & block(const unsigned int row, const unsigned int column)
typename BaseClass::value_type value_type
size_type n_nonzero_elements() const
void precondition_Jacobi(Vector< somenumber > &dst, const Vector< somenumber > &src, const number omega=1.) const
typename BaseClass::const_iterator const_iterator
static ::ExceptionBase & ExcBlockDimensionMismatch()
virtual void reinit(const BlockSparsityPattern &sparsity)
void vmult(BlockVector< block_number > &dst, const BlockVector< block_number > &src) const
size_type get_row_length(const size_type row) const
unsigned int n_block_rows() const
void print_formatted(std::ostream &out, const unsigned int precision=3, const bool scientific=true, const unsigned int width=0, const char *zero_string=" ", const double denominator=1.) const
typename BaseClass::const_reference const_reference
void precondition_Jacobi(BlockVectorType &dst, const BlockVectorType &src, const number omega=1.) const