Householder QR decomposition of a matrix. More...
#include <HouseholderQR.h>
Householder QR decomposition of a matrix.
MatrixType | the type of the matrix of which we are computing the QR decomposition |
This class performs a QR decomposition of a matrix A into matrices Q and R such that
by using Householder transformations. Here, Q a unitary matrix and R an upper triangular matrix. The result is stored in a compact way compatible with LAPACK.
Note that no pivoting is performed. This is not a rank-revealing decomposition. If you want that feature, use FullPivHouseholderQR or ColPivHouseholderQR instead.
This Householder QR decomposition is faster, but less numerically stable and less feature-full than FullPivHouseholderQR or ColPivHouseholderQR.
Definition at line 55 of file HouseholderQR.h.
typedef internal::plain_diag_type<MatrixType>::type HouseholderQR< _MatrixType >::HCoeffsType |
Definition at line 71 of file HouseholderQR.h.
typedef HouseholderSequence<MatrixType,HCoeffsType>::ConjugateReturnType HouseholderQR< _MatrixType >::HouseholderSequenceType |
Definition at line 73 of file HouseholderQR.h.
typedef MatrixType::Index HouseholderQR< _MatrixType >::Index |
Definition at line 69 of file HouseholderQR.h.
typedef Matrix<Scalar, RowsAtCompileTime, RowsAtCompileTime, (MatrixType::Flags&RowMajorBit) ? RowMajor : ColMajor, MaxRowsAtCompileTime, MaxRowsAtCompileTime> HouseholderQR< _MatrixType >::MatrixQType |
Definition at line 70 of file HouseholderQR.h.
typedef _MatrixType HouseholderQR< _MatrixType >::MatrixType |
Definition at line 59 of file HouseholderQR.h.
typedef MatrixType::RealScalar HouseholderQR< _MatrixType >::RealScalar |
Definition at line 68 of file HouseholderQR.h.
typedef internal::plain_row_type<MatrixType>::type HouseholderQR< _MatrixType >::RowVectorType |
Definition at line 72 of file HouseholderQR.h.
typedef MatrixType::Scalar HouseholderQR< _MatrixType >::Scalar |
Definition at line 67 of file HouseholderQR.h.
anonymous enum |
Definition at line 60 of file HouseholderQR.h.
HouseholderQR< _MatrixType >::HouseholderQR | ( | ) | [inline] |
Default Constructor.
The default constructor is useful in cases in which the user intends to perform decompositions via HouseholderQR::compute(const MatrixType&).
Definition at line 81 of file HouseholderQR.h.
HouseholderQR< _MatrixType >::HouseholderQR | ( | Index | rows, |
Index | cols | ||
) | [inline] |
Default Constructor with memory preallocation.
Like the default constructor but with preallocation of the internal data according to the specified problem size.
Definition at line 89 of file HouseholderQR.h.
HouseholderQR< _MatrixType >::HouseholderQR | ( | const MatrixType & | matrix | ) | [inline] |
Definition at line 95 of file HouseholderQR.h.
MatrixType::RealScalar HouseholderQR< _MatrixType >::absDeterminant | ( | ) | const |
Index HouseholderQR< _MatrixType >::cols | ( | void | ) | const [inline] |
Definition at line 176 of file HouseholderQR.h.
HouseholderQR& HouseholderQR< _MatrixType >::compute | ( | const MatrixType & | matrix | ) |
const HCoeffsType& HouseholderQR< _MatrixType >::hCoeffs | ( | ) | const [inline] |
Definition at line 177 of file HouseholderQR.h.
HouseholderSequenceType HouseholderQR< _MatrixType >::householderQ | ( | void | ) | const [inline] |
Definition at line 129 of file HouseholderQR.h.
MatrixType::RealScalar HouseholderQR< _MatrixType >::logAbsDeterminant | ( | ) | const |
const MatrixType& HouseholderQR< _MatrixType >::matrixQR | ( | ) | const [inline] |
Definition at line 138 of file HouseholderQR.h.
Index HouseholderQR< _MatrixType >::rows | ( | void | ) | const [inline] |
Definition at line 175 of file HouseholderQR.h.
const internal::solve_retval<HouseholderQR, Rhs> HouseholderQR< _MatrixType >::solve | ( | const MatrixBase< Rhs > & | b | ) | const [inline] |
This method finds a solution x to the equation Ax=b, where A is the matrix of which *this is the QR decomposition, if any exists.
b | the right-hand-side of the equation to solve. |
Example:
typedef Matrix<float,3,3> Matrix3x3; Matrix3x3 m = Matrix3x3::Random(); Matrix3f y = Matrix3f::Random(); cout << "Here is the matrix m:" << endl << m << endl; cout << "Here is the matrix y:" << endl << y << endl; Matrix3f x; x = m.householderQr().solve(y); assert(y.isApprox(m*x)); cout << "Here is a solution x to the equation mx=y:" << endl << x << endl;
Output:
Definition at line 123 of file HouseholderQR.h.
HCoeffsType HouseholderQR< _MatrixType >::m_hCoeffs [protected] |
Definition at line 181 of file HouseholderQR.h.
bool HouseholderQR< _MatrixType >::m_isInitialized [protected] |
Definition at line 183 of file HouseholderQR.h.
MatrixType HouseholderQR< _MatrixType >::m_qr [protected] |
Definition at line 180 of file HouseholderQR.h.
RowVectorType HouseholderQR< _MatrixType >::m_temp [protected] |
Definition at line 182 of file HouseholderQR.h.