Go to the documentation of this file.
6 #ifndef __pinocchio_python_spatial_inertia_hpp__
7 #define __pinocchio_python_spatial_inertia_hpp__
12 #include <boost/python/tuple.hpp>
20 #if EIGENPY_VERSION_AT_MOST(2, 8, 1)
32 template<
typename Inertia>
41 typedef typename Inertia::Matrix3
Matrix3;
42 typedef typename Inertia::Vector6
Vector6;
43 typedef typename Inertia::Matrix6
Matrix6;
45 typedef Eigen::Matrix<Scalar, Eigen::Dynamic, 1, Options>
VectorXs;
50 template<
class PyClass>
53 static const Scalar dummy_precision = Eigen::NumTraits<Scalar>::dummy_precision();
58 bp::args(
"mass",
"lever",
"inertia")),
59 "Initialize from mass, lever and 3d inertia.")
61 .def(bp::init<>(bp::arg(
"self"),
"Default constructor."))
62 .def(bp::init<const Inertia &>((bp::arg(
"self"), bp::arg(
"clone")),
"Copy constructor"))
66 "Mass of the Spatial Inertia.")
71 bp::return_internal_reference<>()),
73 "Center of mass location of the Spatial Inertia. It corresponds to the location of the "
74 "center of mass regarding to the frame where the Spatial Inertia is expressed.")
77 "Rotational part of the Spatial Inertia, i.e. a symmetric matrix "
78 "representing the rotational inertia around the center of mass.")
80 .def(
"matrix", (
Matrix6(
Inertia::*)()
const)&Inertia::matrix, bp::arg(
"self"))
83 "se3Action", &Inertia::template se3Action<Scalar, Options>, bp::args(
"self",
"M"),
84 "Returns the result of the action of M on *this.")
86 "se3ActionInverse", &Inertia::template se3ActionInverse<Scalar, Options>,
87 bp::args(
"self",
"M"),
"Returns the result of the action of the inverse of M on *this.")
91 "Set *this to be the Identity inertia.")
94 "Set all the components of *this to zero.")
97 "Set all the components of *this to random values.")
99 .def(bp::self + bp::self)
100 .def(bp::self += bp::self)
101 .def(bp::self - bp::self)
102 .def(bp::self -= bp::self)
103 .def(bp::self * bp::other<Motion>())
105 .add_property(
"np", (
Matrix6(
Inertia::*)()
const)&Inertia::matrix)
107 "vxiv", &Inertia::template vxiv<Motion>, bp::args(
"self",
"v"),
108 "Returns the result of v x Iv.")
110 "vtiv", &Inertia::template vtiv<Motion>, bp::args(
"self",
"v"),
111 "Returns the result of v.T * Iv.")
115 bp::args(
"self",
"v"),
"Returns the result of v x* I, a 6x6 matrix.")
119 bp::args(
"self",
"v"),
"Returns the result of I vx, a 6x6 matrix.")
123 const)&Inertia::template variation<Motion>,
124 bp::args(
"self",
"v"),
"Returns the time derivative of the inertia.")
126 #ifndef PINOCCHIO_PYTHON_SKIP_COMPARISON_OPERATIONS
127 .def(bp::self == bp::self)
128 .def(bp::self != bp::self)
131 #ifndef PINOCCHIO_PYTHON_SKIP_COMPARISON_OPERATIONS
133 "isApprox", &Inertia::isApprox,
134 (bp::arg(
"self"), bp::arg(
"other"), bp::arg(
"prec") = dummy_precision),
135 "Returns true if *this is approximately equal to other, within the precision given "
139 "isZero", &
Inertia::isZero, (bp::arg(
"self"), bp::arg(
"prec") = dummy_precision),
140 "Returns true if *this is approximately equal to the zero Inertia, within the "
141 "precision given by prec.")
145 .staticmethod(
"Identity")
147 .staticmethod(
"Zero")
149 .staticmethod(
"Random")
154 "Returns the representation of the matrix as a vector of dynamic parameters."
155 "\nThe parameters are given as v = [m, mc_x, mc_y, mc_z, I_{xx}, I_{xy}, I_{yy}, "
156 "I_{xz}, I_{yz}, I_{zz}]^T "
157 "where I = I_C + mS^T(c)S(c) and I_C has its origin at the barycenter")
160 bp::args(
"dynamic_parameters"),
161 "Builds and inertia matrix from a vector of dynamic parameters."
162 "\nThe parameters are given as dynamic_parameters = [m, mc_x, mc_y, mc_z, I_{xx}, "
163 "I_{xy}, I_{yy}, I_{xz}, I_{yz}, I_{zz}]^T "
164 "where I = I_C + mS^T(c)S(c) and I_C has its origin at the barycenter.")
165 .staticmethod(
"FromDynamicParameters")
169 "Returns the Inertia of a sphere defined by a given mass and radius.")
170 .staticmethod(
"FromSphere")
173 bp::args(
"mass",
"length_x",
"length_y",
"length_z"),
174 "Returns the Inertia of an ellipsoid shape defined by a mass and given dimensions "
175 "the semi-axis of values length_{x,y,z}.")
176 .staticmethod(
"FromEllipsoid")
179 "Returns the Inertia of a cylinder defined by its mass, radius and length along the "
181 .staticmethod(
"FromCylinder")
183 "FromBox", &
Inertia::FromBox, bp::args(
"mass",
"length_x",
"length_y",
"length_z"),
184 "Returns the Inertia of a box shape with a mass and of dimension the semi axis of "
186 .staticmethod(
"FromBox")
189 "Computes the Inertia of a capsule defined by its mass, radius and length along the "
190 "Z axis. Assumes a uniform density.")
191 .staticmethod(
"FromCapsule")
195 "Returns the Inertia created from a pseudo inertia object.")
196 .staticmethod(
"FromPseudoInertia")
200 "Returns the pseudo inertia representation of the inertia.")
204 bp::args(
"log_cholesky_parameters"),
205 "Returns the Inertia created from log Cholesky parameters.")
206 .staticmethod(
"FromLogCholeskyParameters")
211 (bp::arg(
"self"), bp::arg(
"dtype") = bp::object(), bp::arg(
"copy") = bp::object()))
212 #ifndef PINOCCHIO_PYTHON_NO_SERIALIZATION
229 self.lever() = lever;
234 return self.inertia().matrix();
240 if (!check_expression_if_real<Scalar>(
241 isZero(symmetric_inertia - symmetric_inertia.transpose())))
243 self.inertia().data() << symmetric_inertia(0, 0), symmetric_inertia(1, 0),
244 symmetric_inertia(1, 1), symmetric_inertia(0, 2), symmetric_inertia(1, 2),
245 symmetric_inertia(2, 2);
250 return self.toDynamicParameters();
255 if (params.rows() != 10 || params.cols() != 1)
257 std::ostringstream shape;
258 shape <<
"(" << params.rows() <<
", " << params.cols() <<
")";
259 throw std::invalid_argument(
260 "Wrong size: params" + shape.str() +
" but should have the following shape (10, 1)");
268 #ifndef PINOCCHIO_PYTHON_SKIP_COMPARISON_OPERATIONS
269 if (!inertia.isApprox(inertia.transpose()))
272 (Vector3::UnitX().transpose() * inertia * Vector3::UnitX() < 0)
273 || (Vector3::UnitY().transpose() * inertia * Vector3::UnitY() < 0)
274 || (Vector3::UnitZ().transpose() * inertia * Vector3::UnitZ() < 0))
282 #if PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION == 6 && EIGENPY_VERSION_AT_LEAST(2, 9, 0)
285 typedef ::boost::python::detail::not_specified HolderType;
287 bp::class_<Inertia, HolderType>(
289 "This class represenses a sparse version of a Spatial Inertia and its is defined by its "
290 "mass, its center of mass location and the rotational inertia expressed around this "
291 "center of mass.\n\n"
292 "Supported operations ...",
304 return self.matrix();
322 template<
typename PseudoInertia>
324 :
public boost::python::def_visitor<PseudoInertiaPythonVisitor<PseudoInertia>>
335 typedef Eigen::Matrix<Scalar, Eigen::Dynamic, 1, Options>
VectorXs;
338 template<
class PyClass>
341 cl.def(bp::init<const Scalar &, const Vector3 &, const Matrix3 &>(
342 (bp::arg(
"self"), bp::arg(
"mass"), bp::arg(
"h"), bp::arg(
"sigma")),
343 "Initialize from mass, vector part of the pseudo inertia and matrix part of the "
345 .def(bp::init<const PseudoInertia &>(
346 (bp::arg(
"self"), bp::arg(
"clone")),
"Copy constructor"))
349 "Mass of the Pseudo Inertia.")
352 "Vector part of the Pseudo Inertia.")
355 "Matrix part of the Pseudo Inertia.")
359 "Returns the pseudo inertia as a 4x4 matrix.")
362 bp::arg(
"self"),
"Returns the dynamic parameters representation.")
365 "Returns the inertia representation.")
368 bp::args(
"dynamic_parameters"),
369 "Builds a pseudo inertia matrix from a vector of dynamic parameters."
370 "\nThe parameters are given as dynamic_parameters = [m, h_x, h_y, h_z, I_{xx}, "
371 "I_{xy}, I_{yy}, I_{xz}, I_{yz}, I_{zz}]^T.")
372 .staticmethod(
"FromDynamicParameters")
376 "Returns the Pseudo Inertia from a 4x4 matrix.")
377 .staticmethod(
"FromMatrix")
381 "Returns the Pseudo Inertia from an Inertia object.")
382 .staticmethod(
"FromInertia")
387 (bp::arg(
"self"), bp::arg(
"dtype") = bp::object(), bp::arg(
"copy") = bp::object()))
388 #ifndef PINOCCHIO_PYTHON_NO_SERIALIZATION
423 return self.toDynamicParameters();
428 if (params.rows() != 10 || params.cols() != 1)
430 std::ostringstream shape;
431 shape <<
"(" << params.rows() <<
", " << params.cols() <<
")";
432 throw std::invalid_argument(
433 "Wrong size: params" + shape.str() +
" but should have the following shape (10, 1)");
440 #if PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION == 6 && EIGENPY_VERSION_AT_LEAST(2, 9, 0)
443 typedef ::boost::python::detail::not_specified HolderType;
445 bp::class_<PseudoInertia, HolderType>(
447 "This class represents a pseudo inertia matrix and it is defined by its mass, vector "
448 "part, and 3x3 matrix part.\n\n"
449 "Supported operations ...",
461 return self.toMatrix();
468 return bp::make_tuple(pi.
mass, pi.
h, pi.
sigma);
479 template<
typename LogCholeskyParameters>
481 :
public boost::python::def_visitor<LogCholeskyParametersPythonVisitor<LogCholeskyParameters>>
490 typedef Eigen::Matrix<Scalar, Eigen::Dynamic, 1, Options>
VectorXs;
491 typedef Eigen::Matrix<Scalar, Eigen::Dynamic, Eigen::Dynamic, Options>
MatrixXs;
494 template<
class PyClass>
499 bp::make_constructor(
501 bp::args(
"log_cholesky_parameters")),
502 "Initialize from log cholesky parameters.")
503 .def(bp::init<const LogCholeskyParameters &>(
504 (bp::arg(
"self"), bp::arg(
"clone")),
"Copy constructor"))
512 bp::arg(
"self"),
"Returns the dynamic parameters representation.")
515 "Returns the Pseudo Inertia representation.")
518 "Returns the Inertia representation.")
521 bp::arg(
"self"),
"Calculates the Jacobian of the log Cholesky parameters.")
526 (bp::arg(
"self"), bp::arg(
"dtype") = bp::object(), bp::arg(
"copy") = bp::object()))
527 #ifndef PINOCCHIO_PYTHON_NO_SERIALIZATION
535 if (params.rows() != 10 || params.cols() != 1)
537 std::ostringstream shape;
538 shape <<
"(" << params.rows() <<
", " << params.cols() <<
")";
539 throw std::invalid_argument(
540 "Wrong size: params" + shape.str() +
" but should have the following shape (10, 1)");
547 return self.parameters;
551 self.parameters = parameters;
556 return self.toDynamicParameters();
561 return self.calculateJacobian();
566 #if PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION == 6 && EIGENPY_VERSION_AT_LEAST(2, 9, 0)
569 typedef ::boost::python::detail::not_specified HolderType;
571 bp::class_<LogCholeskyParameters, HolderType>(
572 "LogCholeskyParameters",
573 "This class represents log Cholesky parameters.\n\n"
574 "Supported operations ...",
587 return self.parameters;
608 #endif // ifndef __pinocchio_python_spatial_inertia_hpp__
A structure representing a pseudo inertia matrix.
static Inertia fromDynamicParameters_proxy(const VectorXs ¶ms)
static Inertia * makeFromMCI(const Scalar &mass, const Vector3 &lever, const Matrix3 &inertia)
Eigen::Matrix< Scalar, Eigen::Dynamic, 1, Options > VectorXs
static void setInertia(Inertia &self, const Matrix3 &symmetric_inertia)
static InertiaTpl FromEllipsoid(const Scalar mass, const Scalar x, const Scalar y, const Scalar z)
Computes the Inertia of an ellipsoid defined by its mass and main semi-axis dimensions (x,...
Vector3 h
Vector part of the pseudo inertia.
#define PINOCCHIO_SHARED_PTR_HOLDER_TYPE(T)
const Vector3 & lever() const
ForceTpl< Scalar, Options > Force
static PseudoInertia fromDynamicParameters_proxy(const VectorXs ¶ms)
void visit(PyClass &cl) const
Eigen::Matrix< Scalar, 10, 1, Options > Vector10
static Matrix3 getInertia(const Inertia &self)
Eigen::Matrix< Scalar, 10, 1, Options > Vector10
static bool getstate_manages_dict()
static Vector3 getH(const PseudoInertia &self)
bool isZero(const Eigen::MatrixBase< MatrixLike > &m, const typename MatrixLike::RealScalar &prec=Eigen::NumTraits< typename MatrixLike::Scalar >::dummy_precision())
PseudoInertia::Matrix4 Matrix4
static InertiaTpl FromPseudoInertia(const PseudoInertia &pseudo_inertia)
Create an InertiaTpl object from a PseudoInertia object.
PseudoInertia::Scalar Scalar
PseudoInertia::Vector3 Vector3
static VectorXs __array__(const LogCholeskyParameters &self, bp::object, bp::object)
InertiaTpl< context::Scalar, context::Options > Inertia
static MatrixXs calculateJacobian_proxy(const LogCholeskyParameters &self)
void visit(PyClass &cl) const
InertiaTpl< Scalar, Options > toInertia() const
Converts the PseudoInertiaTpl object to an InertiaTpl object.
PseudoInertia toPseudoInertia() const
Converts the LogCholeskyParametersTpl object to a PseudoInertiaTpl object.
Vector10 parameters
10-dimensional vector of log Cholesky parameters
static Matrix4 __array__(const PseudoInertia &self, bp::object, bp::object)
static VectorXs getParameters(const LogCholeskyParameters &self)
static boost::python::tuple getinitargs(const Inertia &I)
LogCholeskyParametersTpl< context::Scalar, context::Options > LogCholeskyParameters
Eigen::Matrix< Scalar, Eigen::Dynamic, 1, Options > VectorXs
Eigen::Matrix< Scalar, 3, 1, Options > Vector3
Eigen::Matrix< Scalar, 3, 3, Options > Matrix3
PseudoInertia toPseudoInertia() const
Convert the InertiaTpl object to a 4x4 pseudo inertia matrix.
static void setMass(PseudoInertia &self, Scalar mass)
Eigen::Matrix< Scalar, Eigen::Dynamic, Eigen::Dynamic, Options > MatrixXs
LogCholeskyParameters::Scalar Scalar
static VectorXs toDynamicParameters_proxy(const LogCholeskyParameters &self)
Matrix3 sigma
3x3 matrix part of the pseudo inertia
Scalar mass
Mass of the pseudo inertia.
const Symmetric3 & inertia() const
#define EIGENPY_DEFINE_STRUCT_ALLOCATOR_SPECIALIZATION(...)
Set the Python method str and repr to use the overloading operator<<.
static InertiaTpl FromLogCholeskyParameters(const LogCholeskyParameters &log_cholesky)
Create an InertiaTpl object from log Cholesky parameters.
MotionTpl< Scalar, Options > Motion
static boost::python::tuple getinitargs(const PseudoInertia &pi)
PseudoInertia::Matrix3 Matrix3
A structure representing log Cholesky parameters.
static void setMass(Inertia &self, Scalar mass)
InertiaTpl< Scalar, Options > toInertia() const
Converts the LogCholeskyParametersTpl object to an InertiaTpl object.
Eigen::Matrix< Scalar, 4, 4, Options > Matrix4
static boost::python::tuple getinitargs(const LogCholeskyParameters &lcp)
static Scalar getMass(const PseudoInertia &self)
Add the Python method copy to allow a copy of this by calling the copy constructor.
static InertiaTpl FromCapsule(const Scalar mass, const Scalar radius, const Scalar height)
Computes the Inertia of a capsule defined by its mass, radius and length along the Z axis....
static VectorXs toDynamicParameters_proxy(const Inertia &self)
void inverse(const Eigen::MatrixBase< MatrixIn > &m_in, const Eigen::MatrixBase< MatrixOut > &dest)
static InertiaTpl Random()
Eigen::Matrix< Scalar, 3, 1, Options > Vector3
static PseudoInertiaTpl FromInertia(const InertiaTpl< Scalar, Options > &inertia)
Constructs a PseudoInertiaTpl object from an InertiaTpl object.
static VectorXs toDynamicParameters_proxy(const PseudoInertia &self)
static void setLever(Inertia &self, const Vector3 &lever)
Add the Python method cast.
static PseudoInertiaTpl FromMatrix(const Matrix4 &pseudo_inertia)
Constructs a PseudoInertiaTpl object from a 4x4 pseudo inertia matrix.
static PseudoInertiaTpl FromDynamicParameters(const Eigen::MatrixBase< Vector10Like > &dynamic_params)
Constructs a PseudoInertiaTpl object from dynamic parameters.
static Scalar getMass(const Inertia &self)
LogCholeskyParameters::Matrix10 Matrix10
static Matrix3 getSigma(const PseudoInertia &self)
static InertiaTpl FromDynamicParameters(const Eigen::MatrixBase< Vector10Like > ¶ms)
static InertiaTpl Identity()
static bool getstate_manages_dict()
static void setParameters(LogCholeskyParameters &self, const Vector10 ¶meters)
Matrix4 toMatrix() const
Converts the PseudoInertiaTpl object to a 4x4 matrix.
static bool getstate_manages_dict()
static InertiaTpl FromBox(const Scalar mass, const Scalar x, const Scalar y, const Scalar z)
Computes the Inertia of a box defined by its mass and main dimensions (x,y,z).
static InertiaTpl FromSphere(const Scalar mass, const Scalar radius)
Computes the Inertia of a sphere defined by its mass and its radius.
static void setSigma(PseudoInertia &self, const Matrix3 &sigma)
PseudoInertia::Vector10 Vector10
void visit(PyClass &cl) const
Eigen::Matrix< Scalar, Eigen::Dynamic, 1, Options > VectorXs
static InertiaTpl FromCylinder(const Scalar mass, const Scalar radius, const Scalar length)
Computes the Inertia of a cylinder defined by its mass, radius and length along the Z axis.
Eigen::Matrix< Scalar, 10, 10, Options > Matrix10
static LogCholeskyParameters * makeFromParameters(const VectorXs ¶ms)
static void setH(PseudoInertia &self, const Vector3 &h)
LogCholeskyParameters::Vector10 Vector10
static Matrix6 __array__(const Inertia &self, bp::object, bp::object)
Main pinocchio namespace.
pinocchio
Author(s):
autogenerated on Tue Jan 7 2025 03:41:44