diff options
author | Gael Guennebaud <g.gael@free.fr> | 2009-04-10 19:54:43 +0000 |
---|---|---|
committer | Gael Guennebaud <g.gael@free.fr> | 2009-04-10 19:54:43 +0000 |
commit | 804a239d308bea55722c59b70c95459336230488 (patch) | |
tree | fa16185ed5bd4bfa00c406d9243ecba6e8fca035 /test/sparse_solvers.cpp | |
parent | fb3078fb6208b432c9874119deee4e6a350ac456 (diff) |
patch from Moritz Lenz to allow solving transposed problem with superlu
Diffstat (limited to 'test/sparse_solvers.cpp')
-rw-r--r-- | test/sparse_solvers.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/test/sparse_solvers.cpp b/test/sparse_solvers.cpp index d1090dfed..e1ec1ef35 100644 --- a/test/sparse_solvers.cpp +++ b/test/sparse_solvers.cpp @@ -191,6 +191,14 @@ template<typename Scalar> void sparse_solvers(int rows, int cols) VERIFY(refX.isApprox(x,test_precision<Scalar>()) && "LU: SuperLU"); } // std::cerr << refDet << " == " << slu.determinant() << "\n"; + if (slu.solve(b, &x, SvTranspose)) { + VERIFY(b.isApprox(m2.transpose() * x, test_precision<Scalar>())); + } + + if (slu.solve(b, &x, SvAdjoint)) { +// VERIFY(b.isApprox(m2.adjoint() * x, test_precision<Scalar>())); + } + if (count==0) { VERIFY_IS_APPROX(refDet,slu.determinant()); // FIXME det is not very stable for complex } |