blob: 4071b8c0d4de4d124ebd84173ff853e12d1d2b6f [file] [log] [blame]
Benoit Jacob86220782007-12-28 16:20:00 +00001#include <Eigen/Core>
Benoit Jacob3cd2a122007-12-24 11:14:25 +00002USING_PART_OF_NAMESPACE_EIGEN
3using namespace std;
4
Benoit Jacob01572b92008-03-10 17:23:11 +00005template<typename Derived>
Benoit Jacob3cd2a122007-12-24 11:14:25 +00006Eigen::Row<Derived>
Benoit Jacob01572b92008-03-10 17:23:11 +00007firstRow(MatrixBase<Derived>& m)
Benoit Jacob3cd2a122007-12-24 11:14:25 +00008{
Benoit Jacob861c6f42008-03-04 17:08:23 +00009 return Eigen::Row<Derived>(m.asArg(), 0);
Benoit Jacob6b9370e2007-12-26 09:25:00 +000010}
11
Benoit Jacob01572b92008-03-10 17:23:11 +000012template<typename Derived>
Benoit Jacob6b9370e2007-12-26 09:25:00 +000013const Eigen::Row<Derived>
Benoit Jacob01572b92008-03-10 17:23:11 +000014firstRow(const MatrixBase<Derived>& m)
Benoit Jacob6b9370e2007-12-26 09:25:00 +000015{
Benoit Jacob861c6f42008-03-04 17:08:23 +000016 return Eigen::Row<Derived>(m.asArg(), 0);
Benoit Jacob3cd2a122007-12-24 11:14:25 +000017}
18
19int main(int, char**)
20{
21 Matrix4d m = Matrix4d::identity();
Benoit Jacob6b9370e2007-12-26 09:25:00 +000022 cout << firstRow(2*m) << endl; // calls the const version
23 firstRow(m) *= 5; // calls the non-const version
Benoit Jacob3cd2a122007-12-24 11:14:25 +000024 cout << "Now the matrix m is:" << endl << m << endl;
25 return 0;
26}