|
typedef Traits::derived_type | derived_type |
| type of derived matrix class
|
|
typedef Traits::value_type | value_type |
| export the type representing the field
|
|
typedef Traits::value_type | field_type |
| export the type representing the field
|
|
typedef Traits::value_type | block_type |
| export the type representing the components
|
|
typedef DenseIterator< DenseMatrix, row_type, row_reference > | Iterator |
| Iterator class for sequential access.
|
|
typedef Iterator | iterator |
| typedef for stl compliant access
|
|
typedef Iterator | RowIterator |
| rename the iterators for easier access
|
|
typedef std::remove_reference< row_reference >::type::Iterator | ColIterator |
| rename the iterators for easier access
|
|
typedef DenseIterator< const DenseMatrix, const row_type, const_row_reference > | ConstIterator |
| Iterator class for sequential access.
|
|
typedef ConstIterator | const_iterator |
| typedef for stl compliant access
|
|
typedef ConstIterator | ConstRowIterator |
| rename the iterators for easier access
|
|
typedef std::remove_reference< const_row_reference >::type::ConstIterator | ConstColIterator |
| rename the iterators for easier access
|
|
|
constexpr | FieldMatrix ()=default |
| Default constructor.
|
|
constexpr | FieldMatrix (std::initializer_list< Dune::FieldVector< K, cols > > const &l) |
| Constructor initializing the matrix from a list of vector.
|
|
| FieldMatrix (const FieldMatrix &)=default |
| copy constructor
|
|
template<class T , typename = std::enable_if_t<HasDenseMatrixAssigner<FieldMatrix, T>::value>> |
| FieldMatrix (T const &rhs) |
| copy constructor from assignable type T
|
|
FieldMatrix & | operator= (const FieldMatrix &)=default |
| copy assignment operator
|
|
template<typename T > |
FieldMatrix & | operator= (const FieldMatrix< T, ROWS, COLS > &x) |
| copy assignment from FieldMatrix over a different field
|
|
template<typename T , int rows, int cols> |
FieldMatrix & | operator= (FieldMatrix< T, rows, cols > const &)=delete |
| no copy assignment from FieldMatrix of different size
|
|
FieldMatrix< K, COLS, ROWS > | transposed () const |
| Return transposed of the matrix as FieldMatrix.
|
|
template<int l> |
FieldMatrix< K, l, cols > | leftmultiplyany (const FieldMatrix< K, l, rows > &M) const |
| Multiplies M from the left to this matrix, this matrix is not modified.
|
|
template<int r, int c> |
FieldMatrix & | rightmultiply (const FieldMatrix< K, r, c > &M) |
| Multiplies M from the right to this matrix.
|
|
template<int l> |
FieldMatrix< K, rows, l > | rightmultiplyany (const FieldMatrix< K, cols, l > &M) const |
| Multiplies M from the right to this matrix, this matrix is not modified.
|
|
row_reference | operator[] (size_type i) |
| random access
|
|
size_type | size () const |
| size method (number of rows)
|
|
Iterator | begin () |
| begin iterator
|
|
ConstIterator | begin () const |
| begin iterator
|
|
Iterator | end () |
| end iterator
|
|
ConstIterator | end () const |
| end iterator
|
|
Iterator | beforeEnd () |
|
ConstIterator | beforeEnd () const |
|
Iterator | beforeBegin () |
|
ConstIterator | beforeBegin () const |
|
derived_type & | operator+= (const DenseMatrix< Other > &x) |
| vector space addition
|
|
derived_type | operator- () const |
| Matrix negation.
|
|
derived_type & | operator-= (const DenseMatrix< Other > &x) |
| vector space subtraction
|
|
derived_type & | operator*= (const field_type &k) |
| vector space multiplication with scalar
|
|
derived_type & | operator/= (const field_type &k) |
| vector space division by scalar
|
|
derived_type & | axpy (const field_type &a, const DenseMatrix< Other > &x) |
| vector space axpy operation (*this += a x)
|
|
bool | operator== (const DenseMatrix< Other > &x) const |
| Binary matrix comparison.
|
|
bool | operator!= (const DenseMatrix< Other > &x) const |
| Binary matrix incomparison.
|
|
void | mv (const X &x, Y &y) const |
| y = A x
|
|
void | mtv (const X &x, Y &y) const |
| y = A^T x
|
|
void | umv (const X &x, Y &y) const |
| y += A x
|
|
void | umtv (const X &x, Y &y) const |
| y += A^T x
|
|
void | umhv (const X &x, Y &y) const |
| y += A^H x
|
|
void | mmv (const X &x, Y &y) const |
| y -= A x
|
|
void | mmtv (const X &x, Y &y) const |
| y -= A^T x
|
|
void | mmhv (const X &x, Y &y) const |
| y -= A^H x
|
|
void | usmv (const typename FieldTraits< Y >::field_type &alpha, const X &x, Y &y) const |
| y += alpha A x
|
|
void | usmtv (const typename FieldTraits< Y >::field_type &alpha, const X &x, Y &y) const |
| y += alpha A^T x
|
|
void | usmhv (const typename FieldTraits< Y >::field_type &alpha, const X &x, Y &y) const |
| y += alpha A^H x
|
|
FieldTraits< value_type >::real_type | frobenius_norm () const |
| frobenius norm: sqrt(sum over squared values of entries)
|
|
FieldTraits< value_type >::real_type | frobenius_norm2 () const |
| square of frobenius norm, need for block recursion
|
|
FieldTraits< vt >::real_type | infinity_norm () const |
| infinity norm (row sum norm, how to generalize for blocks?)
|
|
FieldTraits< vt >::real_type | infinity_norm () const |
| infinity norm (row sum norm, how to generalize for blocks?)
|
|
FieldTraits< vt >::real_type | infinity_norm_real () const |
| simplified infinity norm (uses Manhattan norm for complex values)
|
|
FieldTraits< vt >::real_type | infinity_norm_real () const |
| simplified infinity norm (uses Manhattan norm for complex values)
|
|
void | solve (V1 &x, const V2 &b, bool doPivoting=true) const |
| Solve system A x = b. More...
|
|
void | invert (bool doPivoting=true) |
| Compute inverse. More...
|
|
field_type | determinant (bool doPivoting=true) const |
| calculates the determinant of this matrix
|
|
FieldMatrix< K, ROWS, COLS > & | leftmultiply (const DenseMatrix< M2 > &M) |
| Multiplies M from the left to this matrix.
|
|
FieldMatrix< K, ROWS, COLS > & | rightmultiply (const DenseMatrix< M2 > &M) |
| Multiplies M from the right to this matrix.
|
|
constexpr size_type | N () const |
| number of rows
|
|
constexpr size_type | M () const |
| number of columns
|
|
constexpr size_type | rows () const |
| number of rows
|
|
constexpr size_type | cols () const |
| number of columns
|
|
bool | exists (size_type i, size_type j) const |
| return true when (i,j) is in pattern
|
|
|
template<class OtherScalar > |
auto | operator+ (const FieldMatrix &matrixA, const FieldMatrix< OtherScalar, ROWS, COLS > &matrixB) |
| vector space addition – two-argument version
|
|
template<class OtherScalar > |
auto | operator- (const FieldMatrix &matrixA, const FieldMatrix< OtherScalar, ROWS, COLS > &matrixB) |
| vector space subtraction – two-argument version
|
|
template<class Scalar , std::enable_if_t< IsNumber< Scalar >::value, int > = 0> |
auto | operator* (const FieldMatrix &matrix, Scalar scalar) |
| vector space multiplication with scalar
|
|
template<class Scalar , std::enable_if_t< IsNumber< Scalar >::value, int > = 0> |
auto | operator* (Scalar scalar, const FieldMatrix &matrix) |
| vector space multiplication with scalar
|
|
template<class Scalar , std::enable_if_t< IsNumber< Scalar >::value, int > = 0> |
auto | operator/ (const FieldMatrix &matrix, Scalar scalar) |
| vector space division by scalar
|
|
template<class OtherScalar , int otherCols> |
auto | operator* (const FieldMatrix &matrixA, const FieldMatrix< OtherScalar, COLS, otherCols > &matrixB) |
| Matrix-matrix multiplication.
|
|
template<class OtherMatrix , std::enable_if_t< Impl::IsStaticSizeMatrix_v< OtherMatrix > and not Impl::IsFieldMatrix_v< OtherMatrix >, int > = 0> |
auto | operator* (const FieldMatrix &matrixA, const OtherMatrix &matrixB) |
| Matrix-matrix multiplication. More...
|
|
template<class OtherMatrix , std::enable_if_t< Impl::IsStaticSizeMatrix_v< OtherMatrix > and not Impl::IsFieldMatrix_v< OtherMatrix >, int > = 0> |
auto | operator* (const OtherMatrix &matrixA, const FieldMatrix &matrixB) |
| Matrix-matrix multiplication. More...
|
|
template<class K, int ROWS, int COLS>
class Dune::FieldMatrix< K, ROWS, COLS >
A dense n x m matrix.
Matrices represent linear maps from a vector space V to a vector space W. This class represents such a linear map by storing a two-dimensional array of numbers of a given field type K. The number of rows and columns is given at compile time.
- Examples
- recipe-integration.cc.