|  | #include <Eigen/Core> | 
|  | #include <iostream> | 
|  |  | 
|  | // define a custom template unary functor | 
|  | template<typename Scalar> | 
|  | struct CwiseClampOp { | 
|  | CwiseClampOp(const Scalar& inf, const Scalar& sup) : m_inf(inf), m_sup(sup) {} | 
|  | const Scalar operator()(const Scalar& x) const { return x<m_inf ? m_inf : (x>m_sup ? m_sup : x); } | 
|  | Scalar m_inf, m_sup; | 
|  | }; | 
|  |  | 
|  | int main(int, char**) | 
|  | { | 
|  | Eigen::Matrix4d m1 = Eigen::Matrix4d::Random(); | 
|  | std::cout << m1 << std::endl << "becomes: " << std::endl << m1.unaryExpr(CwiseClampOp<double>(-0.5,0.5)) << std::endl; | 
|  | return 0; | 
|  | } |