16 #ifndef dealii_householder_h 17 #define dealii_householder_h 33 template <
typename number>
80 template <
typename number>
97 template <
typename number2>
105 template <
typename number2>
119 template <
typename number2>
121 least_squares(Vector<number2> &dst,
const Vector<number2> &src)
const;
126 template <
typename number2>
135 template <
class VectorType>
143 template <
class VectorType>
168 template <
typename number>
169 template <
typename number2>
173 const size_type m = M.n_rows(), n = M.n_cols();
188 for (i = j; i < m; ++i)
195 number2 s = (
storage(j, j) < 0) ? std::sqrt(sigma) : -std::sqrt(sigma);
197 number2 beta = std::sqrt(1. / (sigma - s *
storage(j, j)));
205 for (i = j + 1; i < m; ++i)
214 for (i = j + 1; i < m; ++i)
218 for (i = j + 1; i < m; ++i)
226 template <
typename number>
227 template <
typename number2>
235 template <
typename number>
236 template <
typename number2>
239 const Vector<number2> &src)
const 249 aux->reinit(src,
true);
260 sum += static_cast<number2>(
storage(i, j)) * (*aux)(i);
264 (*aux)(i) -= sum * static_cast<number2>(
storage(i, j));
269 sum += (*aux)(i) * (*aux)(i);
275 return std::sqrt(sum);
280 template <
typename number>
281 template <
typename number2>
294 aux->reinit(src,
true);
305 sum +=
storage(i, j) * (*aux)(i);
309 (*aux)(i) -= sum *
storage(i, j);
314 sum += (*aux)(i) * (*aux)(i);
320 Vector<number2> v_dst, v_aux;
329 return std::sqrt(sum);
333 template <
typename number>
334 template <
class VectorType>
342 template <
typename number>
343 template <
class VectorType>
static ::ExceptionBase & ExcEmptyMatrix()
#define AssertDimension(dim1, dim2)
SymmetricTensor< 2, dim, Number > e(const Tensor< 2, dim, Number > &F)
void Tvmult(VectorType &dst, const VectorType &src) const
void backward(Vector< number2 > &dst, const Vector< number2 > &src) const
T sum(const T &t, const MPI_Comm &mpi_communicator)
void reinit(const TableIndices< N > &new_size, const bool omit_default_initialization=false)
#define Assert(cond, exc)
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
#define DEAL_II_NAMESPACE_CLOSE
void vmult(VectorType &dst, const VectorType &src) const
FullMatrix< double > storage
Expression fabs(const Expression &x)
unsigned int global_dof_index
std::vector< number > diagonal
void initialize(const FullMatrix< number2 > &A)
#define DEAL_II_NAMESPACE_OPEN
double least_squares(Vector< number2 > &dst, const Vector< number2 > &src) const
static ::ExceptionBase & ExcNotImplemented()
#define AssertIsFinite(number)
void fill(const FullMatrix< number2 > &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)