mirror of
https://gitlab.com/libeigen/eigen.git
synced 2025-05-02 16:54:10 +08:00
bug #1560 fix product with a 1x1 diagonal matrix
This commit is contained in:
parent
2f62cc68cd
commit
ee5864f72e
@ -785,7 +785,11 @@ public:
|
|||||||
_Vectorizable = bool(int(MatrixFlags)&PacketAccessBit) && _SameTypes && (_ScalarAccessOnDiag || (bool(int(DiagFlags)&PacketAccessBit))),
|
_Vectorizable = bool(int(MatrixFlags)&PacketAccessBit) && _SameTypes && (_ScalarAccessOnDiag || (bool(int(DiagFlags)&PacketAccessBit))),
|
||||||
_LinearAccessMask = (MatrixType::RowsAtCompileTime==1 || MatrixType::ColsAtCompileTime==1) ? LinearAccessBit : 0,
|
_LinearAccessMask = (MatrixType::RowsAtCompileTime==1 || MatrixType::ColsAtCompileTime==1) ? LinearAccessBit : 0,
|
||||||
Flags = ((HereditaryBits|_LinearAccessMask) & (unsigned int)(MatrixFlags)) | (_Vectorizable ? PacketAccessBit : 0),
|
Flags = ((HereditaryBits|_LinearAccessMask) & (unsigned int)(MatrixFlags)) | (_Vectorizable ? PacketAccessBit : 0),
|
||||||
Alignment = evaluator<MatrixType>::Alignment
|
Alignment = evaluator<MatrixType>::Alignment,
|
||||||
|
|
||||||
|
AsScalarProduct = (DiagonalType::SizeAtCompileTime==1)
|
||||||
|
|| (DiagonalType::SizeAtCompileTime==Dynamic && MatrixType::RowsAtCompileTime==1 && ProductOrder==OnTheLeft)
|
||||||
|
|| (DiagonalType::SizeAtCompileTime==Dynamic && MatrixType::ColsAtCompileTime==1 && ProductOrder==OnTheRight)
|
||||||
};
|
};
|
||||||
|
|
||||||
diagonal_product_evaluator_base(const MatrixType &mat, const DiagonalType &diag)
|
diagonal_product_evaluator_base(const MatrixType &mat, const DiagonalType &diag)
|
||||||
@ -797,7 +801,10 @@ public:
|
|||||||
|
|
||||||
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const Scalar coeff(Index idx) const
|
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const Scalar coeff(Index idx) const
|
||||||
{
|
{
|
||||||
return m_diagImpl.coeff(idx) * m_matImpl.coeff(idx);
|
if(AsScalarProduct)
|
||||||
|
return m_diagImpl.coeff(0) * m_matImpl.coeff(idx);
|
||||||
|
else
|
||||||
|
return m_diagImpl.coeff(idx) * m_matImpl.coeff(idx);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -30,6 +30,7 @@ template<typename MatrixType> void diagonalmatrices(const MatrixType& m)
|
|||||||
v2 = VectorType::Random(rows);
|
v2 = VectorType::Random(rows);
|
||||||
RowVectorType rv1 = RowVectorType::Random(cols),
|
RowVectorType rv1 = RowVectorType::Random(cols),
|
||||||
rv2 = RowVectorType::Random(cols);
|
rv2 = RowVectorType::Random(cols);
|
||||||
|
|
||||||
LeftDiagonalMatrix ldm1(v1), ldm2(v2);
|
LeftDiagonalMatrix ldm1(v1), ldm2(v2);
|
||||||
RightDiagonalMatrix rdm1(rv1), rdm2(rv2);
|
RightDiagonalMatrix rdm1(rv1), rdm2(rv2);
|
||||||
|
|
||||||
@ -105,6 +106,25 @@ template<typename MatrixType> void diagonalmatrices(const MatrixType& m)
|
|||||||
sq_m2 = sq_m1 * sq_m2;
|
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()).col(i), sq_m2.col(i) );
|
||||||
VERIFY_IS_APPROX( (sq_m1*v1.asDiagonal()).row(i), sq_m2.row(i) );
|
VERIFY_IS_APPROX( (sq_m1*v1.asDiagonal()).row(i), sq_m2.row(i) );
|
||||||
|
|
||||||
|
if(v1.size()==1)
|
||||||
|
{
|
||||||
|
typedef Matrix<Scalar, Dynamic, 1> DynVectorType;
|
||||||
|
typedef Matrix<Scalar, 1, Dynamic> DynRowVectorType;
|
||||||
|
Index depth = internal::random<Index>(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<int>
|
template<int>
|
||||||
@ -130,6 +150,7 @@ void test_diagonalmatrices()
|
|||||||
CALL_SUBTEST_7( diagonalmatrices(MatrixXi(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) );
|
CALL_SUBTEST_7( diagonalmatrices(MatrixXi(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) );
|
||||||
CALL_SUBTEST_8( diagonalmatrices(Matrix<double,Dynamic,Dynamic,RowMajor>(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) );
|
CALL_SUBTEST_8( diagonalmatrices(Matrix<double,Dynamic,Dynamic,RowMajor>(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) );
|
||||||
CALL_SUBTEST_9( diagonalmatrices(MatrixXf(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) );
|
CALL_SUBTEST_9( diagonalmatrices(MatrixXf(internal::random<int>(1,EIGEN_TEST_MAX_SIZE), internal::random<int>(1,EIGEN_TEST_MAX_SIZE))) );
|
||||||
|
CALL_SUBTEST_9( diagonalmatrices(MatrixXf(1,1)) );
|
||||||
}
|
}
|
||||||
CALL_SUBTEST_10( bug987<0>() );
|
CALL_SUBTEST_10( bug987<0>() );
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user