11#ifndef EIGEN_HOUSEHOLDER_H
12#define EIGEN_HOUSEHOLDER_H
17template<
int n>
struct decrement_size
20 ret = n==Dynamic ? n : n-1
41template<
typename Derived>
63template<
typename Derived>
64template<
typename EssentialPart>
66 EssentialPart& essential,
68 RealScalar& beta)
const
70 EIGEN_STATIC_ASSERT_VECTOR_ONLY(EssentialPart)
73 RealScalar tailSqNorm = size()==1 ? RealScalar(0) :
tail.squaredNorm();
76 if(tailSqNorm == RealScalar(0) && internal::imag(c0)==RealScalar(0))
79 beta = internal::real(c0);
84 beta = internal::sqrt(internal::abs2(c0) + tailSqNorm);
85 if (internal::real(c0)>=RealScalar(0))
87 essential =
tail / (c0 - beta);
88 tau = internal::conj((beta - c0) / beta);
107template<
typename Derived>
108template<
typename EssentialPart>
110 const EssentialPart& essential,
116 *
this *= Scalar(1)-tau;
122 tmp.noalias() = essential.adjoint() * bottom;
124 this->
row(0) -= tau * tmp;
125 bottom.noalias() -= tau * essential * tmp;
144template<
typename Derived>
145template<
typename EssentialPart>
147 const EssentialPart& essential,
153 *
this *= Scalar(1)-tau;
159 tmp.noalias() = right * essential.conjugate();
161 this->
col(0) -= tau * tmp;
162 right.noalias() -= tau * tmp * essential.transpose();
Expression of a fixed-size or dynamic-size block.
Definition Block.h:99
ColXpr col(Index i)
Definition DenseBase.h:553
SegmentReturnType tail(Index size)
Definition VectorBlock.h:175
RowXpr row(Index i)
Definition DenseBase.h:570
A matrix or vector expression mapping an existing array of data.
Definition Map.h:106
void applyHouseholderOnTheRight(const EssentialPart &essential, const Scalar &tau, Scalar *workspace)
Definition Householder.h:146
void applyHouseholderOnTheLeft(const EssentialPart &essential, const Scalar &tau, Scalar *workspace)
Definition Householder.h:109
void makeHouseholder(EssentialPart &essential, Scalar &tau, RealScalar &beta) const
Definition Householder.h:65
void makeHouseholderInPlace(Scalar &tau, RealScalar &beta)
Definition Householder.h:42
Expression of a fixed-size or dynamic-size sub-vector.
Definition VectorBlock.h:61