diff options
author | Gael Guennebaud <g.gael@free.fr> | 2012-07-02 16:33:32 +0200 |
---|---|---|
committer | Gael Guennebaud <g.gael@free.fr> | 2012-07-02 16:33:32 +0200 |
commit | 9a97dac4d91ee20c0bbdef39270d5a1bc743c20e (patch) | |
tree | 35244a766b23b48d6332b7bc4f307570fa0ae59d | |
parent | eee34f2da4039adaba5016e1498c3700e6e3e927 (diff) |
Doc: add an example for HouseholderQR::householderQ()
-rw-r--r-- | Eigen/src/QR/HouseholderQR.h | 8 | ||||
-rw-r--r-- | doc/snippets/HouseholderQR_householderQ.cpp | 7 |
2 files changed, 15 insertions, 0 deletions
diff --git a/Eigen/src/QR/HouseholderQR.h b/Eigen/src/QR/HouseholderQR.h index 59f6fcaa2..970672832 100644 --- a/Eigen/src/QR/HouseholderQR.h +++ b/Eigen/src/QR/HouseholderQR.h @@ -128,6 +128,14 @@ template<typename _MatrixType> class HouseholderQR return internal::solve_retval<HouseholderQR, Rhs>(*this, b.derived()); } + /** This method returns an expression of the unitary matrix Q as a sequence of Householder transformations. + * + * The returned expression can directly be used to perform matrix products. It can also be assigned to a dense Matrix object. + * Here is an example showing how to recover the full or thin matrix Q, as well as how to perform matrix products using operator*: + * + * Example: \include HouseholderQR_householderQ.cpp + * Output: \verbinclude HouseholderQR_householderQ.out + */ HouseholderSequenceType householderQ() const { eigen_assert(m_isInitialized && "HouseholderQR is not initialized."); diff --git a/doc/snippets/HouseholderQR_householderQ.cpp b/doc/snippets/HouseholderQR_householderQ.cpp new file mode 100644 index 000000000..e859ce55b --- /dev/null +++ b/doc/snippets/HouseholderQR_householderQ.cpp @@ -0,0 +1,7 @@ +MatrixXf A(MatrixXf::Random(5,3)), thinQ(MatrixXf::Identity(5,3)), Q; +A.setRandom(); +HouseholderQR<MatrixXf> qr(A); +Q = qr.householderQ(); +thinQ = qr.householderQ() * thinQ; +std::cout << "The complete unitary matrix Q is:\n" << Q << "\n\n"; +std::cout << "The thin matrix Q is:\n" << thinQ << "\n\n"; |