aboutsummaryrefslogtreecommitdiffhomepage
path: root/test/qr.cpp
diff options
context:
space:
mode:
authorGravatar Gael Guennebaud <g.gael@free.fr>2008-06-08 15:03:23 +0000
committerGravatar Gael Guennebaud <g.gael@free.fr>2008-06-08 15:03:23 +0000
commite3fac69f196a0a1c6ede9d510f2a4409399ad2c1 (patch)
treeec3cd5a2d0401237bec591c93435d3917fe1564e /test/qr.cpp
parent4dd57b585d2cd33afcd5900eb740250115e03c4a (diff)
Added a Hessenberg decomposition class for both real and complex matrices.
This is the first step towards a non-selfadjoint eigen solver. Notes: - We might consider merging Tridiagonalization and Hessenberg toghether ? - Or we could factorize some code into a Householder class (could also be shared with QR)
Diffstat (limited to 'test/qr.cpp')
-rw-r--r--test/qr.cpp20
1 files changed, 17 insertions, 3 deletions
diff --git a/test/qr.cpp b/test/qr.cpp
index 8facbac96..716ec94c9 100644
--- a/test/qr.cpp
+++ b/test/qr.cpp
@@ -39,17 +39,31 @@ template<typename MatrixType> void qr(const MatrixType& m)
MatrixType a = MatrixType::random(rows,cols);
QR<MatrixType> qrOfA(a);
-
VERIFY_IS_APPROX(a, qrOfA.matrixQ() * qrOfA.matrixR());
VERIFY_IS_NOT_APPROX(a+MatrixType::identity(rows, cols), qrOfA.matrixQ() * qrOfA.matrixR());
+
+ SquareMatrixType b = a.adjoint() * a;
+
+ // check tridiagonalization
+ Tridiagonalization<SquareMatrixType> tridiag(b);
+ VERIFY_IS_APPROX(b, tridiag.matrixQ() * tridiag.matrixT() * tridiag.matrixQ().adjoint());
+
+ // check hessenberg decomposition
+ HessenbergDecomposition<SquareMatrixType> hess(b);
+ VERIFY_IS_APPROX(b, hess.matrixQ() * hess.matrixH() * hess.matrixQ().adjoint());
+ VERIFY_IS_APPROX(tridiag.matrixT(), hess.matrixH());
+ b = SquareMatrixType::random(cols,cols);
+ hess.compute(b);
+ VERIFY_IS_APPROX(b, hess.matrixQ() * hess.matrixH() * hess.matrixQ().adjoint());
}
void test_qr()
{
for(int i = 0; i < 1; i++) {
CALL_SUBTEST( qr(Matrix2f()) );
- CALL_SUBTEST( qr(Matrix3d()) );
+ CALL_SUBTEST( qr(Matrix4d()) );
CALL_SUBTEST( qr(MatrixXf(12,8)) );
-// CALL_SUBTEST( qr(MatrixXcd(17,7)) ); // complex numbers are not supported yet
+ CALL_SUBTEST( qr(MatrixXcd(5,5)) );
+ CALL_SUBTEST( qr(MatrixXcd(7,3)) );
}
}