16 #ifndef dealii_lapack_full_matrix_h 17 #define dealii_lapack_full_matrix_h 37 template <
typename number>
39 template <
typename number>
41 template <
typename number>
43 template <
typename number>
59 template <
typename number>
66 using size_type = std::make_unsigned<types::blas_int>::type;
110 template <
typename number2>
120 template <
typename number2>
197 const bool left =
true);
205 template <
typename MatrixType>
307 template <
typename MatrixType>
309 fill(
const MatrixType &src,
314 const number factor = 1.,
345 template <
typename number2>
347 vmult(Vector<number2> &
w,
348 const Vector<number2> &v,
349 const bool adding =
false)
const;
357 const bool adding =
false)
const;
365 template <
typename number2>
367 vmult_add(Vector<number2> &
w,
const Vector<number2> &v)
const;
386 template <
typename number2>
389 const Vector<number2> &v,
390 const bool adding =
false)
const;
398 const bool adding =
false)
const;
406 template <
typename number2>
408 Tvmult_add(Vector<number2> &
w,
const Vector<number2> &v)
const;
434 const bool adding =
false)
const;
443 const bool adding =
false)
const;
462 const bool adding =
false)
const;
471 const bool adding =
false)
const;
492 const bool adding =
false)
const;
511 const bool adding =
false)
const;
520 const bool adding =
false)
const;
540 const bool adding =
false)
const;
549 const bool adding =
false)
const;
697 const bool left_eigenvectors =
false);
720 const number upper_bound,
721 const number abs_accuracy,
755 const number upper_bound,
756 const number abs_accuracy,
890 const unsigned int precision = 3,
891 const bool scientific =
true,
892 const unsigned int width = 0,
893 const char * zero_string =
" ",
894 const double denominator = 1.,
895 const double threshold = 0.)
const;
902 norm(
const char type)
const;
919 mutable std::vector<number>
work;
924 mutable std::vector<types::blas_int>
iwork;
932 std::vector<types::blas_int>
ipiv;
943 std::vector<typename numbers::NumberTraits<number>::real_type>
wr;
949 std::vector<number>
wi;
954 std::vector<number>
vl;
959 std::vector<number>
vr;
965 std::unique_ptr<LAPACKFullMatrix<number>>
svd_u;
971 std::unique_ptr<LAPACKFullMatrix<number>>
svd_vt;
987 template <
typename number>
1011 template <
typename number>
1017 (*this)(i, j) = value;
1021 template <
typename number>
1028 template <
typename number>
1035 template <
typename number>
1036 template <
typename MatrixType>
1040 this->
reinit(M.m(), M.n());
1045 for (
size_type row = 0; row < M.m(); ++row)
1047 const typename MatrixType::const_iterator end_row = M.end(row);
1048 for (
typename MatrixType::const_iterator entry = M.begin(row);
1051 this->
el(row, entry->column()) = entry->value();
1059 template <
typename number>
1060 template <
typename MatrixType>
1067 const number factor,
1072 for (
size_type row = src_offset_i; row < M.m(); ++row)
1074 const typename MatrixType::const_iterator end_row = M.end(row);
1075 for (
typename MatrixType::const_iterator entry = M.begin(row);
1079 const size_type i = transpose ? entry->column() : row;
1080 const size_type j = transpose ? row : entry->column();
1082 const size_type dst_i = dst_offset_i + i - src_offset_i;
1083 const size_type dst_j = dst_offset_j + j - src_offset_j;
1085 (*this)(dst_i, dst_j) = factor * entry->value();
1093 template <
typename number>
1094 template <
typename number2>
1097 const Vector<number2> &,
1101 ExcMessage(
"LAPACKFullMatrix<number>::vmult must be called with a " 1102 "matching Vector<double> vector type."));
1106 template <
typename number>
1107 template <
typename number2>
1110 const Vector<number2> &)
const 1113 ExcMessage(
"LAPACKFullMatrix<number>::vmult_add must be called with a " 1114 "matching Vector<double> vector type."));
1118 template <
typename number>
1119 template <
typename number2>
1122 const Vector<number2> &,
1126 ExcMessage(
"LAPACKFullMatrix<number>::Tvmult must be called with a " 1127 "matching Vector<double> vector type."));
1131 template <
typename number>
1132 template <
typename number2>
1135 const Vector<number2> &)
const 1139 "LAPACKFullMatrix<number>::Tvmult_add must be called with a " 1140 "matching Vector<double> vector type."));
1144 template <
typename number>
1145 inline std::complex<number>
1154 return std::complex<number>(
wi[i]);
1156 return std::complex<number>(
wr[i],
wi[i]);
1160 template <
typename number>
1172 template <
typename number>
1183 template <
typename number>
Iterator lower_bound(Iterator first, Iterator last, const T &val)
LAPACKFullMatrix(const size_type size=0)
std::vector< number > work
void rank1_update(const number a, const Vector< number > &v)
void TmTmult(LAPACKFullMatrix< number > &C, const LAPACKFullMatrix< number > &B, const bool adding=false) const
std::unique_ptr< LAPACKFullMatrix< number > > svd_vt
LAPACKFullMatrix< number > & operator/=(const number factor)
Contents is actually a matrix.
std::array< std::pair< Number, Tensor< 1, dim, Number > >, std::integral_constant< int, dim >::value > eigenvectors(const SymmetricTensor< 2, dim, Number > &T, const SymmetricTensorEigenvectorMethod method=SymmetricTensorEigenvectorMethod::ql_implicit_shifts)
void Tvmult(Vector< number2 > &w, const Vector< number2 > &v, const bool adding=false) const
LAPACKSupport::State state
void remove_row_and_column(const size_type row, const size_type col)
std::vector< types::blas_int > ipiv
const TableIndices< N > & size() const
std::complex< number > eigenvalue(const size_type i) const
#define AssertIndexRange(index, range)
void apply_givens_rotation(const std::array< number, 3 > &csr, const size_type i, const size_type k, const bool left=true)
void compute_eigenvalues_symmetric(const number lower_bound, const number upper_bound, const number abs_accuracy, Vector< number > &eigenvalues, FullMatrix< number > &eigenvectors)
void reinit(const size_type size)
number norm(const char type) const
const LAPACKFullMatrix< number > & get_svd_u() const
void Tmmult(LAPACKFullMatrix< number > &C, const LAPACKFullMatrix< number > &B, const bool adding=false) const
SymmetricTensor< 2, dim, Number > C(const Tensor< 2, dim, Number > &F)
std::vector< types::blas_int > iwork
static ::ExceptionBase & ExcState(State arg1)
void set(const size_type i, const size_type j, const number value)
static ::ExceptionBase & ExcInvalidState()
static ::ExceptionBase & ExcMessage(std::string arg1)
void mTmult(LAPACKFullMatrix< number > &C, const LAPACKFullMatrix< number > &B, const bool adding=false) const
#define Assert(cond, exc)
void compute_inverse_svd_with_kernel(const unsigned int kernel_size)
void copy_from(const MatrixType &)
std::make_unsigned< types::blas_int >::type size_type
void add(const number a, const LAPACKFullMatrix< number > &B)
std::vector< number > inv_work
#define DEAL_II_NAMESPACE_CLOSE
void transpose(LAPACKFullMatrix< number > &B) const
const LAPACKFullMatrix< number > & get_svd_vt() const
Matrix is the inverse of a singular value decomposition.
void compute_lu_factorization()
void vmult(Vector< number2 > &w, const Vector< number2 > &v, const bool adding=false) const
std::unique_ptr< LAPACKFullMatrix< number > > svd_u
SymmetricTensor< 2, dim, Number > d(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
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 double threshold=0.) const
void grow_or_shrink(const size_type size)
void scale_rows(const Vector< number > &V)
number singular_value(const size_type i) const
LAPACKFullMatrix< number > & operator*=(const number factor)
void compute_inverse_svd(const double threshold=0.)
Tensor< 2, dim, Number > w(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
SmartPointer< const LAPACKFullMatrix< number >, PreconditionLU< number > > matrix
void compute_cholesky_factorization()
number linfty_norm() const
LAPACKFullMatrix< number > & operator=(const LAPACKFullMatrix< number > &)
void fill(const MatrixType &src, const size_type dst_offset_i=0, const size_type dst_offset_j=0, const size_type src_offset_i=0, const size_type src_offset_j=0, const number factor=1., const bool transpose=false)
number determinant() const
typename AlignedVector< Number >::size_type size_type
number frobenius_norm() const
void Tvmult_add(Vector< number2 > &w, const Vector< number2 > &v) const
#define DEAL_II_NAMESPACE_OPEN
std::vector< typename numbers::NumberTraits< number >::real_type > wr
Matrix contains singular value decomposition,.
void set_property(const LAPACKSupport::Property property)
void solve(Vector< number > &v, const bool transposed=false) const
reference el(const size_type i, const size_type j)
void compute_generalized_eigenvalues_symmetric(LAPACKFullMatrix< number > &B, const number lower_bound, const number upper_bound, const number abs_accuracy, Vector< number > &eigenvalues, std::vector< Vector< number >> &eigenvectors, const types::blas_int itype=1)
void compute_eigenvalues(const bool right_eigenvectors=false, const bool left_eigenvectors=false)
SmartPointer< VectorMemory< Vector< number > >, PreconditionLU< number > > mem
number reciprocal_condition_number() const
Eigenvalue vector is filled.
LAPACKSupport::Property property
void vmult_add(Vector< number2 > &w, const Vector< number2 > &v) const
void mmult(LAPACKFullMatrix< number > &C, const LAPACKFullMatrix< number > &B, const bool adding=false) const
static ::ExceptionBase & ExcInternalError()