HouseholderSequence.h
Go to the documentation of this file.
1 // This file is part of Eigen, a lightweight C++ template library
2 // for linear algebra.
3 //
4 // Copyright (C) 2009 Gael Guennebaud <gael.guennebaud@inria.fr>
5 // Copyright (C) 2010 Benoit Jacob <jacob.benoit.1@gmail.com>
6 //
7 // This Source Code Form is subject to the terms of the Mozilla
8 // Public License v. 2.0. If a copy of the MPL was not distributed
9 // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
10 
11 #ifndef EIGEN_HOUSEHOLDER_SEQUENCE_H
12 #define EIGEN_HOUSEHOLDER_SEQUENCE_H
13 
14 namespace Eigen {
15 
57 namespace internal {
58 
59 template<typename VectorsType, typename CoeffsType, int Side>
60 struct traits<HouseholderSequence<VectorsType,CoeffsType,Side> >
61 {
62  typedef typename VectorsType::Scalar Scalar;
63  typedef typename VectorsType::StorageIndex StorageIndex;
64  typedef typename VectorsType::StorageKind StorageKind;
65  enum {
68  ColsAtCompileTime = RowsAtCompileTime,
71  MaxColsAtCompileTime = MaxRowsAtCompileTime,
72  Flags = 0
73  };
74 };
75 
77 
78 template<typename VectorsType, typename CoeffsType, int Side>
79 struct evaluator_traits<HouseholderSequence<VectorsType,CoeffsType,Side> >
80  : public evaluator_traits_base<HouseholderSequence<VectorsType,CoeffsType,Side> >
81 {
83 };
84 
85 template<typename VectorsType, typename CoeffsType, int Side>
87 {
91  {
92  Index start = k+1+h.m_shift;
93  return Block<const VectorsType,Dynamic,1>(h.m_vectors, start, k, h.rows()-start, 1);
94  }
95 };
96 
97 template<typename VectorsType, typename CoeffsType>
98 struct hseq_side_dependent_impl<VectorsType, CoeffsType, OnTheRight>
99 {
103  {
104  Index start = k+1+h.m_shift;
105  return Block<const VectorsType,1,Dynamic>(h.m_vectors, k, start, 1, h.rows()-start).transpose();
106  }
107 };
108 
109 template<typename OtherScalarType, typename MatrixType> struct matrix_type_times_scalar_type
110 {
113  typedef Matrix<ResultScalar, MatrixType::RowsAtCompileTime, MatrixType::ColsAtCompileTime,
114  0, MatrixType::MaxRowsAtCompileTime, MatrixType::MaxColsAtCompileTime> Type;
115 };
116 
117 } // end namespace internal
118 
119 template<typename VectorsType, typename CoeffsType, int Side> class HouseholderSequence
120  : public EigenBase<HouseholderSequence<VectorsType,CoeffsType,Side> >
121 {
123 
124  public:
125  enum {
130  };
132 
133  typedef HouseholderSequence<
136  VectorsType>::type,
139  CoeffsType>::type,
140  Side
142 
143  typedef HouseholderSequence<
144  VectorsType,
147  CoeffsType>::type,
148  Side
150 
151  typedef HouseholderSequence<
154  VectorsType>::type,
155  CoeffsType,
156  Side
158 
159  typedef HouseholderSequence<
162  Side
164 
183  HouseholderSequence(const VectorsType& v, const CoeffsType& h)
184  : m_vectors(v), m_coeffs(h), m_reverse(false), m_length(v.diagonalSize()),
185  m_shift(0)
186  {
187  }
188 
197  {
198  }
199 
205  Index rows() const EIGEN_NOEXCEPT { return Side==OnTheLeft ? m_vectors.rows() : m_vectors.cols(); }
206 
212  Index cols() const EIGEN_NOEXCEPT { return rows(); }
213 
230  {
231  eigen_assert(k >= 0 && k < m_length);
233  }
234 
237  {
238  return TransposeReturnType(m_vectors.conjugate(), m_coeffs)
239  .setReverseFlag(!m_reverse)
240  .setLength(m_length)
241  .setShift(m_shift);
242  }
243 
246  {
247  return ConjugateReturnType(m_vectors.conjugate(), m_coeffs.conjugate())
248  .setReverseFlag(m_reverse)
249  .setLength(m_length)
250  .setShift(m_shift);
251  }
252 
256  template<bool Cond>
259  conjugateIf() const
260  {
262  return ReturnType(m_vectors.template conjugateIf<Cond>(), m_coeffs.template conjugateIf<Cond>());
263  }
264 
267  {
268  return AdjointReturnType(m_vectors, m_coeffs.conjugate())
269  .setReverseFlag(!m_reverse)
270  .setLength(m_length)
271  .setShift(m_shift);
272  }
273 
275  AdjointReturnType inverse() const { return adjoint(); }
276 
278  template<typename DestType>
279  inline EIGEN_DEVICE_FUNC
280  void evalTo(DestType& dst) const
281  {
282  Matrix<Scalar, DestType::RowsAtCompileTime, 1,
283  AutoAlign|ColMajor, DestType::MaxRowsAtCompileTime, 1> workspace(rows());
284  evalTo(dst, workspace);
285  }
286 
288  template<typename Dest, typename Workspace>
290  void evalTo(Dest& dst, Workspace& workspace) const
291  {
292  workspace.resize(rows());
293  Index vecs = m_length;
295  {
296  // in-place
297  dst.diagonal().setOnes();
298  dst.template triangularView<StrictlyUpper>().setZero();
299  for(Index k = vecs-1; k >= 0; --k)
300  {
301  Index cornerSize = rows() - k - m_shift;
302  if(m_reverse)
303  dst.bottomRightCorner(cornerSize, cornerSize)
304  .applyHouseholderOnTheRight(essentialVector(k), m_coeffs.coeff(k), workspace.data());
305  else
306  dst.bottomRightCorner(cornerSize, cornerSize)
307  .applyHouseholderOnTheLeft(essentialVector(k), m_coeffs.coeff(k), workspace.data());
308 
309  // clear the off diagonal vector
310  dst.col(k).tail(rows()-k-1).setZero();
311  }
312  // clear the remaining columns if needed
313  for(Index k = 0; k<cols()-vecs ; ++k)
314  dst.col(k).tail(rows()-k-1).setZero();
315  }
316  else if(m_length>BlockSize)
317  {
318  dst.setIdentity(rows(), rows());
319  if(m_reverse)
320  applyThisOnTheLeft(dst,workspace,true);
321  else
322  applyThisOnTheLeft(dst,workspace,true);
323  }
324  else
325  {
326  dst.setIdentity(rows(), rows());
327  for(Index k = vecs-1; k >= 0; --k)
328  {
329  Index cornerSize = rows() - k - m_shift;
330  if(m_reverse)
331  dst.bottomRightCorner(cornerSize, cornerSize)
332  .applyHouseholderOnTheRight(essentialVector(k), m_coeffs.coeff(k), workspace.data());
333  else
334  dst.bottomRightCorner(cornerSize, cornerSize)
335  .applyHouseholderOnTheLeft(essentialVector(k), m_coeffs.coeff(k), workspace.data());
336  }
337  }
338  }
339 
341  template<typename Dest> inline void applyThisOnTheRight(Dest& dst) const
342  {
344  applyThisOnTheRight(dst, workspace);
345  }
346 
348  template<typename Dest, typename Workspace>
349  inline void applyThisOnTheRight(Dest& dst, Workspace& workspace) const
350  {
351  workspace.resize(dst.rows());
352  for(Index k = 0; k < m_length; ++k)
353  {
354  Index actual_k = m_reverse ? m_length-k-1 : k;
355  dst.rightCols(rows()-m_shift-actual_k)
356  .applyHouseholderOnTheRight(essentialVector(actual_k), m_coeffs.coeff(actual_k), workspace.data());
357  }
358  }
359 
361  template<typename Dest> inline void applyThisOnTheLeft(Dest& dst, bool inputIsIdentity = false) const
362  {
364  applyThisOnTheLeft(dst, workspace, inputIsIdentity);
365  }
366 
368  template<typename Dest, typename Workspace>
369  inline void applyThisOnTheLeft(Dest& dst, Workspace& workspace, bool inputIsIdentity = false) const
370  {
371  if(inputIsIdentity && m_reverse)
372  inputIsIdentity = false;
373  // if the entries are large enough, then apply the reflectors by block
374  if(m_length>=BlockSize && dst.cols()>1)
375  {
376  // Make sure we have at least 2 useful blocks, otherwise it is point-less:
377  Index blockSize = m_length<Index(2*BlockSize) ? (m_length+1)/2 : Index(BlockSize);
378  for(Index i = 0; i < m_length; i+=blockSize)
379  {
380  Index end = m_reverse ? (std::min)(m_length,i+blockSize) : m_length-i;
381  Index k = m_reverse ? i : (std::max)(Index(0),end-blockSize);
382  Index bs = end-k;
383  Index start = k + m_shift;
384 
386  SubVectorsType sub_vecs1(m_vectors.const_cast_derived(), Side==OnTheRight ? k : start,
387  Side==OnTheRight ? start : k,
388  Side==OnTheRight ? bs : m_vectors.rows()-start,
389  Side==OnTheRight ? m_vectors.cols()-start : bs);
390  typename internal::conditional<Side==OnTheRight, Transpose<SubVectorsType>, SubVectorsType&>::type sub_vecs(sub_vecs1);
391 
392  Index dstStart = dst.rows()-rows()+m_shift+k;
393  Index dstRows = rows()-m_shift-k;
394  Block<Dest,Dynamic,Dynamic> sub_dst(dst,
395  dstStart,
396  inputIsIdentity ? dstStart : 0,
397  dstRows,
398  inputIsIdentity ? dstRows : dst.cols());
399  apply_block_householder_on_the_left(sub_dst, sub_vecs, m_coeffs.segment(k, bs), !m_reverse);
400  }
401  }
402  else
403  {
404  workspace.resize(dst.cols());
405  for(Index k = 0; k < m_length; ++k)
406  {
407  Index actual_k = m_reverse ? k : m_length-k-1;
408  Index dstStart = rows()-m_shift-actual_k;
409  dst.bottomRightCorner(dstStart, inputIsIdentity ? dstStart : dst.cols())
410  .applyHouseholderOnTheLeft(essentialVector(actual_k), m_coeffs.coeff(actual_k), workspace.data());
411  }
412  }
413  }
414 
422  template<typename OtherDerived>
424  {
428  return res;
429  }
430 
431  template<typename _VectorsType, typename _CoeffsType, int _Side> friend struct internal::hseq_side_dependent_impl;
432 
444  {
445  m_length = length;
446  return *this;
447  }
448 
462  {
463  m_shift = shift;
464  return *this;
465  }
466 
468  Index length() const { return m_length; }
471  Index shift() const { return m_shift; }
473  /* Necessary for .adjoint() and .conjugate() */
474  template <typename VectorsType2, typename CoeffsType2, int Side2> friend class HouseholderSequence;
475 
476  protected:
477 
489  {
490  m_reverse = reverse;
491  return *this;
492  }
493 
494  bool reverseFlag() const { return m_reverse; }
496  typename VectorsType::Nested m_vectors;
497  typename CoeffsType::Nested m_coeffs;
498  bool m_reverse;
501  enum { BlockSize = 48 };
502 };
503 
512 template<typename OtherDerived, typename VectorsType, typename CoeffsType, int Side>
514 {
517  h.applyThisOnTheRight(res);
518  return res;
519 }
520 
525 template<typename VectorsType, typename CoeffsType>
527 {
529 }
530 
537 template<typename VectorsType, typename CoeffsType>
539 {
541 }
542 
543 } // end namespace Eigen
544 
545 #endif // EIGEN_HOUSEHOLDER_SEQUENCE_H
Eigen::internal::hseq_side_dependent_impl< VectorsType, CoeffsType, OnTheRight >::HouseholderSequenceType
HouseholderSequence< VectorsType, CoeffsType, OnTheRight > HouseholderSequenceType
Definition: HouseholderSequence.h:101
Eigen::rightHouseholderSequence
HouseholderSequence< VectorsType, CoeffsType, OnTheRight > rightHouseholderSequence(const VectorsType &v, const CoeffsType &h)
Convenience function for constructing a Householder sequence.
Definition: HouseholderSequence.h:538
EIGEN_DEVICE_FUNC
#define EIGEN_DEVICE_FUNC
Definition: Macros.h:976
Eigen::HouseholderSequence::HouseholderSequence
EIGEN_DEVICE_FUNC HouseholderSequence(const VectorsType &v, const CoeffsType &h)
Constructor.
Definition: HouseholderSequence.h:183
Eigen
Namespace containing all symbols from the Eigen library.
Definition: jet.h:637
Eigen::HouseholderSequence::ColsAtCompileTime
@ ColsAtCompileTime
Definition: HouseholderSequence.h:127
Eigen::HouseholderSequence::MaxRowsAtCompileTime
@ MaxRowsAtCompileTime
Definition: HouseholderSequence.h:128
Eigen::Block
Expression of a fixed-size or dynamic-size block.
Definition: Block.h:103
Eigen::HouseholderSequence::m_coeffs
CoeffsType::Nested m_coeffs
Definition: HouseholderSequence.h:497
gtsam.examples.DogLegOptimizerExample.type
type
Definition: DogLegOptimizerExample.py:111
Eigen::HouseholderSequence::Scalar
internal::traits< HouseholderSequence >::Scalar Scalar
Definition: HouseholderSequence.h:131
Eigen::internal::matrix_type_times_scalar_type::ResultScalar
ScalarBinaryOpTraits< OtherScalarType, typename MatrixType::Scalar >::ReturnType ResultScalar
Definition: HouseholderSequence.h:112
Eigen::EigenBase
Definition: EigenBase.h:29
Eigen::HouseholderSequence::conjugate
ConjugateReturnType conjugate() const
Complex conjugate of the Householder sequence.
Definition: HouseholderSequence.h:245
Eigen::internal::hseq_side_dependent_impl
Definition: HouseholderSequence.h:86
eigen_assert
#define eigen_assert(x)
Definition: Macros.h:1037
Eigen::HouseholderSequence::MaxColsAtCompileTime
@ MaxColsAtCompileTime
Definition: HouseholderSequence.h:129
Eigen::HouseholderSequence::setLength
EIGEN_DEVICE_FUNC HouseholderSequence & setLength(Index length)
Sets the length of the Householder sequence.
Definition: HouseholderSequence.h:443
EIGEN_CONSTEXPR
#define EIGEN_CONSTEXPR
Definition: Macros.h:787
Eigen::HouseholderSequence::conjugateIf
EIGEN_DEVICE_FUNC internal::conditional< Cond, ConjugateReturnType, ConstHouseholderSequence >::type conjugateIf() const
Definition: HouseholderSequence.h:259
Eigen::internal::hseq_side_dependent_impl< VectorsType, CoeffsType, OnTheRight >::EssentialVectorType
Transpose< Block< const VectorsType, 1, Dynamic > > EssentialVectorType
Definition: HouseholderSequence.h:100
type
Definition: pytypes.h:1525
Eigen::internal::evaluator_traits
Definition: CoreEvaluators.h:79
Eigen::HouseholderSequence::RowsAtCompileTime
@ RowsAtCompileTime
Definition: HouseholderSequence.h:126
Eigen::internal::traits< HouseholderSequence< VectorsType, CoeffsType, Side > >::StorageKind
VectorsType::StorageKind StorageKind
Definition: HouseholderSequence.h:64
Eigen::ScalarBinaryOpTraits
Determines whether the given binary operation of two numeric types is allowed and what the scalar ret...
Definition: XprHelper.h:801
Eigen::HouseholderSequence::setReverseFlag
HouseholderSequence & setReverseFlag(bool reverse)
Definition: HouseholderSequence.h:488
Eigen::internal::HouseholderSequenceShape
Definition: HouseholderSequence.h:76
res
cout<< "Here is the matrix m:"<< endl<< m<< endl;Matrix< ptrdiff_t, 3, 1 > res
Definition: PartialRedux_count.cpp:3
h
const double h
Definition: testSimpleHelicopter.cpp:19
Eigen::HouseholderSequence::setShift
EIGEN_DEVICE_FUNC HouseholderSequence & setShift(Index shift)
Sets the shift of the Householder sequence.
Definition: HouseholderSequence.h:461
Eigen::HouseholderSequence::BlockSize
@ BlockSize
Definition: HouseholderSequence.h:501
Eigen::operator*
const EIGEN_DEVICE_FUNC Product< MatrixDerived, PermutationDerived, AliasFreeProduct > operator*(const MatrixBase< MatrixDerived > &matrix, const PermutationBase< PermutationDerived > &permutation)
Definition: PermutationMatrix.h:515
Eigen::Transpose
Expression of the transpose of a matrix.
Definition: Transpose.h:52
Eigen::OnTheLeft
@ OnTheLeft
Definition: Constants.h:332
Eigen::internal::hseq_side_dependent_impl::HouseholderSequenceType
HouseholderSequence< VectorsType, CoeffsType, OnTheLeft > HouseholderSequenceType
Definition: HouseholderSequence.h:89
Eigen::HouseholderSequence::TransposeReturnType
HouseholderSequence< typename internal::conditional< NumTraits< Scalar >::IsComplex, typename internal::remove_all< typename VectorsType::ConjugateReturnType >::type, VectorsType >::type, CoeffsType, Side > TransposeReturnType
Definition: HouseholderSequence.h:157
Eigen::internal::true_type
Definition: Meta.h:96
Eigen::internal::traits< HouseholderSequence< VectorsType, CoeffsType, Side > >::StorageIndex
VectorsType::StorageIndex StorageIndex
Definition: HouseholderSequence.h:63
Eigen::internal::is_identity
Definition: XprHelper.h:678
Eigen::HouseholderSequence::cols
EIGEN_DEVICE_FUNC EIGEN_CONSTEXPR Index cols() const EIGEN_NOEXCEPT
Number of columns of transformation viewed as a matrix.
Definition: HouseholderSequence.h:212
Eigen::Dynamic
const int Dynamic
Definition: Constants.h:22
Eigen::HouseholderSequence::essentialVector
const EIGEN_DEVICE_FUNC EssentialVectorType essentialVector(Index k) const
Essential part of a Householder vector.
Definition: HouseholderSequence.h:229
Eigen::internal::add_const
Definition: Meta.h:208
Eigen::internal::matrix_type_times_scalar_type::Type
Matrix< ResultScalar, MatrixType::RowsAtCompileTime, MatrixType::ColsAtCompileTime, 0, MatrixType::MaxRowsAtCompileTime, MatrixType::MaxColsAtCompileTime > Type
Definition: HouseholderSequence.h:114
Eigen::HouseholderSequence::ConstHouseholderSequence
HouseholderSequence< typename internal::add_const< VectorsType >::type, typename internal::add_const< CoeffsType >::type, Side > ConstHouseholderSequence
Definition: HouseholderSequence.h:163
Eigen::internal::evaluator_traits_base
Definition: CoreEvaluators.h:70
Eigen::HouseholderSequence::applyThisOnTheLeft
void applyThisOnTheLeft(Dest &dst, Workspace &workspace, bool inputIsIdentity=false) const
Definition: HouseholderSequence.h:369
Eigen::Triplet< double >
Eigen::AutoAlign
@ AutoAlign
Definition: Constants.h:323
Eigen::HouseholderSequence::inverse
AdjointReturnType inverse() const
Inverse of the Householder sequence (equals the adjoint).
Definition: HouseholderSequence.h:275
Eigen::HouseholderSequence::adjoint
AdjointReturnType adjoint() const
Adjoint (conjugate transpose) of the Householder sequence.
Definition: HouseholderSequence.h:266
Eigen::OnTheRight
@ OnTheRight
Definition: Constants.h:334
Eigen::internal::hseq_side_dependent_impl< VectorsType, CoeffsType, OnTheRight >::essentialVector
static const EssentialVectorType essentialVector(const HouseholderSequenceType &h, Index k)
Definition: HouseholderSequence.h:102
Eigen::HouseholderSequence::evalTo
EIGEN_DEVICE_FUNC void evalTo(DestType &dst) const
Definition: HouseholderSequence.h:280
Eigen::HouseholderSequence::operator*
internal::matrix_type_times_scalar_type< Scalar, OtherDerived >::Type operator*(const MatrixBase< OtherDerived > &other) const
Computes the product of a Householder sequence with a matrix.
Definition: HouseholderSequence.h:423
Eigen::HouseholderSequence::transpose
TransposeReturnType transpose() const
Transpose of the Householder sequence.
Definition: HouseholderSequence.h:236
Eigen::HouseholderSequence::m_length
Index m_length
Definition: HouseholderSequence.h:499
Eigen::internal::apply_block_householder_on_the_left
void apply_block_householder_on_the_left(MatrixType &mat, const VectorsType &vectors, const CoeffsType &hCoeffs, bool forward)
Definition: BlockHouseholder.h:86
Eigen::HouseholderSequence::applyThisOnTheLeft
void applyThisOnTheLeft(Dest &dst, bool inputIsIdentity=false) const
Definition: HouseholderSequence.h:361
Eigen::internal::traits
Definition: ForwardDeclarations.h:17
Eigen::HouseholderSequence::evalTo
EIGEN_DEVICE_FUNC void evalTo(Dest &dst, Workspace &workspace) const
Definition: HouseholderSequence.h:290
Eigen::internal::conditional
Definition: Meta.h:109
Eigen::householderSequence
HouseholderSequence< VectorsType, CoeffsType > householderSequence(const VectorsType &v, const CoeffsType &h)
Convenience function for constructing a Householder sequence.
Definition: HouseholderSequence.h:526
Eigen::HouseholderSequence::rows
EIGEN_DEVICE_FUNC EIGEN_CONSTEXPR Index rows() const EIGEN_NOEXCEPT
Number of rows of transformation viewed as a matrix.
Definition: HouseholderSequence.h:205
Eigen::internal::is_same_dense
EIGEN_DEVICE_FUNC bool is_same_dense(const T1 &mat1, const T2 &mat2, typename enable_if< possibly_same_dense< T1, T2 >::value >::type *=0)
Definition: XprHelper.h:695
Eigen::HouseholderSequence::applyThisOnTheRight
void applyThisOnTheRight(Dest &dst, Workspace &workspace) const
Definition: HouseholderSequence.h:349
Eigen::HouseholderSequence::m_shift
Index m_shift
Definition: HouseholderSequence.h:500
v
Array< int, Dynamic, 1 > v
Definition: Array_initializer_list_vector_cxx11.cpp:1
min
#define min(a, b)
Definition: datatypes.h:19
Eigen::HouseholderSequence::AdjointReturnType
HouseholderSequence< VectorsType, typename internal::conditional< NumTraits< Scalar >::IsComplex, typename internal::remove_all< typename CoeffsType::ConjugateReturnType >::type, CoeffsType >::type, Side > AdjointReturnType
Definition: HouseholderSequence.h:149
Eigen::Matrix
The matrix class, also used for vectors and row-vectors.
Definition: 3rdparty/Eigen/Eigen/src/Core/Matrix.h:178
setZero
v setZero(3)
EIGEN_NOEXCEPT
#define EIGEN_NOEXCEPT
Definition: Macros.h:1418
Eigen::HouseholderSequence::HouseholderSequence
EIGEN_DEVICE_FUNC HouseholderSequence(const HouseholderSequence &other)
Copy constructor.
Definition: HouseholderSequence.h:191
internal
Definition: BandTriangularSolver.h:13
reverse
void reverse(const MatrixType &m)
Definition: array_reverse.cpp:16
Eigen::MatrixBase
Base class for all dense matrices, vectors, and expressions.
Definition: MatrixBase.h:48
Eigen::internal::hseq_side_dependent_impl::essentialVector
static const EIGEN_DEVICE_FUNC EssentialVectorType essentialVector(const HouseholderSequenceType &h, Index k)
Definition: HouseholderSequence.h:90
Eigen::HouseholderSequence::EssentialVectorType
internal::hseq_side_dependent_impl< VectorsType, CoeffsType, Side >::EssentialVectorType EssentialVectorType
Definition: HouseholderSequence.h:122
Eigen::ColMajor
@ ColMajor
Definition: Constants.h:319
Eigen::placeholders::end
static const EIGEN_DEPRECATED end_t end
Definition: IndexedViewHelper.h:181
max
#define max(a, b)
Definition: datatypes.h:20
Eigen::HouseholderSequence::applyThisOnTheRight
void applyThisOnTheRight(Dest &dst) const
Definition: HouseholderSequence.h:341
i
int i
Definition: BiCGSTAB_step_by_step.cpp:9
pybind_wrapper_test_script.other
other
Definition: pybind_wrapper_test_script.py:42
Eigen::internal::hseq_side_dependent_impl::EssentialVectorType
Block< const VectorsType, Dynamic, 1 > EssentialVectorType
Definition: HouseholderSequence.h:88
Eigen::internal::traits< HouseholderSequence< VectorsType, CoeffsType, Side > >::Scalar
VectorsType::Scalar Scalar
Definition: HouseholderSequence.h:62
Eigen::HouseholderSequence::m_vectors
VectorsType::Nested m_vectors
Definition: HouseholderSequence.h:496
Eigen::internal::cast
EIGEN_DEVICE_FUNC NewType cast(const OldType &x)
Definition: Eigen/src/Core/MathFunctions.h:460
Eigen::internal::evaluator_traits< HouseholderSequence< VectorsType, CoeffsType, Side > >::Shape
HouseholderSequenceShape Shape
Definition: HouseholderSequence.h:82
Scalar
SCALAR Scalar
Definition: bench_gemm.cpp:46
Eigen::HouseholderSequence::ConjugateReturnType
HouseholderSequence< typename internal::conditional< NumTraits< Scalar >::IsComplex, typename internal::remove_all< typename VectorsType::ConjugateReturnType >::type, VectorsType >::type, typename internal::conditional< NumTraits< Scalar >::IsComplex, typename internal::remove_all< typename CoeffsType::ConjugateReturnType >::type, CoeffsType >::type, Side > ConjugateReturnType
Definition: HouseholderSequence.h:141
Eigen::Index
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
Eigen::HouseholderSequence::m_reverse
bool m_reverse
Definition: HouseholderSequence.h:498
Eigen::HouseholderSequence
Sequence of Householder reflections acting on subspaces with decreasing size.
Definition: ForwardDeclarations.h:282
Eigen::internal::matrix_type_times_scalar_type
Definition: HouseholderSequence.h:109


gtsam
Author(s):
autogenerated on Sat Jan 4 2025 04:01:21