| 1 |  |  | // | 
    
    | 2 |  |  | // Copyright (c) 2021 University of Trento | 
    
    | 3 |  |  | // | 
    
    | 4 |  |  | // This file is part of tsid | 
    
    | 5 |  |  | // tsid is free software: you can redistribute it | 
    
    | 6 |  |  | // and/or modify it under the terms of the GNU Lesser General Public | 
    
    | 7 |  |  | // License as published by the Free Software Foundation, either version | 
    
    | 8 |  |  | // 3 of the License, or (at your option) any later version. | 
    
    | 9 |  |  | // tsid is distributed in the hope that it will be | 
    
    | 10 |  |  | // useful, but WITHOUT ANY WARRANTY; without even the implied warranty | 
    
    | 11 |  |  | // of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 
    
    | 12 |  |  | // General Lesser Public License for more details. You should have | 
    
    | 13 |  |  | // received a copy of the GNU Lesser General Public License along with | 
    
    | 14 |  |  | // tsid If not, see | 
    
    | 15 |  |  | // <http://www.gnu.org/licenses/>. | 
    
    | 16 |  |  | // | 
    
    | 17 |  |  |  | 
    
    | 18 |  |  | #ifndef __tsid_python_task_cop_hpp__ | 
    
    | 19 |  |  | #define __tsid_python_task_cop_hpp__ | 
    
    | 20 |  |  |  | 
    
    | 21 |  |  | #include "tsid/bindings/python/fwd.hpp" | 
    
    | 22 |  |  |  | 
    
    | 23 |  |  | #include "tsid/tasks/task-cop-equality.hpp" | 
    
    | 24 |  |  | #include "tsid/robots/robot-wrapper.hpp" | 
    
    | 25 |  |  | #include "tsid/trajectories/trajectory-base.hpp" | 
    
    | 26 |  |  | #include "tsid/math/constraint-equality.hpp" | 
    
    | 27 |  |  | #include "tsid/math/constraint-base.hpp" | 
    
    | 28 |  |  | namespace tsid { | 
    
    | 29 |  |  | namespace python { | 
    
    | 30 |  |  | namespace bp = boost::python; | 
    
    | 31 |  |  |  | 
    
    | 32 |  |  | template <typename TaskCOP> | 
    
    | 33 |  |  | struct TaskCOPEqualityPythonVisitor | 
    
    | 34 |  |  |     : public boost::python::def_visitor< | 
    
    | 35 |  |  |           TaskCOPEqualityPythonVisitor<TaskCOP> > { | 
    
    | 36 |  |  |   template <class PyClass> | 
    
    | 37 |  |  |  | 
    
    | 38 |  | 7 |   void visit(PyClass& cl) const { | 
    
    | 39 |  | 7 |     cl.def(bp::init<std::string, robots::RobotWrapper&>( | 
    
    | 40 |  |  |                (bp::arg("name"), bp::arg("robot")), "Default Constructor")) | 
    
    | 41 | ✓✗✓✗ ✓✗✓✗
 
 | 14 |         .add_property("dim", &TaskCOP::dim, "return dimension size") | 
    
    | 42 |  | 14 |         .def("setReference", &TaskCOPEqualityPythonVisitor::setReference, | 
    
    | 43 |  |  |              bp::arg("ref")) | 
    
    | 44 | ✓✗✓✗ ✓✗
 | 14 |         .def("setContactNormal", | 
    
    | 45 |  |  |              &TaskCOPEqualityPythonVisitor::setContactNormal, bp::arg("normal")) | 
    
    | 46 | ✓✗✓✗ 
 | 14 |         .def("compute", &TaskCOPEqualityPythonVisitor::compute, | 
    
    | 47 |  |  |              bp::args("t", "q", "v", "data")) | 
    
    | 48 | ✓✗✓✗ 
 | 14 |         .def("getConstraint", &TaskCOPEqualityPythonVisitor::getConstraint) | 
    
    | 49 | ✓✗✓✗ 
 | 7 |         .add_property("name", &TaskCOPEqualityPythonVisitor::name); | 
    
    | 50 |  | 7 |   } | 
    
    | 51 |  |  |   static std::string name(TaskCOP& self) { | 
    
    | 52 |  |  |     std::string name = self.name(); | 
    
    | 53 |  |  |     return name; | 
    
    | 54 |  |  |   } | 
    
    | 55 |  |  |   static math::ConstraintEquality compute(TaskCOP& self, const double t, | 
    
    | 56 |  |  |                                           const Eigen::VectorXd& q, | 
    
    | 57 |  |  |                                           const Eigen::VectorXd& v, | 
    
    | 58 |  |  |                                           pinocchio::Data& data) { | 
    
    | 59 |  |  |     self.compute(t, q, v, data); | 
    
    | 60 |  |  |     math::ConstraintEquality cons(self.getConstraint().name(), | 
    
    | 61 |  |  |                                   self.getConstraint().matrix(), | 
    
    | 62 |  |  |                                   self.getConstraint().vector()); | 
    
    | 63 |  |  |     return cons; | 
    
    | 64 |  |  |   } | 
    
    | 65 |  |  |   static math::ConstraintEquality getConstraint(const TaskCOP& self) { | 
    
    | 66 |  |  |     math::ConstraintEquality cons(self.getConstraint().name(), | 
    
    | 67 |  |  |                                   self.getConstraint().matrix(), | 
    
    | 68 |  |  |                                   self.getConstraint().vector()); | 
    
    | 69 |  |  |     return cons; | 
    
    | 70 |  |  |   } | 
    
    | 71 |  |  |   static void setReference(TaskCOP& self, const Eigen::Vector3d& ref) { | 
    
    | 72 |  |  |     self.setReference(ref); | 
    
    | 73 |  |  |   } | 
    
    | 74 |  |  |   static void setContactNormal(TaskCOP& self, const Eigen::Vector3d& n) { | 
    
    | 75 |  |  |     self.setContactNormal(n); | 
    
    | 76 |  |  |   } | 
    
    | 77 |  | 7 |   static void expose(const std::string& class_name) { | 
    
    | 78 | ✓✗ | 7 |     std::string doc = "TaskCOPEqualityPythonVisitor info."; | 
    
    | 79 | ✓✗✓✗ 
 | 7 |     bp::class_<TaskCOP>(class_name.c_str(), doc.c_str(), bp::no_init) | 
    
    | 80 |  |  |         .def(TaskCOPEqualityPythonVisitor<TaskCOP>()); | 
    
    | 81 |  | 7 |   } | 
    
    | 82 |  |  | }; | 
    
    | 83 |  |  | }  // namespace python | 
    
    | 84 |  |  | }  // namespace tsid | 
    
    | 85 |  |  |  | 
    
    | 86 |  |  | #endif  // ifndef __tsid_python_task_cop_hpp__ |