bindings/python/spatial/se3.hpp
Go to the documentation of this file.
1 //
2 // Copyright (c) 2015-2024 CNRS INRIA
3 // Copyright (c) 2016 Wandercraft, 86 rue de Paris 91400 Orsay, France.
4 //
5 
6 #ifndef __pinocchio_python_spatial_se3_hpp__
7 #define __pinocchio_python_spatial_se3_hpp__
8 
9 #include <eigenpy/eigenpy.hpp>
10 #include <eigenpy/memory.hpp>
11 #include <boost/python/tuple.hpp>
12 
18 
20 
25 
26 #if EIGENPY_VERSION_AT_MOST(2, 8, 1)
28 #endif
29 
30 namespace pinocchio
31 {
32  namespace python
33  {
34  namespace bp = boost::python;
35 
36  template<typename SE3>
37  struct SE3PythonVisitor : public boost::python::def_visitor<SE3PythonVisitor<SE3>>
38  {
39  typedef typename SE3::Scalar Scalar;
40  enum
41  {
43  };
44  typedef typename SE3::Matrix3 Matrix3;
45  typedef typename SE3::Vector3 Vector3;
46  typedef typename SE3::Matrix4 Matrix4;
47  typedef typename SE3::Quaternion Quaternion;
48  typedef typename SE3::ActionMatrixType ActionMatrixType;
49 
53 
54  public:
55  template<class PyClass>
56  void visit(PyClass & cl) const
57  {
58  static const Scalar dummy_precision = Eigen::NumTraits<Scalar>::dummy_precision();
59 
60  cl.def(bp::init<const Matrix3 &, const Vector3 &>(
61  (bp::arg("self"), bp::arg("rotation"), bp::arg("translation")),
62  "Initialize from a rotation matrix and a translation vector."))
63  .def(bp::init<const Quaternion &, const Vector3 &>(
64  (bp::arg("self"), bp::arg("quat"), bp::arg("translation")),
65  "Initialize from a quaternion and a translation vector."))
66  .def(bp::init<int>((bp::arg("self"), bp::arg("int")), "Init to identity."))
67  .def(bp::init<const Matrix4 &>(
68  (bp::arg("self"), bp::arg("array")), "Initialize from an homogeneous matrix."))
69  .def(bp::init<const SE3 &>((bp::arg("self"), bp::arg("clone")), "Copy constructor"))
70 
71  .add_property(
72  "rotation",
73  bp::make_function(
74  (typename SE3::AngularRef(SE3::*)()) & SE3::rotation,
75  bp::return_internal_reference<>()),
76  (void(SE3::*)(const Matrix3 &)) & SE3::rotation,
77  "The rotation part of the transformation.")
78  .add_property(
79  "translation",
80  bp::make_function(
81  (typename SE3::LinearRef(SE3::*)()) & SE3::translation,
82  bp::return_internal_reference<>()),
83  (void(SE3::*)(const Vector3 &)) & SE3::translation,
84  "The translation part of the transformation.")
85 
86  .add_property(
87  "homogeneous", &SE3::toHomogeneousMatrix,
88  "Returns the equivalent homegeneous matrix (acting on SE3).")
89  .add_property(
90  "action", (ActionMatrixType(SE3::*)() const)&SE3::toActionMatrix,
91  "Returns the related action matrix (acting on Motion).")
92  .def(
93  "toActionMatrix", (ActionMatrixType(SE3::*)() const)&SE3::toActionMatrix,
94  bp::arg("self"), "Returns the related action matrix (acting on Motion).")
95  .add_property(
96  "actionInverse", (ActionMatrixType(SE3::*)() const)&SE3::toActionMatrixInverse,
97  "Returns the inverse of the action matrix (acting on Motion).\n"
98  "This is equivalent to do m.inverse().action")
99  .def(
100  "toActionMatrixInverse", (ActionMatrixType(SE3::*)() const)&SE3::toActionMatrixInverse,
101  bp::arg("self"),
102  "Returns the inverse of the action matrix (acting on Motion).\n"
103  "This is equivalent to do m.inverse().toActionMatrix()")
104  .add_property(
105  "dualAction", (ActionMatrixType(SE3::*)() const)&SE3::toDualActionMatrix,
106  "Returns the related dual action matrix (acting on Force).")
107  .def(
108  "toDualActionMatrix", (ActionMatrixType(SE3::*)() const)&SE3::toDualActionMatrix,
109  bp::arg("self"), "Returns the related dual action matrix (acting on Force).")
110 
111  .def(
112  "setIdentity", &SE3PythonVisitor::setIdentity, bp::arg("self"),
113  "Set *this to the identity placement.")
114  .def(
115  "setRandom", &SE3PythonVisitor::setRandom, bp::arg("self"),
116  "Set *this to a random placement.")
117 
118  .def("inverse", &SE3::inverse, bp::arg("self"), "Returns the inverse transform")
119 
120  .def(
121  "act", (Vector3(SE3::*)(const Vector3 &) const)&SE3::act, bp::args("self", "point"),
122  "Returns a point which is the result of the entry point transforms by *this.")
123  .def(
124  "actInv", (Vector3(SE3::*)(const Vector3 &) const)&SE3::actInv,
125  bp::args("self", "point"),
126  "Returns a point which is the result of the entry point by the inverse of *this.")
127 
128  .def(
129  "act", (SE3(SE3::*)(const SE3 & other) const)&SE3::act, bp::args("self", "M"),
130  "Returns the result of *this * M.")
131  .def(
132  "actInv", (SE3(SE3::*)(const SE3 & other) const)&SE3::actInv, bp::args("self", "M"),
133  "Returns the result of the inverse of *this times M.")
134 
135  .def(
136  "act", (Motion(SE3::*)(const Motion &) const)&SE3::act, bp::args("self", "motion"),
137  "Returns the result action of *this onto a Motion.")
138  .def(
139  "actInv", (Motion(SE3::*)(const Motion &) const)&SE3::actInv,
140  bp::args("self", "motion"), "Returns the result of the inverse of *this onto a Motion.")
141 
142  .def(
143  "act", (Force(SE3::*)(const Force &) const)&SE3::act, bp::args("self", "force"),
144  "Returns the result of *this onto a Force.")
145  .def(
146  "actInv", (Force(SE3::*)(const Force &) const)&SE3::actInv, bp::args("self", "force"),
147  "Returns the result of the inverse of *this onto an Inertia.")
148 
149  .def(
150  "act", (Inertia(SE3::*)(const Inertia &) const)&SE3::act, bp::args("self", "inertia"),
151  "Returns the result of *this onto a Force.")
152  .def(
153  "actInv", (Inertia(SE3::*)(const Inertia &) const)&SE3::actInv,
154  bp::args("self", "inertia"),
155  "Returns the result of the inverse of *this onto an Inertia.")
156 
157 #ifndef PINOCCHIO_PYTHON_SKIP_COMPARISON_OPERATIONS
158  .def(
159  "isApprox", &SE3::isApprox,
160  (bp::arg("self"), bp::arg("other"), bp::arg("prec") = dummy_precision),
161  "Returns true if *this is approximately equal to other, within the precision given "
162  "by prec.")
163 
164  .def(
165  "isIdentity", &SE3::isIdentity, (bp::arg("self"), bp::arg("prec") = dummy_precision),
166  "Returns true if *this is approximately equal to the identity placement, within the "
167  "precision given by prec.")
168 #endif
169 
170  .def("__invert__", &SE3::inverse, "Returns the inverse of *this.")
171  .def(bp::self * bp::self)
172  .def("__mul__", &__mul__<Motion>)
173  .def("__mul__", &__mul__<Force>)
174  .def("__mul__", &__mul__<Inertia>)
175  .def("__mul__", &__mul__<Vector3>)
176  .add_property("np", &SE3::toHomogeneousMatrix)
177 
178 #ifndef PINOCCHIO_PYTHON_SKIP_COMPARISON_OPERATIONS
179  .def(bp::self == bp::self)
180  .def(bp::self != bp::self)
181 #endif
182 
183  .def("Identity", &SE3::Identity, "Returns the identity transformation.")
184  .staticmethod("Identity")
185  .def("Random", &SE3::Random, "Returns a random transformation.")
186  .staticmethod("Random")
187  .def(
188  "Interpolate", &SE3::template Interpolate<Scalar>, bp::args("A", "B", "alpha"),
189  "Linear interpolation on the SE3 manifold.\n\n"
190  "This method computes the linear interpolation between A and B, such that the "
191  "result C = A + (B-A)*t if it would be applied on classic Euclidian space.\n"
192  "This operation is very similar to the SLERP operation on Rotations.\n"
193  "Parameters:\n"
194  "\tA: Initial transformation\n"
195  "\tB: Target transformation\n"
196  "\talpha: Interpolation factor")
197  .staticmethod("Interpolate")
198 
199  .def("__array__", &SE3::toHomogeneousMatrix)
200  .def(
201  "__array__", &__array__,
202  (bp::arg("self"), bp::arg("dtype") = bp::object(), bp::arg("copy") = bp::object()))
203 
204 #ifndef PINOCCHIO_PYTHON_NO_SERIALIZATION
205  .def_pickle(Pickle())
206 #endif
207  ;
208  }
209 
210  static std::string scopeName()
211  {
212  static std::string scope_name;
213  return scope_name;
214  }
215 
216  static void expose()
217  {
218 #if PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION == 6 && EIGENPY_VERSION_AT_LEAST(2, 9, 0)
219  typedef PINOCCHIO_SHARED_PTR_HOLDER_TYPE(SE3) HolderType;
220 #else
221  typedef ::boost::python::detail::not_specified HolderType;
222 #endif
223  bp::class_<SE3, HolderType>(
224  "SE3", "SE3 transformation defined by a 3d vector and a rotation matrix.",
225  bp::init<>(bp::arg("self"), "Default constructor."))
226  .def(SE3PythonVisitor<SE3>())
227  .def(CastVisitor<SE3>())
229  .def(CopyableVisitor<SE3>())
230  .def(bp::self_ns::str(bp::self_ns::self))
231  .def("__repr__", &repr);
232  }
233 
234  private:
235  static Matrix4 __array__(const SE3 & self, bp::object, bp::object)
236  {
237  return self.toHomogeneousMatrix();
238  }
239 
240  struct Pickle : bp::pickle_suite
241  {
242  static boost::python::tuple getinitargs(const SE3 & M)
243  {
244  return bp::make_tuple((Matrix3)M.rotation(), (Vector3)M.translation());
245  }
246 
247  static bool getstate_manages_dict()
248  {
249  return true;
250  }
251  };
252 
253  static void setIdentity(SE3 & self)
254  {
255  self.setIdentity();
256  }
257  static void setRandom(SE3 & self)
258  {
259  self.setRandom();
260  }
261 
262  template<typename Spatial>
263  static Spatial __mul__(const SE3 & self, const Spatial & other)
264  {
265  return self.act(other);
266  }
267 
268  static std::string repr(const SE3 & self)
269  {
270  // bp::object
271  // py_rotation(bp::handle<>(eigenpy::EigenToPy<Matrix3,Scalar>::convert(self.rotation())));
272  // std::string rotation_repr =
273  // bp::extract<std::string>(py_rotation.attr("__repr__")());
274  //
275  // bp::object
276  // py_translation(bp::handle<>(eigenpy::EigenToPy<Vector3,Scalar>::convert(self.translation())));
277  // std::string translation_repr =
278  // bp::extract<std::string>(py_translation.attr("__repr__")());
279 
280  bp::object py_homogeneous(
281  bp::handle<>(eigenpy::EigenToPy<Matrix4, Scalar>::convert(self.toHomogeneousMatrix())));
282  std::string homegeneous_repr = bp::extract<std::string>(py_homogeneous.attr("__repr__")());
283  replace(homegeneous_repr, "\n", "");
284  replace(homegeneous_repr, " ", "");
285 
286  std::stringstream ss_repr;
287  ss_repr << "SE3(";
288  ss_repr << homegeneous_repr;
289  ss_repr << ")";
290 
291  return ss_repr.str();
292  }
293  };
294 
295  } // namespace python
296 } // namespace pinocchio
297 
298 #endif // ifndef __pinocchio_python_spatial_se3_hpp__
pinocchio::InertiaTpl< Scalar, Options >
pinocchio::SE3Tpl< context::Scalar, context::Options >::Matrix4
traits< SE3Tpl >::Matrix4 Matrix4
Definition: spatial/se3-tpl.hpp:57
boost::python
pinocchio::python::SE3PythonVisitor::repr
static std::string repr(const SE3 &self)
Definition: bindings/python/spatial/se3.hpp:268
pinocchio::python::SE3PythonVisitor::Matrix3
SE3::Matrix3 Matrix3
Definition: bindings/python/spatial/se3.hpp:44
pinocchio::SE3Tpl< context::Scalar, context::Options >::Vector3
traits< SE3Tpl >::Vector3 Vector3
Definition: spatial/se3-tpl.hpp:55
PINOCCHIO_SHARED_PTR_HOLDER_TYPE
#define PINOCCHIO_SHARED_PTR_HOLDER_TYPE(T)
Definition: bindings/python/fwd.hpp:17
pinocchio::python::SE3PythonVisitor::ActionMatrixType
SE3::ActionMatrixType ActionMatrixType
Definition: bindings/python/spatial/se3.hpp:48
pinocchio::python::SE3PythonVisitor::Scalar
SE3::Scalar Scalar
Definition: bindings/python/spatial/se3.hpp:39
pinocchio::motionSet::act
static void act(const Eigen::MatrixBase< Mat > &iV, const ForceDense< ForceDerived > &f, Eigen::MatrixBase< MatRet > const &jF)
Action of a motion set on a force object. The input motion set is represented by a 6xN matrix whose e...
pinocchio::SE3Tpl::inverse
SE3Tpl inverse() const
aXb = bXa.inverse()
Definition: spatial/se3-tpl.hpp:149
pinocchio::python::SE3PythonVisitor::Vector3
SE3::Vector3 Vector3
Definition: bindings/python/spatial/se3.hpp:45
eigenpy.hpp
pinocchio::python::SE3PythonVisitor::Matrix4
SE3::Matrix4 Matrix4
Definition: bindings/python/spatial/se3.hpp:46
pinocchio::SE3Tpl
Definition: context/casadi.hpp:29
eigenpy::EigenToPy
simulation-closed-kinematic-chains.rotation
rotation
Definition: simulation-closed-kinematic-chains.py:26
inertia.hpp
pinocchio::python::SE3PythonVisitor::Force
ForceTpl< Scalar, Options > Force
Definition: bindings/python/spatial/se3.hpp:51
pinocchio::python::ExposeConstructorByCastVisitor
Definition: bindings/python/utils/cast.hpp:33
pinocchio::python::Scalar
context::Scalar Scalar
Definition: admm-solver.cpp:29
explog.hpp
motion.hpp
pinocchio::python::SE3PythonVisitor::Options
@ Options
Definition: bindings/python/spatial/se3.hpp:42
pinocchio::SE3Tpl< context::Scalar, context::Options >::Matrix3
traits< SE3Tpl >::Matrix3 Matrix3
Definition: spatial/se3-tpl.hpp:56
pinocchio::python::Options
@ Options
Definition: expose-contact-inverse-dynamics.cpp:22
pinocchio::python::SE3PythonVisitor::Pickle::getstate_manages_dict
static bool getstate_manages_dict()
Definition: bindings/python/spatial/se3.hpp:247
string.hpp
cast.hpp
EIGENPY_DEFINE_STRUCT_ALLOCATOR_SPECIALIZATION
#define EIGENPY_DEFINE_STRUCT_ALLOCATOR_SPECIALIZATION(...)
pinocchio::python::SE3PythonVisitor::setIdentity
static void setIdentity(SE3 &self)
Definition: bindings/python/spatial/se3.hpp:253
pinocchio::python::SE3PythonVisitor::expose
static void expose()
Definition: bindings/python/spatial/se3.hpp:216
pinocchio::python::SE3PythonVisitor
Definition: bindings/python/spatial/se3.hpp:37
python
se3.hpp
pinocchio::ForceTpl< Scalar, Options >
pinocchio::python::CopyableVisitor
Add the Python method copy to allow a copy of this by calling the copy constructor.
Definition: copyable.hpp:21
pinocchio::python::SE3PythonVisitor::scopeName
static std::string scopeName()
Definition: bindings/python/spatial/se3.hpp:210
pinocchio::python::SE3PythonVisitor::Pickle::getinitargs
static boost::python::tuple getinitargs(const SE3 &M)
Definition: bindings/python/spatial/se3.hpp:242
pinocchio::SE3Tpl::isIdentity
bool isIdentity(const Scalar &prec=Eigen::NumTraits< Scalar >::dummy_precision()) const
Definition: spatial/se3-tpl.hpp:347
pinocchio::python::SE3PythonVisitor::Inertia
InertiaTpl< Scalar, Options > Inertia
Definition: bindings/python/spatial/se3.hpp:52
M
M
pinocchio::python::CastVisitor
Add the Python method cast.
Definition: bindings/python/utils/cast.hpp:23
pinocchio::python::SE3PythonVisitor::Motion
MotionTpl< Scalar, Options > Motion
Definition: bindings/python/spatial/se3.hpp:50
copyable.hpp
pinocchio::SE3Tpl< context::Scalar, context::Options >::Quaternion
Eigen::Quaternion< Scalar, Options > Quaternion
Definition: spatial/se3-tpl.hpp:54
pinocchio::SE3Tpl::Random
static SE3Tpl Random()
Definition: spatial/se3-tpl.hpp:154
collision-with-point-clouds.translation
translation
Definition: collision-with-point-clouds.py:34
pinocchio::python::SE3PythonVisitor::__array__
static Matrix4 __array__(const SE3 &self, bp::object, bp::object)
Definition: bindings/python/spatial/se3.hpp:235
pinocchio::python::SE3PythonVisitor::Quaternion
SE3::Quaternion Quaternion
Definition: bindings/python/spatial/se3.hpp:47
pinocchio::SE3Tpl::Identity
static SE3Tpl Identity()
Definition: spatial/se3-tpl.hpp:136
pinocchio::replace
bool replace(std::string &input_str, const std::string &from, const std::string &to)
Replace string from with to in input_str.
Definition: string.hpp:22
cl
cl
pinocchio::python::SE3PythonVisitor::Pickle
Definition: bindings/python/spatial/se3.hpp:240
memory.hpp
printable.hpp
pinocchio::python::SE3PythonVisitor::__mul__
static Spatial __mul__(const SE3 &self, const Spatial &other)
Definition: bindings/python/spatial/se3.hpp:263
pinocchio::python::SE3PythonVisitor::setRandom
static void setRandom(SE3 &self)
Definition: bindings/python/spatial/se3.hpp:257
pinocchio::SE3
SE3Tpl< context::Scalar, context::Options > SE3
Definition: spatial/fwd.hpp:64
pinocchio::MotionTpl< Scalar, Options >
force.hpp
pinocchio::python::SE3PythonVisitor::visit
void visit(PyClass &cl) const
Definition: bindings/python/spatial/se3.hpp:56
pinocchio
Main pinocchio namespace.
Definition: timings.cpp:27
namespace.hpp


pinocchio
Author(s):
autogenerated on Thu Dec 19 2024 03:41:32