aboutsummaryrefslogtreecommitdiffhomepage
path: root/test/sparse_solvers.cpp
diff options
context:
space:
mode:
authorGravatar Gael Guennebaud <g.gael@free.fr>2009-04-10 19:54:43 +0000
committerGravatar Gael Guennebaud <g.gael@free.fr>2009-04-10 19:54:43 +0000
commit804a239d308bea55722c59b70c95459336230488 (patch)
treefa16185ed5bd4bfa00c406d9243ecba6e8fca035 /test/sparse_solvers.cpp
parentfb3078fb6208b432c9874119deee4e6a350ac456 (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.cpp8
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
}