mirror of
https://gitlab.com/libeigen/eigen.git
synced 2026-04-10 11:34:33 +08:00
Define non-const operator() in Reverse; enable test for this.
Introduction of DenseCoeffBase (revision bfdc1c4973
) meant that non-const
operator() is only defined if DirectAccess is set. This caused the line
"m.reverse()(1,0) = 4;" in MatrixBase_reverse.cpp to fail at compile-time.
Not sure this is correct solution; perhaps we should disallow this? Or make
Reverse DirectAccess with a negative stride - would that break something?
This commit is contained in:
@@ -103,47 +103,6 @@ template<typename MatrixType> void reverse(const MatrixType& m)
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
cout << "m1:" << endl << m1 << endl;
|
||||
cout << "m1c_reversed:" << endl << m1c_reversed << endl;
|
||||
|
||||
cout << "----------------" << endl;
|
||||
|
||||
for ( int i=0; i< rows*cols; i++){
|
||||
cout << m1c_reversed.coeff(i) << endl;
|
||||
}
|
||||
|
||||
cout << "----------------" << endl;
|
||||
|
||||
for ( int i=0; i< rows*cols; i++){
|
||||
cout << m1c_reversed.colwise().reverse().coeff(i) << endl;
|
||||
}
|
||||
|
||||
cout << "================" << endl;
|
||||
|
||||
cout << "m1.coeff( ind ): " << m1.coeff( ind ) << endl;
|
||||
cout << "m1c_reversed.colwise().reverse().coeff( ind ): " << m1c_reversed.colwise().reverse().coeff( ind ) << endl;
|
||||
*/
|
||||
|
||||
//MatrixType m1r_reversed = m1.rowwise().reverse();
|
||||
//VERIFY_IS_APPROX( m1r_reversed.rowwise().reverse().coeff( ind ), m1.coeff( ind ) );
|
||||
|
||||
/*
|
||||
cout << "m1" << endl << m1 << endl;
|
||||
cout << "m1 using coeff(int index)" << endl;
|
||||
for ( int i = 0; i < rows*cols; i++) {
|
||||
cout << m1.coeff(i) << " ";
|
||||
}
|
||||
cout << endl;
|
||||
|
||||
cout << "m1.transpose()" << endl << m1.transpose() << endl;
|
||||
cout << "m1.transpose() using coeff(int index)" << endl;
|
||||
for ( int i = 0; i < rows*cols; i++) {
|
||||
cout << m1.transpose().coeff(i) << " ";
|
||||
}
|
||||
cout << endl;
|
||||
*/
|
||||
/*
|
||||
Scalar x = ei_random<Scalar>();
|
||||
|
||||
int r = ei_random<int>(0, rows-1),
|
||||
@@ -152,6 +111,7 @@ template<typename MatrixType> void reverse(const MatrixType& m)
|
||||
m1.reverse()(r, c) = x;
|
||||
VERIFY_IS_APPROX(x, m1(rows - 1 - r, cols - 1 - c));
|
||||
|
||||
/*
|
||||
m1.colwise().reverse()(r, c) = x;
|
||||
VERIFY_IS_APPROX(x, m1(rows - 1 - r, c));
|
||||
|
||||
|
||||
Reference in New Issue
Block a user