blob: efd90ddbbccb9e0746cd41dc97024bd58dabf44a [file] [log] [blame]
Benoit Jacob3cd2a122007-12-24 11:14:25 +00001#include <Eigen/Core.h>
2USING_PART_OF_NAMESPACE_EIGEN
3using namespace std;
4
5template<typename Scalar, typename Derived>
6Eigen::Block<Derived, 2, 2>
7topLeft2x2Corner(MatrixBase<Scalar, Derived>& m)
8{
9 return Eigen::Block<Derived, 2, 2>(m.ref(), 0, 0);
Benoit Jacob6b9370e2007-12-26 09:25:00 +000010}
11
12template<typename Scalar, typename Derived>
13const Eigen::Block<Derived, 2, 2>
14topLeft2x2Corner(const MatrixBase<Scalar, Derived>& m)
15{
16 return Eigen::Block<Derived, 2, 2>(m.ref(), 0, 0);
Benoit Jacob3cd2a122007-12-24 11:14:25 +000017}
18
19int main(int, char**)
20{
21 Matrix3d m = Matrix3d::identity();
Benoit Jacob6b9370e2007-12-26 09:25:00 +000022 cout << topLeft2x2Corner(4*m) << endl; // calls the const version
23 topLeft2x2Corner(m) *= 2; // 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}