Go to the documentation of this file.
   11 #ifndef EIGEN_COLPIVOTINGHOUSEHOLDERQR_H 
   12 #define EIGEN_COLPIVOTINGHOUSEHOLDERQR_H 
   48 template<
typename _MatrixType> 
class ColPivHouseholderQR
 
  123     template<
typename InputType>
 
  144     template<
typename InputType>
 
  173     template<
typename Rhs>
 
  210     template<
typename InputType>
 
  262         result += (
abs(
m_qr.coeff(i,i)) > premultiplied_threshold);
 
  417     #ifndef EIGEN_PARSED_BY_DOXYGEN 
  418     template<
typename RhsType, 
typename DstType>
 
  420     void _solve_impl(
const RhsType &rhs, DstType &dst) 
const;
 
  447 template<
typename MatrixType>
 
  451   eigen_assert(m_isInitialized && 
"ColPivHouseholderQR is not initialized.");
 
  452   eigen_assert(m_qr.rows() == m_qr.cols() && 
"You can't take the determinant of a non-square matrix!");
 
  453   return abs(m_qr.diagonal().prod());
 
  456 template<
typename MatrixType>
 
  459   eigen_assert(m_isInitialized && 
"ColPivHouseholderQR is not initialized.");
 
  460   eigen_assert(m_qr.rows() == m_qr.cols() && 
"You can't take the determinant of a non-square matrix!");
 
  461   return m_qr.diagonal().cwiseAbs().array().log().sum();
 
  470 template<
typename MatrixType>
 
  471 template<
typename InputType>
 
  479 template<
