Sparse QR factorization based on SuiteSparseQR library. More...
#include <SuiteSparseQRSupport.h>

| Public Types | |
| enum | { ColsAtCompileTime = Dynamic, MaxColsAtCompileTime = Dynamic } | 
| typedef SparseMatrix< Scalar, ColMajor, StorageIndex > | MatrixType | 
| typedef Map< PermutationMatrix< Dynamic, Dynamic, StorageIndex > > | PermutationType | 
| typedef _MatrixType::RealScalar | RealScalar | 
| typedef _MatrixType::Scalar | Scalar | 
| typedef SuiteSparse_long | StorageIndex | 
| Public Member Functions | |
| template<typename Rhs , typename Dest > | |
| void | _solve_impl (const MatrixBase< Rhs > &b, MatrixBase< Dest > &dest) const | 
| cholmod_common * | cholmodCommon () const | 
| Index | cols () const | 
| PermutationType | colsPermutation () const | 
| Get the permutation that was applied to columns of A.  More... | |
| void | compute (const _MatrixType &matrix) | 
| ComputationInfo | info () const | 
| Reports whether previous computation was successful.  More... | |
| SPQRMatrixQReturnType< SPQR > | matrixQ () const | 
| Get an expression of the matrix Q.  More... | |
| const MatrixType | matrixR () const | 
| Index | rank () const | 
| Index | rows () const | 
| void | setPivotThreshold (const RealScalar &tol) | 
| Set the tolerance tol to treat columns with 2-norm < =tol as zero.  More... | |
| void | setSPQROrdering (int ord) | 
| Set the fill-reducing ordering method to be used.  More... | |
| SPQR () | |
| SPQR (const _MatrixType &matrix) | |
| void | SPQR_free () | 
| ~SPQR () | |
|  Public Member Functions inherited from Eigen::SparseSolverBase< SPQR< _MatrixType > > | |
| void | _solve_impl (const SparseMatrixBase< Rhs > &b, SparseMatrixBase< Dest > &dest) const | 
| SPQR< _MatrixType > & | derived () | 
| const SPQR< _MatrixType > & | derived () const | 
| const Solve< SPQR< _MatrixType >, Rhs > | solve (const MatrixBase< Rhs > &b) const | 
| const Solve< SPQR< _MatrixType >, Rhs > | solve (const SparseMatrixBase< Rhs > &b) const | 
| SparseSolverBase () | |
| ~SparseSolverBase () | |
| Protected Types | |
| typedef SparseSolverBase< SPQR< _MatrixType > > | Base | 
| Protected Attributes | |
| int | m_allow_tol | 
| bool | m_analysisIsOk | 
| cholmod_common | m_cc | 
| cholmod_sparse * | m_cR | 
| StorageIndex * | m_E | 
| bool | m_factorizationIsOk | 
| cholmod_sparse * | m_H | 
| StorageIndex * | m_HPinv | 
| cholmod_dense * | m_HTau | 
| ComputationInfo | m_info | 
| bool | m_isRUpToDate | 
| int | m_ordering | 
| MatrixType | m_R | 
| Index | m_rank | 
| Index | m_rows | 
| RealScalar | m_tolerance | 
| bool | m_useDefaultThreshold | 
|  Protected Attributes inherited from Eigen::SparseSolverBase< SPQR< _MatrixType > > | |
| bool | m_isInitialized | 
| Friends | |
| template<typename , typename > | |
| struct | SPQR_QProduct | 
Sparse QR factorization based on SuiteSparseQR library.
This class is used to perform a multithreaded and multifrontal rank-revealing QR decomposition of sparse matrices. The result is then used to solve linear leasts_square systems. Clearly, a QR factorization is returned such that A*P = Q*R where :
P is the column permutation. Use colsPermutation() to get it.
Q is the orthogonal matrix represented as Householder reflectors. Use matrixQ() to get an expression and matrixQ().transpose() to get the transpose. You can then apply it to a vector.
R is the sparse triangular factor. Use matrixQR() to get it as SparseMatrix. NOTE : The Index type of R is always SuiteSparse_long. You can get it with SPQR::Index
| _MatrixType | The type of the sparse matrix A, must be a column-major SparseMatrix<> | 
Definition at line 16 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 63 of file SuiteSparseQRSupport.h.
| typedef SparseMatrix<Scalar, ColMajor, StorageIndex> Eigen::SPQR< _MatrixType >::MatrixType | 
Definition at line 69 of file SuiteSparseQRSupport.h.
| typedef Map<PermutationMatrix<Dynamic, Dynamic, StorageIndex> > Eigen::SPQR< _MatrixType >::PermutationType | 
Definition at line 70 of file SuiteSparseQRSupport.h.
| typedef _MatrixType::RealScalar Eigen::SPQR< _MatrixType >::RealScalar | 
Definition at line 67 of file SuiteSparseQRSupport.h.
| typedef _MatrixType::Scalar Eigen::SPQR< _MatrixType >::Scalar | 
Definition at line 66 of file SuiteSparseQRSupport.h.
| typedef SuiteSparse_long Eigen::SPQR< _MatrixType >::StorageIndex | 
Definition at line 68 of file SuiteSparseQRSupport.h.
| anonymous enum | 
| Enumerator | |
|---|---|
| ColsAtCompileTime | |
| MaxColsAtCompileTime | |
Definition at line 71 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 76 of file SuiteSparseQRSupport.h.
| 
 | inlineexplicit | 
Definition at line 82 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 89 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 150 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 218 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Get the number of columns of the input matrix.
Definition at line 147 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Get the permutation that was applied to columns of A.
Definition at line 194 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 103 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Reports whether previous computation was successful.
Success if computation was succesful, NumericalIssue if the sparse QR can not be computed Definition at line 226 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Get an expression of the matrix Q.
Definition at line 189 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 179 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Gets the rank of the matrix. It should be equal to matrixQR().cols if the matrix is full-rank
Definition at line 203 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Get the number of rows of the input matrix and the Q matrix
Definition at line 142 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Set the tolerance tol to treat columns with 2-norm < =tol as zero.
Definition at line 211 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Set the fill-reducing ordering method to be used.
Definition at line 209 of file SuiteSparseQRSupport.h.
| 
 | inline | 
Definition at line 94 of file SuiteSparseQRSupport.h.
Definition at line 249 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 237 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 232 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 246 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 239 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 241 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 233 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 242 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 243 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 244 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 235 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 234 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 236 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 240 of file SuiteSparseQRSupport.h.
| 
 | mutableprotected | 
Definition at line 245 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 248 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 238 of file SuiteSparseQRSupport.h.
| 
 | protected | 
Definition at line 247 of file SuiteSparseQRSupport.h.