diff options
author | Benoit Jacob <jacob.benoit.1@gmail.com> | 2007-12-18 15:29:28 +0000 |
---|---|---|
committer | Benoit Jacob <jacob.benoit.1@gmail.com> | 2007-12-18 15:29:28 +0000 |
commit | 3380429e3a93dff0f70fbe3e9646924acafb28cd (patch) | |
tree | 3187f658d54a6eb3d290312c0cfddda0e7d6a3a1 | |
parent | a32690a222b8420d355820ccd3e2e24759187972 (diff) |
Improve the "map" API and corresponding Matrix constructors
-rw-r--r-- | src/Core/Map.h | 36 | ||||
-rw-r--r-- | src/Core/Matrix.h | 5 | ||||
-rw-r--r-- | src/Core/MatrixBase.h | 5 |
3 files changed, 40 insertions, 6 deletions
diff --git a/src/Core/Map.h b/src/Core/Map.h index 835d54d91..02852a9f6 100644 --- a/src/Core/Map.h +++ b/src/Core/Map.h @@ -66,7 +66,23 @@ template<typename MatrixType> class Map template<typename Scalar, typename Derived> Map<Derived> MatrixBase<Scalar, Derived>::map(const Scalar* data, int rows, int cols) { - return Map<Derived>(const_cast<Scalar*>(data),rows, cols); + return Map<Derived>(const_cast<Scalar*>(data), rows, cols); +} + +template<typename Scalar, typename Derived> +Map<Derived> MatrixBase<Scalar, Derived>::map(const Scalar* data, int size) +{ + assert(IsVector); + if(ColsAtCompileTime == 1) + return Map<Derived>(const_cast<Scalar*>(data), size, 1); + else + return Map<Derived>(const_cast<Scalar*>(data), 1, size); +} + +template<typename Scalar, typename Derived> +Map<Derived> MatrixBase<Scalar, Derived>::map(const Scalar* data) +{ + return Map<Derived>(const_cast<Scalar*>(data), RowsAtCompileTime, ColsAtCompileTime); } template<typename _Scalar, int _Rows, int _Cols> @@ -74,7 +90,23 @@ Matrix<_Scalar, _Rows, _Cols> ::Matrix(const Scalar *data, int rows, int cols) : Storage(rows, cols) { - *this = Map<Matrix>(const_cast<Scalar*>(data), rows, cols); + *this = map(data, rows, cols); +} + +template<typename _Scalar, int _Rows, int _Cols> +Matrix<_Scalar, _Rows, _Cols> + ::Matrix(const Scalar *data, int size) + : Storage(size) +{ + *this = map(data, size); +} + +template<typename _Scalar, int _Rows, int _Cols> +Matrix<_Scalar, _Rows, _Cols> + ::Matrix(const Scalar *data) + : Storage() +{ + *this = map(data); } #endif // EIGEN_FROMARRAY_H diff --git a/src/Core/Matrix.h b/src/Core/Matrix.h index b2a747aba..92eb38725 100644 --- a/src/Core/Matrix.h +++ b/src/Core/Matrix.h @@ -144,8 +144,9 @@ 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); + Matrix(const Scalar *data, int rows, int cols); + Matrix(const Scalar *data, int size); + explicit Matrix(const Scalar *data); template<typename OtherDerived> Matrix(const MatrixBase<Scalar, OtherDerived>& other) diff --git a/src/Core/MatrixBase.h b/src/Core/MatrixBase.h index e1ee000d8..b2eebe791 100644 --- a/src/Core/MatrixBase.h +++ b/src/Core/MatrixBase.h @@ -95,8 +95,9 @@ template<typename Scalar, typename Derived> class MatrixBase diagonal(const OtherDerived& coeffs); DiagonalCoeffs<Derived> diagonal() const; - static Map<Derived> - map(const Scalar* array, int rows = RowsAtCompileTime, int cols = ColsAtCompileTime); + static Map<Derived> map(const Scalar* array, int rows, int cols); + static Map<Derived> map(const Scalar* array, int size); + static Map<Derived> map(const Scalar* array); template<typename OtherDerived> bool isApprox( |