typename MatrixType>
 
  482   check_template_parameters();
 
  489   Index rows = m_qr.rows();
 
  490   Index cols = m_qr.cols();
 
  493   m_hCoeffs.resize(
size);
 
  497   m_colsTranspositions.resize(m_qr.cols());
 
  498   Index number_of_transpositions = 0;
 
  500   m_colNormsUpdated.resize(cols);
 
  501   m_colNormsDirect.resize(cols);
 
  502   for (
Index k = 0; k < cols; ++k) {
 
  505     m_colNormsDirect.coeffRef(k) = m_qr.col(k).norm();
 
  506     m_colNormsUpdated.coeffRef(k) = m_colNormsDirect.coeffRef(k);
 
  512   m_nonzero_pivots = 
size; 
 
  518     Index biggest_col_index;
 
  519     RealScalar biggest_col_sq_norm = 
numext::abs2(m_colNormsUpdated.tail(cols-k).maxCoeff(&biggest_col_index));
 
  520     biggest_col_index += k;
 
  524     if(m_nonzero_pivots==
size && biggest_col_sq_norm < threshold_helper * 
RealScalar(rows-k))
 
  525       m_nonzero_pivots = k;
 
  528     m_colsTranspositions.coeffRef(k) = biggest_col_index;
 
  529     if(k != biggest_col_index) {
 
  530       m_qr.col(k).swap(m_qr.col(biggest_col_index));
 
  531       std::swap(m_colNormsUpdated.coeffRef(k), m_colNormsUpdated.coeffRef(biggest_col_index));
 
  532       std::swap(m_colNormsDirect.coeffRef(k), m_colNormsDirect.coeffRef(biggest_col_index));
 
  533       ++number_of_transpositions;
 
  538     m_qr.col(k).tail(rows-k).makeHouseholderInPlace(m_hCoeffs.coeffRef(k), beta);
 
  541     m_qr.coeffRef(k,k) = beta;
 
  544     if(
abs(beta) > m_maxpivot) m_maxpivot = 
abs(beta);
 
  547     m_qr.bottomRightCorner(rows-k, cols-k-1)
 
  548         .applyHouseholderOnTheLeft(m_qr.col(k).tail(rows-k-1), m_hCoeffs.coeffRef(k), &m_temp.coeffRef(k+1));
 
  551     for (
Index j = k + 1; j < cols; ++j) {
 
  556       if (m_colNormsUpdated.coeffRef(j) != 
RealScalar(0)) {
 
  557         RealScalar temp = 
abs(m_qr.coeffRef(k, j)) / m_colNormsUpdated.coeffRef(j);
 
  560         RealScalar temp2 = temp * numext::abs2<RealScalar>(m_colNormsUpdated.coeffRef(j) /
 
  561                                                            m_colNormsDirect.coeffRef(j));
 
  562         if (temp2 <= norm_downdate_threshold) {
 
  565           m_colNormsDirect.coeffRef(j) = m_qr.col(j).tail(rows - k - 1).norm();
 
  566           m_colNormsUpdated.coeffRef(j) = m_colNormsDirect.coeffRef(j);
 
  576     m_colsPermutation.applyTranspositionOnTheRight(k, 
PermIndexType(m_colsTranspositions.coeff(k)));
 
  578   m_det_pq = (number_of_transpositions%2) ? -1 : 1;
 
  579   m_isInitialized = 
true;
 
  582 #ifndef EIGEN_PARSED_BY_DOXYGEN 
  583 template<
typename _MatrixType>
 
  584 template<
typename RhsType, 
typename DstType>
 
  589   const Index nonzero_pivots = nonzeroPivots();
 
  591   if(nonzero_pivots == 0)
 
  597   typename RhsType::PlainObject 
c(rhs);
 
  601                     .setLength(nonzero_pivots)
 
  605   m_qr.topLeftCorner(nonzero_pivots, nonzero_pivots)
 
  606       .template triangularView<Upper>()
 
  607       .solveInPlace(
c.topRows(nonzero_pivots));
 
  609   for(
Index i = 0; i < nonzero_pivots; ++i) dst.row(m_colsPermutation.indices().coeff(i)) = 
c.row(i);
 
  610   for(
Index i = nonzero_pivots; i < cols(); ++i) dst.row(m_colsPermutation.indices().coeff(i)).setZero();
 
  616 template<
typename DstXprType, 
typename MatrixType>
 
  632 template<
typename MatrixType>
 
  634   ::householderQ()
 const 
  636   eigen_assert(m_isInitialized && 
"ColPivHouseholderQR is not initialized.");
 
  644 template<
typename Derived>
 
  653 #endif // EIGEN_COLPIVOTINGHOUSEHOLDERQR_H 
  
RealRowVectorType m_colNormsDirect
Expression of the inverse of another expression.
ColPivHouseholderQR & setThreshold(const RealScalar &threshold)
const EIGEN_DEVICE_FUNC SqrtReturnType sqrt() const
IntRowVectorType m_colsTranspositions
Index dimensionOfKernel() const
HouseholderSequence< VectorsType, CoeffsType > householderSequence(const VectorsType &v, const CoeffsType &h)
Convenience function for constructing a Householder sequence.
ColPivHouseholderQR(EigenBase< InputType > &matrix)
Constructs a QR factorization from a given matrix.
const HCoeffsType & hCoeffs() const
Traits::StorageIndex StorageIndex
NumTraits< Scalar >::Real RealScalar
RealScalar m_prescribedThreshold
internal::plain_row_type< MatrixType >::type RowVectorType
RealRowVectorType m_colNormsUpdated
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE Abs2ReturnType abs2() const
static void run(DstXprType &dst, const SrcXprType &src, const internal::assign_op< typename DstXprType::Scalar, typename QrType::Scalar > &)
Map< Matrix< T, Dynamic, Dynamic, ColMajor >, 0, OuterStride<> > matrix(T *data, int rows, int cols, int stride)
ColPivHouseholderQR(const EigenBase< InputType > &matrix)
Constructs a QR factorization from a given matrix.
HouseholderSequence< MatrixType, typename internal::remove_all< typename HCoeffsType::ConjugateReturnType >::type > HouseholderSequenceType
const Solve< ColPivHouseholderQR, Rhs > solve(const MatrixBase< Rhs > &b) const
RealScalar maxPivot() const
internal::plain_diag_type< MatrixType >::type HCoeffsType
internal::plain_row_type< MatrixType, Index >::type IntRowVectorType
ColPivHouseholderQR()
Default Constructor.
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE AbsReturnType abs() const
PermutationType::StorageIndex PermIndexType
MatrixType::StorageIndex StorageIndex
ColPivHouseholderQR & compute(const EigenBase< InputType > &matrix)
ColPivHouseholderQR< MatrixType > QrType
Inverse< QrType > SrcXprType
const EIGEN_DEVICE_FUNC XprTypeNestedCleaned & nestedExpression() const
const Inverse< ColPivHouseholderQR > inverse() const
Complete orthogonal decomposition (COD) of a matrix.
ComputationInfo info() const
Reports whether the QR factorization was succesful.
Householder rank-revealing QR decomposition of a matrix with column-pivoting.
EIGEN_DEVICE_FUNC Index cols() const
MatrixType::PlainObject PlainObject
EIGEN_DEVICE_FUNC void _solve_impl(const RhsType &rhs, DstType &dst) const
Pseudo expression representing a solving operation.
MatrixType::RealScalar logAbsDeterminant() const
MatrixType::RealScalar absDeterminant() const
bool isInvertible() const
const MatrixType & matrixQR() const
MatrixType::Scalar Scalar
Index nonzeroPivots() const
RealScalar threshold() const
static constexpr size_t size(Tuple< Args... > &)
Provides access to the number of elements in a tuple as a compile-time constant expression.
PermutationType m_colsPermutation
const MatrixType & matrixR() const
Base class for all dense matrices, vectors, and expressions.
PermutationMatrix< ColsAtCompileTime, MaxColsAtCompileTime > PermutationType
bool isSurjective() const
static void check_template_parameters()
int EIGEN_BLAS_FUNC() swap(int *n, RealScalar *px, int *incx, RealScalar *py, int *incy)
HouseholderSequenceType matrixQ() const
ColPivHouseholderQR(Index rows, Index cols)
Default Constructor with memory preallocation.
EIGEN_DEVICE_FUNC Index rows() const
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
ColPivHouseholderQR & setThreshold(Default_t)
HouseholderSequenceType householderQ() const
const PermutationType & colsPermutation() const
bool m_usePrescribedThreshold
internal::plain_row_type< MatrixType, RealScalar >::type RealRowVectorType
MatrixType::RealScalar RealScalar
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Sequence of Householder reflections acting on subspaces with decreasing size.
#define EIGEN_STATIC_ASSERT_NON_INTEGER(TYPE)
control_box_rst
Author(s): Christoph Rösmann 
autogenerated on Wed Mar 2 2022 00:05:39