mirror of
https://gitlab.com/libeigen/eigen.git
synced 2026-04-10 11:34:33 +08:00
Fix more gcc compiler warnings / sort-of bugs
This commit is contained in:
@@ -40,14 +40,14 @@ template <typename MatrixType>
|
||||
std::enable_if_t<((MatrixType::Flags&RowMajorBit)==0),void>
|
||||
check_left_top(const MatrixType& m, Index r, Index c,
|
||||
Index rows, Index /*unused*/) {
|
||||
VERIFY_IS_EQUAL(m.leftCols(c).coeff(r+c*rows), m(r,c));
|
||||
if(c > 0) VERIFY_IS_EQUAL(m.leftCols(c).coeff(r+c*rows), m(r,c));
|
||||
}
|
||||
|
||||
template <typename MatrixType>
|
||||
std::enable_if_t<((MatrixType::Flags&RowMajorBit)!=0),void>
|
||||
check_left_top(const MatrixType& m, Index r, Index c,
|
||||
Index /*unused*/, Index cols) {
|
||||
VERIFY_IS_EQUAL(m.topRows(r).coeff(c+r*cols), m(r,c));
|
||||
if(r > 0) VERIFY_IS_EQUAL(m.topRows(r).coeff(c+r*cols), m(r,c));
|
||||
}
|
||||
|
||||
template<typename MatrixType> void block(const MatrixType& m)
|
||||
|
||||
@@ -63,7 +63,7 @@ void check_generateRandomMatrixSvs(const Index rows, const Index cols, const Ind
|
||||
{
|
||||
RealVectorType svs = setupRangeSvs<RealVectorType, RealScalar>(diag_size, min_svs, max_svs);
|
||||
|
||||
MatrixType M;
|
||||
MatrixType M = MatrixType::Zero(rows, cols);
|
||||
generateRandomMatrixSvs(svs, rows, cols, M);
|
||||
|
||||
// validate dimensions
|
||||
|
||||
@@ -55,6 +55,7 @@ template<typename MatrixType> void triangular_square(const MatrixType& m)
|
||||
r1(rows, cols),
|
||||
r2(rows, cols);
|
||||
VectorType v2 = VectorType::Random(rows);
|
||||
VectorType v3 = VectorType::Zero(rows);
|
||||
|
||||
MatrixType m1up = m1.template triangularView<Upper>();
|
||||
MatrixType m2up = m2.template triangularView<Upper>();
|
||||
@@ -96,23 +97,31 @@ template<typename MatrixType> void triangular_square(const MatrixType& m)
|
||||
Transpose<MatrixType> trm4(m4);
|
||||
// test back and forward substitution with a vector as the rhs
|
||||
m3 = m1.template triangularView<Upper>();
|
||||
VERIFY(v2.isApprox(m3.adjoint() * (m1.adjoint().template triangularView<Lower>().solve(v2)), largerEps));
|
||||
v3 = m3.adjoint() * (m1.adjoint().template triangularView<Lower>().solve(v2));
|
||||
VERIFY(v2.isApprox(v3, largerEps));
|
||||
m3 = m1.template triangularView<Lower>();
|
||||
VERIFY(v2.isApprox(m3.transpose() * (m1.transpose().template triangularView<Upper>().solve(v2)), largerEps));
|
||||
v3 = m3.transpose() * (m1.transpose().template triangularView<Upper>().solve(v2));
|
||||
VERIFY(v2.isApprox(v3, largerEps));
|
||||
m3 = m1.template triangularView<Upper>();
|
||||
VERIFY(v2.isApprox(m3 * (m1.template triangularView<Upper>().solve(v2)), largerEps));
|
||||
v3 = m3 * (m1.template triangularView<Upper>().solve(v2));
|
||||
VERIFY(v2.isApprox(v3, largerEps));
|
||||
m3 = m1.template triangularView<Lower>();
|
||||
VERIFY(v2.isApprox(m3.conjugate() * (m1.conjugate().template triangularView<Lower>().solve(v2)), largerEps));
|
||||
v3 = m3.conjugate() * (m1.conjugate().template triangularView<Lower>().solve(v2));
|
||||
VERIFY(v2.isApprox(v3, largerEps));
|
||||
|
||||
// test back and forward substitution with a matrix as the rhs
|
||||
m3 = m1.template triangularView<Upper>();
|
||||
VERIFY(m2.isApprox(m3.adjoint() * (m1.adjoint().template triangularView<Lower>().solve(m2)), largerEps));
|
||||
m4 = m3.adjoint() * (m1.adjoint().template triangularView<Lower>().solve(m2));
|
||||
VERIFY(m2.isApprox(m4, largerEps));
|
||||
m3 = m1.template triangularView<Lower>();
|
||||
VERIFY(m2.isApprox(m3.transpose() * (m1.transpose().template triangularView<Upper>().solve(m2)), largerEps));
|
||||
m4 = m3.transpose() * (m1.transpose().template triangularView<Upper>().solve(m2));
|
||||
VERIFY(m2.isApprox(m4, largerEps));
|
||||
m3 = m1.template triangularView<Upper>();
|
||||
VERIFY(m2.isApprox(m3 * (m1.template triangularView<Upper>().solve(m2)), largerEps));
|
||||
m4 = m3 * (m1.template triangularView<Upper>().solve(m2));
|
||||
VERIFY(m2.isApprox(m4, largerEps));
|
||||
m3 = m1.template triangularView<Lower>();
|
||||
VERIFY(m2.isApprox(m3.conjugate() * (m1.conjugate().template triangularView<Lower>().solve(m2)), largerEps));
|
||||
m4 = m3.conjugate() * (m1.conjugate().template triangularView<Lower>().solve(m2));
|
||||
VERIFY(m2.isApprox(m4, largerEps));
|
||||
|
||||
// check M * inv(L) using in place API
|
||||
m4 = m3;
|
||||
|
||||
Reference in New Issue
Block a user