11 #ifndef EIGEN_HOUSEHOLDER_H 12 #define EIGEN_HOUSEHOLDER_H 15 #include "./InternalHeaderCheck.h" 21 struct decrement_size {
22 enum { ret = n ==
Dynamic ? n : n - 1 };
42 template <
typename Derived>
45 makeHouseholder(essentialPart, tau, beta);
63 template <
typename Derived>
64 template <
typename EssentialPart>
66 RealScalar& beta)
const {
69 EIGEN_STATIC_ASSERT_VECTOR_ONLY(EssentialPart)
72 RealScalar tailSqNorm = size() == 1 ? RealScalar(0) : tail.squaredNorm();
74 const RealScalar tol = (std::numeric_limits<RealScalar>::min)();
76 if (tailSqNorm <= tol && numext::abs2(numext::imag(c0)) <= tol) {
78 beta = numext::real(c0);
81 beta = numext::sqrt(numext::abs2(c0) + tailSqNorm);
82 if (numext::real(c0) >= RealScalar(0)) beta = -beta;
83 essential = tail / (c0 - beta);
84 tau =
conj((beta - c0) / beta);
103 template <
typename Derived>
104 template <
typename EssentialPart>
109 }
else if (!numext::is_exactly_zero(tau)) {
113 tmp.noalias() = essential.adjoint() * bottom;
115 this->row(0) -= tau * tmp;
116 bottom.noalias() -= tau * essential * tmp;
135 template <
typename Derived>
136 template <
typename EssentialPart>
141 }
else if (!numext::is_exactly_zero(tau)) {
145 tmp.noalias() = right * essential;
147 this->col(0) -= tau * tmp;
148 right.noalias() -= tau * tmp * essential.adjoint();
154 #endif // EIGEN_HOUSEHOLDER_H void makeHouseholder(EssentialPart &essential, Scalar &tau, RealScalar &beta) const
Definition: Householder.h:65
internal::traits< Derived >::Scalar Scalar
Definition: DenseBase.h:62
A matrix or vector expression mapping an existing array of data.
Definition: Map.h:96
const Eigen::CwiseUnaryOp< Eigen::internal::scalar_conjugate_op< typename Derived::Scalar >, const Derived > conj(const Eigen::ArrayBase< Derived > &x)
Namespace containing all symbols from the Eigen library.
Definition: B01_Experimental.dox:1
void applyHouseholderOnTheLeft(const EssentialPart &essential, const Scalar &tau, Scalar *workspace)
Definition: Householder.h:105
Expression of a fixed-size or dynamic-size sub-vector.
Definition: ForwardDeclarations.h:98
Expression of a fixed-size or dynamic-size block.
Definition: Block.h:109
void applyHouseholderOnTheRight(const EssentialPart &essential, const Scalar &tau, Scalar *workspace)
Definition: Householder.h:137
void makeHouseholderInPlace(Scalar &tau, RealScalar &beta)
Definition: Householder.h:43
const int Dynamic
Definition: Constants.h:25