From bc8188f6a15a924066b52767fa6e52dc6b61ac3a Mon Sep 17 00:00:00 2001 From: Gael Guennebaud Date: Mon, 27 Feb 2012 13:21:41 +0100 Subject: fix symmetric permuatation for mixed storage orders --- test/sparse_permutations.cpp | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) (limited to 'test/sparse_permutations.cpp') diff --git a/test/sparse_permutations.cpp b/test/sparse_permutations.cpp index 7f47611a5..522e78f67 100644 --- a/test/sparse_permutations.cpp +++ b/test/sparse_permutations.cpp @@ -24,19 +24,22 @@ #include "sparse.h" -template void sparse_permutations(const SparseMatrixType& ref) +template void sparse_permutations(const SparseMatrixType& ref) { typedef typename SparseMatrixType::Index Index; const Index rows = ref.rows(); const Index cols = ref.cols(); typedef typename SparseMatrixType::Scalar Scalar; + typedef typename SparseMatrixType::Index Index; + typedef SparseMatrix OtherSparseMatrixType; typedef Matrix DenseMatrix; - typedef Matrix VectorI; + typedef Matrix VectorI; double density = (std::max)(8./(rows*cols), 0.01); - SparseMatrixType mat(rows, cols), up(rows,cols), lo(rows,cols), res; + SparseMatrixType mat(rows, cols), up(rows,cols), lo(rows,cols); + OtherSparseMatrixType res; DenseMatrix mat_d = DenseMatrix::Zero(rows, cols), up_sym_d, lo_sym_d, res_d; initSparse(density, mat_d, mat, 0); @@ -126,12 +129,19 @@ template void sparse_permutations(const SparseMatrixT VERIFY(res.isApprox(res_d) && "lower selfadjoint twisted to full"); } +template void sparse_permutations_all(int size) +{ + CALL_SUBTEST(( sparse_permutations(SparseMatrix(size,size)) )); + CALL_SUBTEST(( sparse_permutations(SparseMatrix(size,size)) )); + CALL_SUBTEST(( sparse_permutations(SparseMatrix(size,size)) )); + CALL_SUBTEST(( sparse_permutations(SparseMatrix(size,size)) )); +} + void test_sparse_permutations() { for(int i = 0; i < g_repeat; i++) { int s = Eigen::internal::random(1,50); - CALL_SUBTEST_1(( sparse_permutations(SparseMatrix(8, 8)) )); - CALL_SUBTEST_2(( sparse_permutations(SparseMatrix >(s, s)) )); - CALL_SUBTEST_1(( sparse_permutations(SparseMatrix(s, s)) )); + CALL_SUBTEST_1(( sparse_permutations_all(s) )); + CALL_SUBTEST_2(( sparse_permutations_all >(s) )); } } -- cgit v1.2.3