6 #ifndef __pinocchio_joint_translation_hpp__
7 #define __pinocchio_joint_translation_hpp__
9 #include "pinocchio/macros.hpp"
10 #include "pinocchio/multibody/joint/joint-base.hpp"
11 #include "pinocchio/multibody/constraint.hpp"
12 #include "pinocchio/spatial/inertia.hpp"
13 #include "pinocchio/spatial/skew.hpp"
21 template<
typename Scalar,
int Options>
27 template<
typename Scalar,
int Options,
typename MotionDerived>
33 template<
typename _Scalar,
int _Options>
36 typedef _Scalar Scalar;
37 enum { Options = _Options };
38 typedef Eigen::Matrix<Scalar,3,1,Options> Vector3;
39 typedef Eigen::Matrix<Scalar,6,1,Options> Vector6;
40 typedef Eigen::Matrix<Scalar,4,4,Options> Matrix4;
41 typedef Eigen::Matrix<Scalar,6,6,Options> Matrix6;
42 typedef typename PINOCCHIO_EIGEN_REF_CONST_TYPE(Vector6) ToVectorConstReturnType;
43 typedef typename PINOCCHIO_EIGEN_REF_TYPE(Vector6) ToVectorReturnType;
44 typedef Vector3 AngularType;
45 typedef Vector3 LinearType;
46 typedef const Vector3 ConstAngularType;
47 typedef const Vector3 ConstLinearType;
48 typedef Matrix6 ActionMatrixType;
49 typedef Matrix4 HomogeneousMatrixType;
58 template<
typename _Scalar,
int _Options>
60 :
MotionBase< MotionTranslationTpl<_Scalar,_Options> >
62 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
68 template<
typename Vector3Like>
69 MotionTranslationTpl(
const Eigen::MatrixBase<Vector3Like> & v)
73 MotionTranslationTpl(
const MotionTranslationTpl & other)
77 Vector3 & operator()() {
return m_v; }
78 const Vector3 & operator()()
const {
return m_v; }
80 inline PlainReturnType plain()
const
82 return PlainReturnType(m_v,PlainReturnType::Vector3::Zero());
85 bool isEqual_impl(
const MotionTranslationTpl & other)
const
87 return m_v == other.m_v;
90 MotionTranslationTpl & operator=(
const MotionTranslationTpl & other)
96 template<
typename Derived>
97 void addTo(MotionDense<Derived> & other)
const
99 other.linear() += m_v;
102 template<
typename Derived>
103 void setTo(MotionDense<Derived> & other)
const
105 other.linear() = m_v;
106 other.angular().setZero();
109 template<
typename S2,
int O2,
typename D2>
110 void se3Action_impl(
const SE3Tpl<S2,O2> & m, MotionDense<D2> & v)
const
112 v.angular().setZero();
113 v.linear().noalias() = m.rotation() * m_v;
116 template<
typename S2,
int O2>
117 MotionPlain se3Action_impl(
const SE3Tpl<S2,O2> & m)
const
120 se3Action_impl(m,res);
124 template<
typename S2,
int O2,
typename D2>
125 void se3ActionInverse_impl(
const SE3Tpl<S2,O2> & m, MotionDense<D2> & v)
const
128 v.linear().noalias() = m.rotation().transpose() * m_v;
131 v.angular().setZero();
134 template<
typename S2,
int O2>
135 MotionPlain se3ActionInverse_impl(
const SE3Tpl<S2,O2> & m)
const
138 se3ActionInverse_impl(m,res);
142 template<
typename M1,
typename M2>
143 void motionAction(
const MotionDense<M1> & v, MotionDense<M2> & mout)
const
146 mout.linear().noalias() = v.angular().cross(m_v);
149 mout.angular().setZero();
152 template<
typename M1>
153 MotionPlain motionAction(
const MotionDense<M1> & v)
const
160 const Vector3 & linear()
const {
return m_v; }
161 Vector3 & linear() {
return m_v; }
169 template<
typename S1,
int O1,
typename MotionDerived>
170 inline typename MotionDerived::MotionPlain
171 operator+(
const MotionTranslationTpl<S1,O1> & m1,
172 const MotionDense<MotionDerived> & m2)
174 return typename MotionDerived::MotionPlain(m2.linear() + m1.linear(), m2.angular());
179 template<
typename _Scalar,
int _Options>
187 typedef _Scalar Scalar;
189 typedef Eigen::Matrix<Scalar,3,1,Options> Vector3;
190 typedef Eigen::Matrix<Scalar,3,3,Options> Matrix3;
191 typedef typename Matrix3::IdentityReturnType AngularType;
192 typedef AngularType AngularRef;
193 typedef AngularType ConstAngularRef;
194 typedef Vector3 LinearType;
195 typedef LinearType & LinearRef;
196 typedef const LinearType & ConstLinearRef;
201 template<
typename Scalar,
int Options>
205 template<
typename _Scalar,
int _Options>
207 :
SE3Base< TransformTranslationTpl<_Scalar,_Options> >
209 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
215 template<
typename Vector3Like>
216 TransformTranslationTpl(
const Eigen::MatrixBase<Vector3Like> & translation)
217 : m_translation(translation)
220 PlainType plain()
const
222 PlainType res(PlainType::Identity());
223 res.rotation().setIdentity();
224 res.translation() = translation();
229 operator PlainType()
const {
return plain(); }
231 template<
typename S2,
int O2>
232 typename SE3GroupAction<TransformTranslationTpl>::ReturnType
233 se3action(
const SE3Tpl<S2,O2> & m)
const
235 typedef typename SE3GroupAction<TransformTranslationTpl>::ReturnType ReturnType;
237 res.translation() += translation();
242 ConstLinearRef translation()
const {
return m_translation; }
243 LinearRef translation() {
return m_translation; }
245 AngularType rotation()
const {
return AngularType(3,3); }
247 bool isEqual(
const TransformTranslationTpl & other)
const
249 return m_translation == other.m_translation;
254 LinearType m_translation;
259 template<
typename _Scalar,
int _Options>
262 typedef _Scalar Scalar;
264 enum { Options = _Options };
265 enum { LINEAR = 0, ANGULAR = 3 };
268 typedef Eigen::Matrix<Scalar,3,1,Options> JointForce;
269 typedef Eigen::Matrix<Scalar,6,3,Options> DenseBase;
271 typedef DenseBase MatrixReturnType;
272 typedef const DenseBase ConstMatrixReturnType;
275 template<
typename _Scalar,
int _Options>
279 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
285 ConstraintTranslationTpl() {}
291 template<
typename Vector3Like>
292 JointMotion __mult__(
const Eigen::MatrixBase<Vector3Like> & v)
const
294 EIGEN_STATIC_ASSERT_VECTOR_SPECIFIC_SIZE(Vector3Like,3);
295 return JointMotion(v);
298 int nv_impl()
const {
return NV; }
305 template<
typename Derived>
313 template<
typename MatrixDerived>
315 operator*(
const Eigen::MatrixBase<MatrixDerived> & F)
const
318 return F.derived().template middleRows<3>(LINEAR);
325 DenseBase matrix_impl()
const
328 S.template middleRows<3>(LINEAR).setIdentity();
329 S.template middleRows<3>(ANGULAR).setZero();
333 template<
typename S1,
int O1>
334 Eigen::Matrix<S1,6,3,O1> se3Action(
const SE3Tpl<S1,O1> & m)
const
336 Eigen::Matrix<S1,6,3,O1> M;
337 M.template middleRows<3>(LINEAR) = m.rotation();
338 M.template middleRows<3>(ANGULAR).setZero();
343 template<
typename S1,
int O1>
344 Eigen::Matrix<S1,6,3,O1> se3ActionInverse(
const SE3Tpl<S1,O1> & m)
const
346 Eigen::Matrix<S1,6,3,O1> M;
347 M.template middleRows<3>(LINEAR) = m.rotation().transpose();
348 M.template middleRows<3>(ANGULAR).setZero();
353 template<
typename MotionDerived>
354 DenseBase motionAction(
const MotionDense<MotionDerived> & m)
const
356 const typename MotionDerived::ConstAngularType w = m.angular();
359 skew(w,res.template middleRows<3>(LINEAR));
360 res.template middleRows<3>(ANGULAR).setZero();
365 bool isEqual(
const ConstraintTranslationTpl &)
const {
return true; }
369 template<
typename MotionDerived,
typename S2,
int O2>
370 inline typename MotionDerived::MotionPlain
371 operator^(
const MotionDense<MotionDerived> & m1,
372 const MotionTranslationTpl<S2,O2> & m2)
374 return m2.motionAction(m1);
378 template<
typename S1,
int O1,
typename S2,
int O2>
379 inline Eigen::Matrix<S2,6,3,O2>
381 const ConstraintTranslationTpl<S2,O2> &)
383 typedef ConstraintTranslationTpl<S2,O2> Constraint;
384 Eigen::Matrix<S2,6,3,O2> M;
385 alphaSkew(Y.mass(),Y.lever(),M.template middleRows<3>(Constraint::ANGULAR));
386 M.template middleRows<3>(Constraint::LINEAR).setZero();
387 M.template middleRows<3>(Constraint::LINEAR).diagonal().fill(Y.mass ());
393 template<
typename M6Like,
typename S2,
int O2>
394 inline const typename SizeDepType<3>::ColsReturn<M6Like>::ConstType
395 operator*(
const Eigen::MatrixBase<M6Like> & Y,
396 const ConstraintTranslationTpl<S2,O2> &)
398 typedef ConstraintTranslationTpl<S2,O2> Constraint;
399 return Y.derived().template middleCols<3>(Constraint::LINEAR);
402 template<
typename S1,
int O1>
404 {
typedef Eigen::Matrix<S1,6,3,O1> ReturnType; };
406 template<
typename S1,
int O1,
typename MotionDerived>
408 {
typedef Eigen::Matrix<S1,6,3,O1> ReturnType; };
412 template<
typename _Scalar,
int _Options>
419 typedef _Scalar Scalar;
420 enum { Options = _Options };
429 typedef Eigen::Matrix<Scalar,6,NV,Options> U_t;
430 typedef Eigen::Matrix<Scalar,NV,NV,Options> D_t;
431 typedef Eigen::Matrix<Scalar,6,NV,Options> UD_t;
433 PINOCCHIO_JOINT_DATA_BASE_ACCESSOR_DEFAULT_RETURN_TYPE
435 typedef Eigen::Matrix<Scalar,NQ,1,Options> ConfigVector_t;
436 typedef Eigen::Matrix<Scalar,NV,1,Options> TangentVector_t;
439 template<
typename Scalar,
int Options>
443 template<
typename Scalar,
int Options>
447 template<
typename _Scalar,
int _Options>
449 :
public JointDataBase< JointDataTranslationTpl<_Scalar,_Options> >
451 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
454 PINOCCHIO_JOINT_DATA_TYPEDEF_TEMPLATE(JointDerived);
455 PINOCCHIO_JOINT_DATA_BASE_DEFAULT_ACCESSOR
468 : M(Transformation_t::Vector3::Zero())
469 , v(Motion_t::Vector3::Zero())
472 , UDinv(UD_t::Zero())
475 static std::string classname() {
return std::string(
"JointDataTranslation"); }
476 std::string shortname()
const {
return classname(); }
479 PINOCCHIO_JOINT_CAST_TYPE_SPECIALIZATION(JointModelTranslationTpl);
480 template<
typename _Scalar,
int _Options>
481 struct JointModelTranslationTpl
482 :
public JointModelBase< JointModelTranslationTpl<_Scalar,_Options> >
484 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
486 typedef JointTranslationTpl<_Scalar,_Options> JointDerived;
487 PINOCCHIO_JOINT_TYPEDEF_TEMPLATE(JointDerived);
489 typedef JointModelBase<JointModelTranslationTpl> Base;
493 using Base::setIndexes;
495 JointDataDerived createData()
const {
return JointDataDerived(); }
497 const std::vector<bool> hasConfigurationLimit()
const
499 return {
true,
true,
true};
502 const std::vector<bool> hasConfigurationLimitInTangent()
const
504 return {
true,
true,
true};
507 template<
typename ConfigVector>
508 void calc(JointDataDerived & data,
509 const typename Eigen::MatrixBase<ConfigVector> & qs)
const
511 data.M.translation() = this->jointConfigSelector(qs);
514 template<
typename ConfigVector,
typename TangentVector>
515 void calc(JointDataDerived & data,
516 const typename Eigen::MatrixBase<ConfigVector> & qs,
517 const typename Eigen::MatrixBase<TangentVector> & vs)
const
519 calc(data,qs.derived());
521 data.v.linear() = this->jointVelocitySelector(vs);
524 template<
typename Matrix6Like>
525 void calc_aba(JointDataDerived & data,
526 const Eigen::MatrixBase<Matrix6Like> & I,
527 const bool update_I)
const
529 data.U = I.template middleCols<3>(Inertia::LINEAR);
534 internal::PerformStYSInversion<Scalar>::run(data.U.template middleRows<3>(Inertia::LINEAR),data.Dinv);
536 data.UDinv.template middleRows<3>(Inertia::LINEAR).setIdentity();
537 data.UDinv.template middleRows<3>(Inertia::ANGULAR).noalias() = data.U.template middleRows<3>(Inertia::ANGULAR) * data.Dinv;
541 Matrix6Like & I_ = PINOCCHIO_EIGEN_CONST_CAST(Matrix6Like,I);
542 I_.template block<3,3>(Inertia::ANGULAR,Inertia::ANGULAR)
543 -= data.UDinv.template middleRows<3>(Inertia::ANGULAR) * I_.template block<3,3>(Inertia::LINEAR, Inertia::ANGULAR);
544 I_.template middleCols<3>(Inertia::LINEAR).setZero();
545 I_.template block<3,3>(Inertia::LINEAR,Inertia::ANGULAR).setZero();
549 static std::string classname() {
return std::string(
"JointModelTranslation"); }
550 std::string shortname()
const {
return classname(); }
553 template<
typename NewScalar>
566 #include <boost/type_traits.hpp>
570 template<
typename Scalar,
int Options>
572 :
public integral_constant<bool,true> {};
574 template<
typename Scalar,
int Options>
576 :
public integral_constant<bool,true> {};
578 template<
typename Scalar,
int Options>
580 :
public integral_constant<bool,true> {};
582 template<
typename Scalar,
int Options>
584 :
public integral_constant<bool,true> {};
587 #endif // ifndef __pinocchio_joint_translation_hpp__