From ee5864f72e83830f536ad91dc38d574c02a08348 Mon Sep 17 00:00:00 2001 From: Gael Guennebaud Date: Mon, 25 Jun 2018 10:30:12 +0200 Subject: bug #1560 fix product with a 1x1 diagonal matrix --- test/diagonalmatrices.cpp | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'test/diagonalmatrices.cpp') diff --git a/test/diagonalmatrices.cpp b/test/diagonalmatrices.cpp index a2092c43e..73b4cd58c 100644 --- a/test/diagonalmatrices.cpp +++ b/test/diagonalmatrices.cpp @@ -30,6 +30,7 @@ template void diagonalmatrices(const MatrixType& m) v2 = VectorType::Random(rows); RowVectorType rv1 = RowVectorType::Random(cols), rv2 = RowVectorType::Random(cols); + LeftDiagonalMatrix ldm1(v1), ldm2(v2); RightDiagonalMatrix rdm1(rv1), rdm2(rv2); @@ -105,6 +106,25 @@ template void diagonalmatrices(const MatrixType& m) sq_m2 = sq_m1 * sq_m2; VERIFY_IS_APPROX( (sq_m1*v1.asDiagonal()).col(i), sq_m2.col(i) ); VERIFY_IS_APPROX( (sq_m1*v1.asDiagonal()).row(i), sq_m2.row(i) ); + + if(v1.size()==1) + { + typedef Matrix DynVectorType; + typedef Matrix DynRowVectorType; + Index depth = internal::random(1,EIGEN_TEST_MAX_SIZE); + DynVectorType dv1 = DynVectorType::Random(depth); + DynRowVectorType drv1 = DynRowVectorType::Random(depth); + DynMatrixType dm1 = dv1; + DynMatrixType drm1 = drv1; + + Scalar s = v1(0); + + VERIFY_IS_APPROX( v1.asDiagonal() * drv1, s*drv1 ); + VERIFY_IS_APPROX( dv1 * v1.asDiagonal(), dv1*s ); + + VERIFY_IS_APPROX( v1.asDiagonal() * drm1, s*drm1 ); + VERIFY_IS_APPROX( dm1 * v1.asDiagonal(), dm1*s ); + } } template @@ -130,6 +150,7 @@ void test_diagonalmatrices() CALL_SUBTEST_7( diagonalmatrices(MatrixXi(internal::random(1,EIGEN_TEST_MAX_SIZE), internal::random(1,EIGEN_TEST_MAX_SIZE))) ); CALL_SUBTEST_8( diagonalmatrices(Matrix(internal::random(1,EIGEN_TEST_MAX_SIZE), internal::random(1,EIGEN_TEST_MAX_SIZE))) ); CALL_SUBTEST_9( diagonalmatrices(MatrixXf(internal::random(1,EIGEN_TEST_MAX_SIZE), internal::random(1,EIGEN_TEST_MAX_SIZE))) ); + CALL_SUBTEST_9( diagonalmatrices(MatrixXf(1,1)) ); } CALL_SUBTEST_10( bug987<0>() ); } -- cgit v1.2.3