mirror of
https://gitlab.com/libeigen/eigen.git
synced 2026-04-10 11:34:33 +08:00
Big refactoring/cleaning in the spasre module with
in particular the addition of a selfadjointView, and the extension of triangularView. The rest is cleaning and does not change/extend the API.
This commit is contained in:
@@ -66,12 +66,12 @@ template<typename Scalar> void sparse_solvers(int rows, int cols)
|
||||
// lower - dense
|
||||
initSparse<Scalar>(density, refMat2, m2, ForceNonZeroDiag|MakeLowerTriangular, &zeroCoords, &nonzeroCoords);
|
||||
VERIFY_IS_APPROX(refMat2.template triangularView<LowerTriangular>().solve(vec2),
|
||||
m2.template triangular<LowerTriangular>().solve(vec3));
|
||||
m2.template triangularView<LowerTriangular>().solve(vec3));
|
||||
|
||||
// upper - dense
|
||||
initSparse<Scalar>(density, refMat2, m2, ForceNonZeroDiag|MakeUpperTriangular, &zeroCoords, &nonzeroCoords);
|
||||
VERIFY_IS_APPROX(refMat2.template triangularView<UpperTriangular>().solve(vec2),
|
||||
m2.template triangular<UpperTriangular>().solve(vec3));
|
||||
m2.template triangularView<UpperTriangular>().solve(vec3));
|
||||
|
||||
// TODO test row major
|
||||
|
||||
@@ -82,20 +82,20 @@ template<typename Scalar> void sparse_solvers(int rows, int cols)
|
||||
initSparse<Scalar>(density, refMat2, m2, ForceNonZeroDiag|MakeLowerTriangular);
|
||||
initSparse<Scalar>(density, refMatB, matB);
|
||||
refMat2.template triangularView<LowerTriangular>().solveInPlace(refMatB);
|
||||
m2.template triangular<LowerTriangular>().solveInPlace(matB);
|
||||
m2.template triangularView<LowerTriangular>().solveInPlace(matB);
|
||||
VERIFY_IS_APPROX(matB.toDense(), refMatB);
|
||||
|
||||
// upper - sparse
|
||||
initSparse<Scalar>(density, refMat2, m2, ForceNonZeroDiag|MakeUpperTriangular);
|
||||
initSparse<Scalar>(density, refMatB, matB);
|
||||
refMat2.template triangularView<UpperTriangular>().solveInPlace(refMatB);
|
||||
m2.template triangular<UpperTriangular>().solveInPlace(matB);
|
||||
m2.template triangularView<UpperTriangular>().solveInPlace(matB);
|
||||
VERIFY_IS_APPROX(matB, refMatB);
|
||||
|
||||
// test deprecated API
|
||||
initSparse<Scalar>(density, refMat2, m2, ForceNonZeroDiag|MakeLowerTriangular, &zeroCoords, &nonzeroCoords);
|
||||
VERIFY_IS_APPROX(refMat2.template triangularView<LowerTriangular>().solve(vec2),
|
||||
m2.template triangular<LowerTriangular>().solve(vec3));
|
||||
m2.template triangularView<LowerTriangular>().solve(vec3));
|
||||
}
|
||||
|
||||
// test LLT
|
||||
|
||||
Reference in New Issue
Block a user