mirror of
https://gitlab.com/libeigen/eigen.git
synced 2025-01-30 17:40:05 +08:00
add matrix constructor taking an array. update unit-tests.
This commit is contained in:
parent
53040f53d9
commit
2c656c51e6
@ -36,7 +36,7 @@ template<typename MatrixType> class Map
|
||||
static const int RowsAtCompileTime = MatrixType::RowsAtCompileTime,
|
||||
ColsAtCompileTime = MatrixType::ColsAtCompileTime;
|
||||
|
||||
Map(int rows, int cols, Scalar* array) : m_rows(rows), m_cols(cols), m_data(array)
|
||||
Map(Scalar* data, int rows, int cols) : m_data(data), m_rows(rows), m_cols(cols)
|
||||
{
|
||||
assert(rows > 0 && cols > 0);
|
||||
}
|
||||
@ -59,14 +59,22 @@ template<typename MatrixType> class Map
|
||||
}
|
||||
|
||||
protected:
|
||||
int m_rows, m_cols;
|
||||
Scalar* m_data;
|
||||
int m_rows, m_cols;
|
||||
};
|
||||
|
||||
template<typename Scalar, typename Derived>
|
||||
Map<Derived> MatrixBase<Scalar, Derived>::map(const Scalar* array, int rows, int cols)
|
||||
Map<Derived> MatrixBase<Scalar, Derived>::map(const Scalar* data, int rows, int cols)
|
||||
{
|
||||
return Map<Derived>(rows, cols, const_cast<Scalar*>(array));
|
||||
return Map<Derived>(const_cast<Scalar*>(data),rows, cols);
|
||||
}
|
||||
|
||||
template<typename _Scalar, int _Rows, int _Cols>
|
||||
Matrix<_Scalar, _Rows, _Cols>
|
||||
::Matrix(const Scalar *data, int rows, int cols)
|
||||
: Storage(rows, cols)
|
||||
{
|
||||
*this = Map<Matrix>(const_cast<Scalar*>(data), rows, cols);
|
||||
}
|
||||
|
||||
#endif // EIGEN_FROMARRAY_H
|
||||
|
@ -144,6 +144,8 @@ class Matrix : public MatrixBase<_Scalar, Matrix<_Scalar, _Rows, _Cols> >,
|
||||
(Storage::m_data)[2] = z;
|
||||
(Storage::m_data)[3] = w;
|
||||
}
|
||||
explicit Matrix(const Scalar *data, int rows = RowsAtCompileTime,
|
||||
int cols = ColsAtCompileTime);
|
||||
|
||||
template<typename OtherDerived>
|
||||
Matrix(const MatrixBase<Scalar, OtherDerived>& other)
|
||||
|
@ -195,7 +195,6 @@ template<typename Scalar, typename Derived> class MatrixBase
|
||||
Scalar& z() { return coeffRef(2, UserDebugging); }
|
||||
Scalar& w() { return coeffRef(3, UserDebugging); }
|
||||
|
||||
|
||||
Eval<Derived> eval() const EIGEN_ALWAYS_INLINE;
|
||||
};
|
||||
|
||||
|
@ -150,12 +150,14 @@ template<typename MatrixType> void basicStuff(const MatrixType& m)
|
||||
// test Map.h
|
||||
Scalar* array1 = new Scalar[rows];
|
||||
Scalar* array2 = new Scalar[rows];
|
||||
Matrix<Scalar, Dynamic, 1>::map(array1, rows) = Matrix<Scalar, Dynamic, 1>::random(rows);
|
||||
Matrix<Scalar, Dynamic, 1>::map(array2, rows)
|
||||
= Matrix<Scalar, Dynamic, 1>::map(array1, rows);
|
||||
Matrix<Scalar, Dynamic, 1> ma1 = Matrix<Scalar, Dynamic, 1>::map(array1, rows);
|
||||
Matrix<Scalar, Dynamic, 1> ma2 = Matrix<Scalar, Dynamic, 1>::map(array2, rows);
|
||||
typedef Matrix<Scalar, Dynamic, 1> VectorX;
|
||||
VectorX::map(array1, rows) = VectorX::random(rows);
|
||||
VectorX::map(array2, rows) = VectorX::map(array1, rows);
|
||||
VectorX ma1 = VectorX::map(array1, rows);
|
||||
VectorX ma2 = VectorX::map(array2, rows);
|
||||
VERIFY_IS_APPROX(ma1, ma2);
|
||||
VERIFY_IS_APPROX(ma1, VectorX(array2, rows));
|
||||
|
||||
delete[] array1;
|
||||
delete[] array2;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user