aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar Benoit Jacob <jacob.benoit.1@gmail.com>2007-12-18 15:29:28 +0000
committerGravatar Benoit Jacob <jacob.benoit.1@gmail.com>2007-12-18 15:29:28 +0000
commit3380429e3a93dff0f70fbe3e9646924acafb28cd (patch)
tree3187f658d54a6eb3d290312c0cfddda0e7d6a3a1
parenta32690a222b8420d355820ccd3e2e24759187972 (diff)
Improve the "map" API and corresponding Matrix constructors
-rw-r--r--src/Core/Map.h36
-rw-r--r--src/Core/Matrix.h5
-rw-r--r--src/Core/MatrixBase.h5
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(