Benoit Jacob | 8622078 | 2007-12-28 16:20:00 +0000 | [diff] [blame] | 1 | #include <Eigen/Core> |
Benoit Jacob | 3cd2a12 | 2007-12-24 11:14:25 +0000 | [diff] [blame] | 2 | USING_PART_OF_NAMESPACE_EIGEN |
| 3 | using namespace std; |
| 4 | |
Benoit Jacob | 01572b9 | 2008-03-10 17:23:11 +0000 | [diff] [blame^] | 5 | template<typename Derived> |
Benoit Jacob | 3cd2a12 | 2007-12-24 11:14:25 +0000 | [diff] [blame] | 6 | Eigen::Row<Derived> |
Benoit Jacob | 01572b9 | 2008-03-10 17:23:11 +0000 | [diff] [blame^] | 7 | firstRow(MatrixBase<Derived>& m) |
Benoit Jacob | 3cd2a12 | 2007-12-24 11:14:25 +0000 | [diff] [blame] | 8 | { |
Benoit Jacob | 861c6f4 | 2008-03-04 17:08:23 +0000 | [diff] [blame] | 9 | return Eigen::Row<Derived>(m.asArg(), 0); |
Benoit Jacob | 6b9370e | 2007-12-26 09:25:00 +0000 | [diff] [blame] | 10 | } |
| 11 | |
Benoit Jacob | 01572b9 | 2008-03-10 17:23:11 +0000 | [diff] [blame^] | 12 | template<typename Derived> |
Benoit Jacob | 6b9370e | 2007-12-26 09:25:00 +0000 | [diff] [blame] | 13 | const Eigen::Row<Derived> |
Benoit Jacob | 01572b9 | 2008-03-10 17:23:11 +0000 | [diff] [blame^] | 14 | firstRow(const MatrixBase<Derived>& m) |
Benoit Jacob | 6b9370e | 2007-12-26 09:25:00 +0000 | [diff] [blame] | 15 | { |
Benoit Jacob | 861c6f4 | 2008-03-04 17:08:23 +0000 | [diff] [blame] | 16 | return Eigen::Row<Derived>(m.asArg(), 0); |
Benoit Jacob | 3cd2a12 | 2007-12-24 11:14:25 +0000 | [diff] [blame] | 17 | } |
| 18 | |
| 19 | int main(int, char**) |
| 20 | { |
| 21 | Matrix4d m = Matrix4d::identity(); |
Benoit Jacob | 6b9370e | 2007-12-26 09:25:00 +0000 | [diff] [blame] | 22 | cout << firstRow(2*m) << endl; // calls the const version |
| 23 | firstRow(m) *= 5; // calls the non-const version |
Benoit Jacob | 3cd2a12 | 2007-12-24 11:14:25 +0000 | [diff] [blame] | 24 | cout << "Now the matrix m is:" << endl << m << endl; |
| 25 | return 0; |
| 26 | } |