aboutsummaryrefslogtreecommitdiffhomepage
path: root/Eigen/src/Core/CommaInitializer.h
diff options
context:
space:
mode:
authorGravatar Gael Guennebaud <g.gael@free.fr>2008-03-08 19:46:06 +0000
committerGravatar Gael Guennebaud <g.gael@free.fr>2008-03-08 19:46:06 +0000
commitf64311e07de95694187e5d6d5d2e3cd118302076 (patch)
treec59b5170c51503c030081a5aa9a2f97650f312a3 /Eigen/src/Core/CommaInitializer.h
parent721626dfc5cab61ded1a26357b6c3dbb33763dc0 (diff)
Extended the comma initializer to support xpr on the right side:
Matrix3i mat; Vector2i vec(33,66); mat << vec.transpose(), 99, vec, Matrix2i::random();
Diffstat (limited to 'Eigen/src/Core/CommaInitializer.h')
-rw-r--r--Eigen/src/Core/CommaInitializer.h63
1 files changed, 53 insertions, 10 deletions
diff --git a/Eigen/src/Core/CommaInitializer.h b/Eigen/src/Core/CommaInitializer.h
index 0e6674be1..ba64f3f40 100644
--- a/Eigen/src/Core/CommaInitializer.h
+++ b/Eigen/src/Core/CommaInitializer.h
@@ -26,28 +26,66 @@
#ifndef EIGEN_COMMA_INITIALIZER_H
#define EIGEN_COMMA_INITIALIZER_H
+/** \internal
+ * Helper class to define the MatrixBase::operator<<
+ */
template<typename Scalar, typename Derived>
struct MatrixBase<Scalar, Derived>::CommaInitializer
{
- CommaInitializer(Derived& mat) : m_matrix(mat), m_count(1) {}
+ CommaInitializer(Derived& mat, const Scalar& s)
+ : m_matrix(mat), m_row(0), m_col(1), m_currentBlockRows(1)
+ {
+ m_matrix.coeffRef(0,0) = s;
+ }
+
+ template<typename OtherDerived>
+ CommaInitializer(Derived& mat, const MatrixBase<Scalar, OtherDerived>& other)
+ : m_matrix(mat), m_row(0), m_col(other.cols()), m_currentBlockRows(other.rows())
+ {
+ m_matrix.block(0, 0, other.rows(), other.cols()) = other;
+ }
- CommaInitializer& operator,(const Scalar& s) {
- assert(m_count<m_matrix.size() && "Too many coefficients passed to Matrix::operator<<");
- m_matrix._coeffRef(m_count/m_matrix.cols(), m_count%m_matrix.cols()) = s;
- m_count++;
+ CommaInitializer& operator,(const Scalar& s)
+ {
+ if (m_col==m_matrix.cols())
+ {
+ m_row+=m_currentBlockRows;
+ m_col = 0;
+ m_currentBlockRows = 1;
+ }
+ assert(m_col<m_matrix.cols() && "Too many coefficients passed to Matrix::operator<<");
+ assert(m_currentBlockRows==1);
+ m_matrix._coeffRef(m_row, m_col++) = s;
+ return *this;
+ }
+
+ template<typename OtherDerived>
+ CommaInitializer& operator,(const MatrixBase<Scalar, OtherDerived>& other)
+ {
+ if (m_col==m_matrix.cols())
+ {
+ m_row+=m_currentBlockRows;
+ m_col = 0;
+ m_currentBlockRows = other.rows();
+ }
+ assert(m_col<m_matrix.cols() && "Too many coefficients passed to Matrix::operator<<");
+ assert(m_currentBlockRows==other.rows());
+ m_matrix.block(m_row, m_col, other.rows(), other.cols()) = other;
+ m_col += other.cols();
return *this;
}
~CommaInitializer(void)
{
- assert(m_count==m_matrix.size() && "Too few coefficients passed to Matrix::operator<<");
+ assert((m_row+m_currentBlockRows)==m_matrix.rows() && m_col==m_matrix.cols() && "Too few coefficients passed to Matrix::operator<<");
}
Derived& m_matrix;
- int m_count;
+ int m_row; // current row id
+ int m_col; // current col id
+ int m_currentBlockRows; // current block height
};
-
/** Convenient operator to set the coefficients of a matrix.
*
* The coefficients must be provided in a row major order and exactly match
@@ -59,9 +97,14 @@ struct MatrixBase<Scalar, Derived>::CommaInitializer
template<typename Scalar, typename Derived>
typename MatrixBase<Scalar, Derived>::CommaInitializer MatrixBase<Scalar, Derived>::operator<< (const Scalar& s)
{
- coeffRef(0,0) = s;
- return CommaInitializer(*static_cast<Derived *>(this));
+ return CommaInitializer(*static_cast<Derived *>(this), s);
}
+template<typename Scalar, typename Derived>
+template<typename OtherDerived>
+typename MatrixBase<Scalar, Derived>::CommaInitializer MatrixBase<Scalar, Derived>::operator<< (const MatrixBase<Scalar, OtherDerived>& other)
+{
+ return CommaInitializer(*static_cast<Derived *>(this), other);
+}
#endif // EIGEN_COMMA_INITIALIZER_H