joint-translation.hpp
Go to the documentation of this file.
1 //
2 // Copyright (c) 2015-2019 CNRS INRIA
3 // Copyright (c) 2015-2016 Wandercraft, 86 rue de Paris 91400 Orsay, France.
4 //
5 
6 #ifndef __pinocchio_joint_translation_hpp__
7 #define __pinocchio_joint_translation_hpp__
8 
9 #include "pinocchio/macros.hpp"
14 
15 namespace pinocchio
16 {
17 
18  template<typename Scalar, int Options=0> struct MotionTranslationTpl;
20 
21  template<typename Scalar, int Options>
23  {
25  };
26 
27  template<typename Scalar, int Options, typename MotionDerived>
29  {
31  };
32 
33  template<typename _Scalar, int _Options>
34  struct traits< MotionTranslationTpl<_Scalar,_Options> >
35  {
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;
46  typedef const Vector3 ConstAngularType;
47  typedef const Vector3 ConstLinearType;
52  enum {
53  LINEAR = 0,
54  ANGULAR = 3
55  };
56  }; // traits MotionTranslationTpl
57 
58  template<typename _Scalar, int _Options>
59  struct MotionTranslationTpl
60  : MotionBase< MotionTranslationTpl<_Scalar,_Options> >
61  {
62  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
63 
65 
67 
68  template<typename Vector3Like>
69  MotionTranslationTpl(const Eigen::MatrixBase<Vector3Like> & v)
70  : m_v(v)
71  {}
72 
74  : m_v(other.m_v)
75  {}
76 
77  Vector3 & operator()() { return m_v; }
78  const Vector3 & operator()() const { return m_v; }
79 
80  inline PlainReturnType plain() const
81  {
82  return PlainReturnType(m_v,PlainReturnType::Vector3::Zero());
83  }
84 
85  bool isEqual_impl(const MotionTranslationTpl & other) const
86  {
87  return m_v == other.m_v;
88  }
89 
91  {
92  m_v = other.m_v;
93  return *this;
94  }
95 
96  template<typename Derived>
97  void addTo(MotionDense<Derived> & other) const
98  {
99  other.linear() += m_v;
100  }
101 
102  template<typename Derived>
103  void setTo(MotionDense<Derived> & other) const
104  {
105  other.linear() = m_v;
106  other.angular().setZero();
107  }
108 
109  template<typename S2, int O2, typename D2>
111  {
112  v.angular().setZero();
113  v.linear().noalias() = m.rotation() * m_v; // TODO: check efficiency
114  }
115 
116  template<typename S2, int O2>
117  MotionPlain se3Action_impl(const SE3Tpl<S2,O2> & m) const
118  {
119  MotionPlain res;
121  return res;
122  }
123 
124  template<typename S2, int O2, typename D2>
126  {
127  // Linear
128  v.linear().noalias() = m.rotation().transpose() * m_v;
129 
130  // Angular
131  v.angular().setZero();
132  }
133 
134  template<typename S2, int O2>
135  MotionPlain se3ActionInverse_impl(const SE3Tpl<S2,O2> & m) const
136  {
137  MotionPlain res;
139  return res;
140  }
141 
142  template<typename M1, typename M2>
143  void motionAction(const MotionDense<M1> & v, MotionDense<M2> & mout) const
144  {
145  // Linear
146  mout.linear().noalias() = v.angular().cross(m_v);
147 
148  // Angular
149  mout.angular().setZero();
150  }
151 
152  template<typename M1>
153  MotionPlain motionAction(const MotionDense<M1> & v) const
154  {
155  MotionPlain res;
156  motionAction(v,res);
157  return res;
158  }
159 
160  const Vector3 & linear() const { return m_v; }
161  Vector3 & linear() { return m_v; }
162 
163  protected:
164 
165  Vector3 m_v;
166 
167  }; // struct MotionTranslationTpl
168 
169  template<typename S1, int O1, typename MotionDerived>
170  inline typename MotionDerived::MotionPlain
172  const MotionDense<MotionDerived> & m2)
173  {
174  return typename MotionDerived::MotionPlain(m2.linear() + m1.linear(), m2.angular());
175  }
176 
177  template<typename Scalar, int Options> struct TransformTranslationTpl;
178 
179  template<typename _Scalar, int _Options>
180  struct traits< TransformTranslationTpl<_Scalar,_Options> >
181  {
182  enum {
183  Options = _Options,
184  LINEAR = 0,
185  ANGULAR = 3
186  };
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;
196  typedef const LinearType & ConstLinearRef;
199  }; // traits TransformTranslationTpl
200 
201  template<typename Scalar, int Options>
204 
205  template<typename _Scalar, int _Options>
207  : SE3Base< TransformTranslationTpl<_Scalar,_Options> >
208  {
209  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
212 
214 
215  template<typename Vector3Like>
216  TransformTranslationTpl(const Eigen::MatrixBase<Vector3Like> & translation)
218  {}
219 
220  PlainType plain() const
221  {
222  PlainType res(PlainType::Identity());
223  res.rotation().setIdentity();
224  res.translation() = translation();
225 
226  return res;
227  }
228 
229  operator PlainType() const { return plain(); }
230 
231  template<typename S2, int O2>
233  se3action(const SE3Tpl<S2,O2> & m) const
234  {
235  typedef typename SE3GroupAction<TransformTranslationTpl>::ReturnType ReturnType;
236  ReturnType res(m);
237  res.translation() += translation();
238 
239  return res;
240  }
241 
242  ConstLinearRef translation() const { return m_translation; }
243  LinearRef translation() { return m_translation; }
244 
245  AngularType rotation() const { return AngularType(3,3); }
246 
247  bool isEqual(const TransformTranslationTpl & other) const
248  {
249  return m_translation == other.m_translation;
250  }
251 
252  protected:
253 
254  LinearType m_translation;
255  };
256 
257  template<typename Scalar, int Options> struct ConstraintTranslationTpl;
258 
259  template<typename _Scalar, int _Options>
260  struct traits< ConstraintTranslationTpl<_Scalar,_Options> >
261  {
262  typedef _Scalar Scalar;
263 
264  enum { Options = _Options };
265  enum { LINEAR = 0, ANGULAR = 3 };
266 
268  typedef Eigen::Matrix<Scalar,3,1,Options> JointForce;
269  typedef Eigen::Matrix<Scalar,6,3,Options> DenseBase;
270 
273  }; // traits ConstraintTranslationTpl
274 
275  template<typename _Scalar, int _Options>
277  : ConstraintBase< ConstraintTranslationTpl<_Scalar,_Options> >
278  {
279  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
280 
282 
283  enum { NV = 3 };
284 
286 
287 // template<typename S1, int O1>
288 // Motion operator*(const MotionTranslationTpl<S1,O1> & vj) const
289 // { return Motion(vj(), Motion::Vector3::Zero()); }
290 
291  template<typename Vector3Like>
292  JointMotion __mult__(const Eigen::MatrixBase<Vector3Like> & v) const
293  {
294  EIGEN_STATIC_ASSERT_VECTOR_SPECIFIC_SIZE(Vector3Like,3);
295  return JointMotion(v);
296  }
297 
298  int nv_impl() const { return NV; }
299 
301  {
304 
305  template<typename Derived>
308  {
309  return phi.linear();
310  }
311 
312  /* [CRBA] MatrixBase operator* (Constraint::Transpose S, ForceSet::Block) */
313  template<typename MatrixDerived>
314  const typename SizeDepType<3>::RowsReturn<MatrixDerived>::ConstType
315  operator*(const Eigen::MatrixBase<MatrixDerived> & F) const
316  {
317  assert(F.rows()==6);
318  return F.derived().template middleRows<3>(LINEAR);
319  }
320 
321  }; // struct ConstraintTranspose
322 
324 
325  DenseBase matrix_impl() const
326  {
327  DenseBase S;
328  S.template middleRows<3>(LINEAR).setIdentity();
329  S.template middleRows<3>(ANGULAR).setZero();
330  return S;
331  }
332 
333  template<typename S1, int O1>
334  Eigen::Matrix<S1,6,3,O1> se3Action(const SE3Tpl<S1,O1> & m) const
335  {
336  Eigen::Matrix<S1,6,3,O1> M;
337  M.template middleRows<3>(LINEAR) = m.rotation();
338  M.template middleRows<3>(ANGULAR).setZero();
339 
340  return M;
341  }
342 
343  template<typename S1, int O1>
344  Eigen::Matrix<S1,6,3,O1> se3ActionInverse(const SE3Tpl<S1,O1> & m) const
345  {
346  Eigen::Matrix<S1,6,3,O1> M;
347  M.template middleRows<3>(LINEAR) = m.rotation().transpose();
348  M.template middleRows<3>(ANGULAR).setZero();
349 
350  return M;
351  }
352 
353  template<typename MotionDerived>
354  DenseBase motionAction(const MotionDense<MotionDerived> & m) const
355  {
356  const typename MotionDerived::ConstAngularType w = m.angular();
357 
358  DenseBase res;
359  skew(w,res.template middleRows<3>(LINEAR));
360  res.template middleRows<3>(ANGULAR).setZero();
361 
362  return res;
363  }
364 
365  bool isEqual(const ConstraintTranslationTpl &) const { return true; }
366 
367  }; // struct ConstraintTranslationTpl
368 
369  template<typename MotionDerived, typename S2, int O2>
370  inline typename MotionDerived::MotionPlain
372  const MotionTranslationTpl<S2,O2> & m2)
373  {
374  return m2.motionAction(m1);
375  }
376 
377  /* [CRBA] ForceSet operator* (Inertia Y,Constraint S) */
378  template<typename S1, int O1, typename S2, int O2>
379  inline Eigen::Matrix<S2,6,3,O2>
382  {
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 ());
388 
389  return M;
390  }
391 
392  /* [ABA] Y*S operator*/
393  template<typename M6Like, typename S2, int O2>
394  inline const typename SizeDepType<3>::ColsReturn<M6Like>::ConstType
395  operator*(const Eigen::MatrixBase<M6Like> & Y,
397  {
398  typedef ConstraintTranslationTpl<S2,O2> Constraint;
399  return Y.derived().template middleCols<3>(Constraint::LINEAR);
400  }
401 
402  template<typename S1, int O1>
404  { typedef Eigen::Matrix<S1,6,3,O1> ReturnType; };
405 
406  template<typename S1, int O1, typename MotionDerived>
407  struct MotionAlgebraAction< ConstraintTranslationTpl<S1,O1>,MotionDerived >
408  { typedef Eigen::Matrix<S1,6,3,O1> ReturnType; };
409 
410  template<typename Scalar, int Options> struct JointTranslationTpl;
411 
412  template<typename _Scalar, int _Options>
413  struct traits< JointTranslationTpl<_Scalar,_Options> >
414  {
415  enum {
416  NQ = 3,
417  NV = 3
418  };
419  typedef _Scalar Scalar;
420  enum { Options = _Options };
427 
428  // [ABA]
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;
432 
434 
435  typedef Eigen::Matrix<Scalar,NQ,1,Options> ConfigVector_t;
436  typedef Eigen::Matrix<Scalar,NV,1,Options> TangentVector_t;
437  }; // traits JointTranslationTpl
438 
439  template<typename Scalar, int Options>
442 
443  template<typename Scalar, int Options>
446 
447  template<typename _Scalar, int _Options>
449  : public JointDataBase< JointDataTranslationTpl<_Scalar,_Options> >
450  {
451  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
452 
456 
457  Constraint_t S;
458  Transformation_t M;
459  Motion_t v;
460  Bias_t c;
461 
462  // [ABA] specific data
463  U_t U;
464  D_t Dinv;
465  UD_t UDinv;
466 
468  : M(Transformation_t::Vector3::Zero())
469  , v(Motion_t::Vector3::Zero())
470  , U(U_t::Zero())
471  , Dinv(D_t::Zero())
472  , UDinv(UD_t::Zero())
473  {}
474 
475  static std::string classname() { return std::string("JointDataTranslation"); }
476  std::string shortname() const { return classname(); }
477  }; // struct JointDataTranslationTpl
478 
479  PINOCCHIO_JOINT_CAST_TYPE_SPECIALIZATION(JointModelTranslationTpl);
480  template<typename _Scalar, int _Options>
481  struct JointModelTranslationTpl
482  : public JointModelBase< JointModelTranslationTpl<_Scalar,_Options> >
483  {
484  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
485 
488 
490  using Base::id;
491  using Base::idx_q;
492  using Base::idx_v;
493  using Base::setIndexes;
494 
495  JointDataDerived createData() const { return JointDataDerived(); }
496 
497  const std::vector<bool> hasConfigurationLimit() const
498  {
499  return {true, true, true};
500  }
501 
502  const std::vector<bool> hasConfigurationLimitInTangent() const
503  {
504  return {true, true, true};
505  }
506 
507  template<typename ConfigVector>
508  void calc(JointDataDerived & data,
509  const typename Eigen::MatrixBase<ConfigVector> & qs) const
510  {
511  data.M.translation() = this->jointConfigSelector(qs);
512  }
513 
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
518  {
519  calc(data,qs.derived());
520 
521  data.v.linear() = this->jointVelocitySelector(vs);
522  }
523 
524  template<typename Matrix6Like>
525  void calc_aba(JointDataDerived & data,
526  const Eigen::MatrixBase<Matrix6Like> & I,
527  const bool update_I) const
528  {
529  data.U = I.template middleCols<3>(Inertia::LINEAR);
530 
531  // compute inverse
532 // data.Dinv.setIdentity();
533 // data.U.template middleRows<3>(Inertia::LINEAR).llt().solveInPlace(data.Dinv);
534  internal::PerformStYSInversion<Scalar>::run(data.U.template middleRows<3>(Inertia::LINEAR),data.Dinv);
535 
536  data.UDinv.template middleRows<3>(Inertia::LINEAR).setIdentity(); // can be put in data constructor
537  data.UDinv.template middleRows<3>(Inertia::ANGULAR).noalias() = data.U.template middleRows<3>(Inertia::ANGULAR) * data.Dinv;
538 
539  if (update_I)
540  {
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();
546  }
547  }
548 
549  static std::string classname() { return std::string("JointModelTranslation"); }
550  std::string shortname() const { return classname(); }
551 
553  template<typename NewScalar>
555  {
557  ReturnType res;
558  res.setIndexes(id(),idx_q(),idx_v());
559  return res;
560  }
561 
562  }; // struct JointModelTranslationTpl
563 
564 } // namespace pinocchio
565 
566 #include <boost/type_traits.hpp>
567 
568 namespace boost
569 {
570  template<typename Scalar, int Options>
571  struct has_nothrow_constructor< ::pinocchio::JointModelTranslationTpl<Scalar,Options> >
572  : public integral_constant<bool,true> {};
573 
574  template<typename Scalar, int Options>
575  struct has_nothrow_copy< ::pinocchio::JointModelTranslationTpl<Scalar,Options> >
576  : public integral_constant<bool,true> {};
577 
578  template<typename Scalar, int Options>
579  struct has_nothrow_constructor< ::pinocchio::JointDataTranslationTpl<Scalar,Options> >
580  : public integral_constant<bool,true> {};
581 
582  template<typename Scalar, int Options>
583  struct has_nothrow_copy< ::pinocchio::JointDataTranslationTpl<Scalar,Options> >
584  : public integral_constant<bool,true> {};
585 }
586 
587 #endif // ifndef __pinocchio_joint_translation_hpp__
pinocchio::JointTranslationTpl
Definition: joint-translation.hpp:410
pinocchio::TransformTranslationTpl::plain
PlainType plain() const
Definition: joint-translation.hpp:220
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::ConstAngularType
const typedef Vector3 ConstAngularType
Definition: joint-translation.hpp:46
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::HomogeneousMatrixType
traits< PlainType >::HomogeneousMatrixType HomogeneousMatrixType
Definition: joint-translation.hpp:198
m
float m
pinocchio::ConstraintTranslationTpl::ConstraintTranspose
Definition: joint-translation.hpp:300
pinocchio::MotionTranslationTpl::se3Action_impl
MotionPlain se3Action_impl(const SE3Tpl< S2, O2 > &m) const
Definition: joint-translation.hpp:117
PINOCCHIO_JOINT_DATA_BASE_ACCESSOR_DEFAULT_RETURN_TYPE
#define PINOCCHIO_JOINT_DATA_BASE_ACCESSOR_DEFAULT_RETURN_TYPE
Definition: joint-data-base.hpp:62
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::UD_t
Eigen::Matrix< Scalar, 6, NV, Options > UD_t
Definition: joint-translation.hpp:431
pinocchio::ConstraintTranslationTpl::isEqual
bool isEqual(const ConstraintTranslationTpl &) const
Definition: joint-translation.hpp:365
pinocchio::ConstraintTranslationTpl::ConstraintTranspose::ref
const ConstraintTranslationTpl & ref
Definition: joint-translation.hpp:302
pinocchio::ForceDense::linear
ConstLinearType linear() const
Return the linear part of the force vector.
Definition: force-base.hpp:42
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::AngularType
Matrix3::IdentityReturnType AngularType
Definition: joint-translation.hpp:191
pinocchio::TransformTranslationTpl::translation
LinearRef translation()
Definition: joint-translation.hpp:243
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::Vector3
Eigen::Matrix< Scalar, 3, 1, Options > Vector3
Definition: joint-translation.hpp:189
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::AngularType
Vector3 AngularType
Definition: joint-translation.hpp:44
pinocchio::TransformTranslationTpl::se3action
SE3GroupAction< TransformTranslationTpl >::ReturnType se3action(const SE3Tpl< S2, O2 > &m) const
Definition: joint-translation.hpp:233
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::Vector6
Eigen::Matrix< Scalar, 6, 1, Options > Vector6
Definition: joint-translation.hpp:39
pinocchio::SE3GroupAction< MotionTranslationTpl< Scalar, Options > >::ReturnType
MotionTpl< Scalar, Options > ReturnType
Definition: joint-translation.hpp:24
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::JointModelDerived
JointModelTranslationTpl< Scalar, Options > JointModelDerived
Definition: joint-translation.hpp:422
macros.hpp
pinocchio::operator*
MultiplicationOp< InertiaTpl< Scalar, Options >, ConstraintDerived >::ReturnType operator*(const InertiaTpl< Scalar, Options > &Y, const ConstraintBase< ConstraintDerived > &constraint)
&#160;
Definition: constraint-base.hpp:112
pinocchio::idx_q
int idx_q(const JointModelTpl< Scalar, Options, JointCollectionTpl > &jmodel)
Visit a JointModelTpl through JointIdxQVisitor to get the index in the full model configuration space...
pinocchio::traits< ConstraintTranslationTpl< _Scalar, _Options > >::MatrixReturnType
DenseBase MatrixReturnType
Definition: joint-translation.hpp:271
pinocchio::JointModelTranslationTpl::calc_aba
void calc_aba(JointDataDerived &data, const Eigen::MatrixBase< Matrix6Like > &I, const bool update_I) const
Definition: joint-translation.hpp:525
pinocchio::JointModelBase
Definition: joint-model-base.hpp:67
pinocchio::JointDataTranslationTpl::JointDataTranslationTpl
JointDataTranslationTpl()
Definition: joint-translation.hpp:467
pinocchio::MotionTranslationTpl::setTo
void setTo(MotionDense< Derived > &other) const
Definition: joint-translation.hpp:103
pinocchio::MotionTranslationTpl::linear
const Vector3 & linear() const
Definition: joint-translation.hpp:160
pinocchio::idx_v
int idx_v(const JointModelTpl< Scalar, Options, JointCollectionTpl > &jmodel)
Visit a JointModelTpl through JointIdxVVisitor to get the index in the full model tangent space corre...
pinocchio::Options
Options
Definition: joint-configuration.hpp:746
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::ConstAngularRef
AngularType ConstAngularRef
Definition: joint-translation.hpp:193
pinocchio::MotionTranslationTpl::plain
PlainReturnType plain() const
Definition: joint-translation.hpp:80
pinocchio::MotionTranslationTpl::MotionTranslationTpl
MotionTranslationTpl(const Eigen::MatrixBase< Vector3Like > &v)
Definition: joint-translation.hpp:69
PINOCCHIO_EIGEN_CONST_CAST
#define PINOCCHIO_EIGEN_CONST_CAST(TYPE, OBJ)
Macro for an automatic const_cast.
Definition: eigen-macros.hpp:43
pinocchio::SE3Tpl
Definition: spatial/fwd.hpp:38
pinocchio::JointModelTranslationTpl::calc
void calc(JointDataDerived &data, const typename Eigen::MatrixBase< ConfigVector > &qs) const
Definition: joint-translation.hpp:508
pinocchio::JointDataTranslationTpl::shortname
std::string shortname() const
Definition: joint-translation.hpp:476
pinocchio::internal::PerformStYSInversion::run
static EIGEN_STRONG_INLINE void run(const Eigen::MatrixBase< M1 > &StYS, const Eigen::MatrixBase< M2 > &Dinv)
Definition: joint-common-operations.hpp:25
pinocchio::SE3GroupAction::ReturnType
D ReturnType
Definition: spatial/se3.hpp:39
pinocchio::JointDataBase
Definition: joint-data-base.hpp:82
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::Matrix3
Eigen::Matrix< Scalar, 3, 3, Options > Matrix3
Definition: joint-translation.hpp:190
pinocchio::MotionTranslationTpl::operator()
Vector3 & operator()()
Definition: joint-translation.hpp:77
pinocchio::traits< ConstraintTranslationTpl< _Scalar, _Options > >::DenseBase
Eigen::Matrix< Scalar, 6, 3, Options > DenseBase
Definition: joint-translation.hpp:269
pinocchio::JointDataTranslationTpl::JointDerived
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef JointTranslationTpl< _Scalar, _Options > JointDerived
Definition: joint-translation.hpp:453
pinocchio::PINOCCHIO_EIGEN_REF_CONST_TYPE
PINOCCHIO_EIGEN_REF_CONST_TYPE(Matrix6Like) operator*(const Eigen
Definition: joint-free-flyer.hpp:122
pinocchio::MotionTranslationTpl::se3Action_impl
void se3Action_impl(const SE3Tpl< S2, O2 > &m, MotionDense< D2 > &v) const
Definition: joint-translation.hpp:110
setup.data
data
Definition: cmake/cython/setup.in.py:48
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::LinearRef
LinearType & LinearRef
Definition: joint-translation.hpp:195
inertia.hpp
pinocchio::MotionDense
Definition: spatial/fwd.hpp:41
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::LinearType
Vector3 LinearType
Definition: joint-translation.hpp:194
boost
pinocchio::MotionAlgebraAction< ConstraintTranslationTpl< S1, O1 >, MotionDerived >::ReturnType
Eigen::Matrix< S1, 6, 3, O1 > ReturnType
Definition: joint-translation.hpp:408
pinocchio::MotionTranslationTpl::MotionTranslationTpl
MotionTranslationTpl()
Definition: joint-translation.hpp:66
pinocchio::MotionTranslationTpl::operator=
MotionTranslationTpl & operator=(const MotionTranslationTpl &other)
Definition: joint-translation.hpp:90
pinocchio::traits< ConstraintTranslationTpl< _Scalar, _Options > >::Scalar
_Scalar Scalar
Definition: joint-translation.hpp:262
pinocchio::TransformTranslationTpl::TransformTranslationTpl
TransformTranslationTpl()
Definition: joint-translation.hpp:213
pinocchio::JointModelBase::setIndexes
void setIndexes(JointIndex id, int q, int v)
Definition: joint-model-base.hpp:127
pinocchio::ConstraintTranslationTpl::ConstraintTranslationTpl
ConstraintTranslationTpl()
Definition: joint-translation.hpp:285
pinocchio::TransformTranslationTpl::m_translation
LinearType m_translation
Definition: joint-translation.hpp:254
pinocchio::JointModelTranslationTpl
Definition: multibody/joint/fwd.hpp:75
pinocchio::JointDataTranslationTpl::Dinv
D_t Dinv
Definition: joint-translation.hpp:464
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::Scalar
_Scalar Scalar
Definition: joint-translation.hpp:187
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::Scalar
_Scalar Scalar
Definition: joint-translation.hpp:419
pinocchio::MotionAlgebraAction
Return type of the ation of a Motion onto an object of type D.
Definition: spatial/motion.hpp:46
pinocchio::JointModelTranslationTpl::createData
JointDataDerived createData() const
Definition: joint-translation.hpp:495
pinocchio::MotionDense::linear
ConstLinearType linear() const
Definition: motion-base.hpp:22
pinocchio::ConstraintTranslationTpl::ConstraintTranspose::operator*
ForceDense< Derived >::ConstLinearType operator*(const ForceDense< Derived > &phi)
Definition: joint-translation.hpp:307
pinocchio::SE3GroupAction
Definition: spatial/se3.hpp:39
pinocchio::MotionTranslationTpl::MotionTranslationTpl
MotionTranslationTpl(const MotionTranslationTpl &other)
Definition: joint-translation.hpp:73
skew.hpp
pinocchio::MotionZeroTpl
Definition: spatial/fwd.hpp:44
PINOCCHIO_JOINT_DATA_BASE_DEFAULT_ACCESSOR
#define PINOCCHIO_JOINT_DATA_BASE_DEFAULT_ACCESSOR
Definition: joint-data-base.hpp:46
pinocchio::MotionTranslationTpl::se3ActionInverse_impl
void se3ActionInverse_impl(const SE3Tpl< S2, O2 > &m, MotionDense< D2 > &v) const
Definition: joint-translation.hpp:125
pinocchio::JointModelTranslationTpl::hasConfigurationLimitInTangent
const std::vector< bool > hasConfigurationLimitInTangent() const
Definition: joint-translation.hpp:502
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::MotionPlain
MotionTpl< Scalar, Options > MotionPlain
Definition: joint-translation.hpp:50
res
res
pinocchio::JointDataTranslationTpl
Definition: multibody/joint/fwd.hpp:78
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::Vector3
Eigen::Matrix< Scalar, 3, 1, Options > Vector3
Definition: joint-translation.hpp:38
pinocchio::JointDataTranslationTpl::UDinv
UD_t UDinv
Definition: joint-translation.hpp:465
pinocchio::SizeDepType::RowsReturn
Definition: matrix-block.hpp:70
pinocchio::traits< ConstraintTranslationTpl< _Scalar, _Options > >::JointMotion
MotionTranslationTpl< Scalar, Options > JointMotion
Definition: joint-translation.hpp:267
pinocchio::SE3GroupAction< ConstraintTranslationTpl< S1, O1 > >::ReturnType
Eigen::Matrix< S1, 6, 3, O1 > ReturnType
Definition: joint-translation.hpp:404
pinocchio::python::Scalar
SE3::Scalar Scalar
Definition: conversions.cpp:15
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::U_t
Eigen::Matrix< Scalar, 6, NV, Options > U_t
Definition: joint-translation.hpp:429
pinocchio::JointDataTranslationTpl::v
Motion_t v
Definition: joint-translation.hpp:459
pinocchio::PINOCCHIO_JOINT_CAST_TYPE_SPECIALIZATION
PINOCCHIO_JOINT_CAST_TYPE_SPECIALIZATION(JointModelFreeFlyerTpl)
pinocchio::traits< ConstraintTranslationTpl< _Scalar, _Options > >::ConstMatrixReturnType
const typedef DenseBase ConstMatrixReturnType
Definition: joint-translation.hpp:272
pinocchio::ConstraintTranslationTpl::NV
@ NV
Definition: joint-translation.hpp:283
pinocchio::skew
void skew(const Eigen::MatrixBase< Vector3 > &v, const Eigen::MatrixBase< Matrix3 > &M)
Computes the skew representation of a given 3d vector, i.e. the antisymmetric matrix representation o...
Definition: skew.hpp:21
pinocchio::ConstraintTranslationTpl::motionAction
DenseBase motionAction(const MotionDense< MotionDerived > &m) const
Definition: joint-translation.hpp:354
pinocchio::JointDataTranslationTpl::c
Bias_t c
Definition: joint-translation.hpp:460
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::TangentVector_t
Eigen::Matrix< Scalar, NV, 1, Options > TangentVector_t
Definition: joint-translation.hpp:436
pinocchio::JointDataTranslationTpl::classname
static std::string classname()
Definition: joint-translation.hpp:475
pinocchio::JointModelTranslationTpl::Base
JointModelBase< JointModelTranslationTpl > Base
Definition: joint-translation.hpp:489
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::PlainReturnType
MotionPlain PlainReturnType
Definition: joint-translation.hpp:51
pinocchio::TransformTranslationTpl::translation
ConstLinearRef translation() const
Definition: joint-translation.hpp:242
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::HomogeneousMatrixType
Matrix4 HomogeneousMatrixType
Definition: joint-translation.hpp:49
joint-base.hpp
pinocchio::MotionTranslationTpl::m_v
Vector3 m_v
Definition: joint-translation.hpp:165
pinocchio::TransformTranslationTpl::TransformTranslationTpl
TransformTranslationTpl(const Eigen::MatrixBase< Vector3Like > &translation)
Definition: joint-translation.hpp:216
pinocchio::JointModelTranslationTpl::hasConfigurationLimit
const std::vector< bool > hasConfigurationLimit() const
Definition: joint-translation.hpp:497
pinocchio::MotionAlgebraAction< MotionTranslationTpl< Scalar, Options >, MotionDerived >::ReturnType
MotionTpl< Scalar, Options > ReturnType
Definition: joint-translation.hpp:30
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::Matrix4
Eigen::Matrix< Scalar, 4, 4, Options > Matrix4
Definition: joint-translation.hpp:40
pinocchio::operator+
MotionDerived::MotionPlain operator+(const MotionPlanarTpl< Scalar, Options > &m1, const MotionDense< MotionDerived > &m2)
Definition: joint-planar.hpp:192
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::PlainType
SE3Tpl< Scalar, Options > PlainType
Definition: joint-translation.hpp:188
M
M
pinocchio::MotionTranslationTpl::se3ActionInverse_impl
MotionPlain se3ActionInverse_impl(const SE3Tpl< S2, O2 > &m) const
Definition: joint-translation.hpp:135
pinocchio::ConstraintTranslationTpl::transpose
ConstraintTranspose transpose() const
Definition: joint-translation.hpp:323
ur5x4.w
w
Definition: ur5x4.py:45
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::AngularRef
AngularType AngularRef
Definition: joint-translation.hpp:192
pinocchio::JointDataTranslationTpl::S
PINOCCHIO_JOINT_DATA_BASE_DEFAULT_ACCESSOR Constraint_t S
Definition: joint-translation.hpp:457
pinocchio::JointDataTranslationTpl::M
Transformation_t M
Definition: joint-translation.hpp:458
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::Bias_t
MotionZeroTpl< Scalar, Options > Bias_t
Definition: joint-translation.hpp:426
pinocchio::JointModelTranslationTpl::calc
void calc(JointDataDerived &data, const typename Eigen::MatrixBase< ConfigVector > &qs, const typename Eigen::MatrixBase< TangentVector > &vs) const
Definition: joint-translation.hpp:515
pinocchio::traits< JointDataTranslationTpl< Scalar, Options > >::JointDerived
JointTranslationTpl< Scalar, Options > JointDerived
Definition: joint-translation.hpp:441
pinocchio::TransformTranslationTpl::rotation
AngularType rotation() const
Definition: joint-translation.hpp:245
pinocchio::ConstraintTranslationTpl::matrix_impl
DenseBase matrix_impl() const
Definition: joint-translation.hpp:325
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::Motion_t
MotionTranslationTpl< Scalar, Options > Motion_t
Definition: joint-translation.hpp:425
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::ActionMatrixType
Matrix6 ActionMatrixType
Definition: joint-translation.hpp:48
pinocchio::ConstraintTranslationTpl::__mult__
JointMotion __mult__(const Eigen::MatrixBase< Vector3Like > &v) const
Definition: joint-translation.hpp:292
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::Scalar
_Scalar Scalar
Definition: joint-translation.hpp:36
pinocchio::JointModelBase::idx_v
int idx_v() const
Definition: joint-model-base.hpp:120
pinocchio::v
JointCollectionTpl const Eigen::MatrixBase< ConfigVectorType > const Eigen::MatrixBase< TangentVectorType > & v
Definition: joint-configuration.hpp:748
constraint.hpp
pinocchio::MotionTranslationTpl::operator()
const Vector3 & operator()() const
Definition: joint-translation.hpp:78
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::ConfigVector_t
PINOCCHIO_JOINT_DATA_BASE_ACCESSOR_DEFAULT_RETURN_TYPE typedef Eigen::Matrix< Scalar, NQ, 1, Options > ConfigVector_t
Definition: joint-translation.hpp:435
pinocchio::JointModelTranslationTpl::JointDerived
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef JointTranslationTpl< _Scalar, _Options > JointDerived
Definition: joint-translation.hpp:486
pinocchio::ConstraintTranslationTpl::se3ActionInverse
Eigen::Matrix< S1, 6, 3, O1 > se3ActionInverse(const SE3Tpl< S1, O1 > &m) const
Definition: joint-translation.hpp:344
pinocchio::traits< JointModelTranslationTpl< Scalar, Options > >::JointDerived
JointTranslationTpl< Scalar, Options > JointDerived
Definition: joint-translation.hpp:445
pinocchio::MotionTranslationTpl::linear
Vector3 & linear()
Definition: joint-translation.hpp:161
pinocchio::MotionTranslationTpl::isEqual_impl
bool isEqual_impl(const MotionTranslationTpl &other) const
Definition: joint-translation.hpp:85
pinocchio::JointModelTranslationTpl::cast
JointModelTranslationTpl< NewScalar, Options > cast() const
Definition: joint-translation.hpp:554
pinocchio::ConstraintTranslationTpl::se3Action
Eigen::Matrix< S1, 6, 3, O1 > se3Action(const SE3Tpl< S1, O1 > &m) const
Definition: joint-translation.hpp:334
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::ConstLinearRef
const typedef LinearType & ConstLinearRef
Definition: joint-translation.hpp:196
collision-with-point-clouds.Y
Y
Definition: collision-with-point-clouds.py:31
pinocchio::traits< ConstraintTranslationTpl< _Scalar, _Options > >::JointForce
Eigen::Matrix< Scalar, 3, 1, Options > JointForce
Definition: joint-translation.hpp:268
pinocchio::ConstraintTranslationTpl
Definition: joint-translation.hpp:257
pinocchio::SE3Base
Base class for rigid transformation.
Definition: se3-base.hpp:30
pinocchio::TransformTranslationTpl::isEqual
bool isEqual(const TransformTranslationTpl &other) const
Definition: joint-translation.hpp:247
pinocchio::JointModelBase::idx_q
int idx_q() const
Definition: joint-model-base.hpp:119
pinocchio::MotionTranslationTpl::motionAction
void motionAction(const MotionDense< M1 > &v, MotionDense< M2 > &mout) const
Definition: joint-translation.hpp:143
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::LinearType
Vector3 LinearType
Definition: joint-translation.hpp:45
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::Transformation_t
TransformTranslationTpl< Scalar, Options > Transformation_t
Definition: joint-translation.hpp:424
pinocchio::ForceDense
Definition: force-dense.hpp:24
pinocchio::JointDataTranslationTpl::PINOCCHIO_JOINT_DATA_TYPEDEF_TEMPLATE
PINOCCHIO_JOINT_DATA_TYPEDEF_TEMPLATE(JointDerived)
pinocchio::MotionTranslationTpl::motionAction
MotionPlain motionAction(const MotionDense< M1 > &v) const
Definition: joint-translation.hpp:153
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::ConstLinearType
const typedef Vector3 ConstLinearType
Definition: joint-translation.hpp:47
pinocchio::MotionTranslationTpl::addTo
void addTo(MotionDense< Derived > &other) const
Definition: joint-translation.hpp:97
pinocchio::traits< TransformTranslationTpl< _Scalar, _Options > >::ActionMatrixType
traits< PlainType >::ActionMatrixType ActionMatrixType
Definition: joint-translation.hpp:197
pinocchio::traits< MotionTranslationTpl< _Scalar, _Options > >::Matrix6
Eigen::Matrix< Scalar, 6, 6, Options > Matrix6
Definition: joint-translation.hpp:41
pinocchio::ConstraintTranslationTpl::ConstraintTranspose::ConstraintTranspose
ConstraintTranspose(const ConstraintTranslationTpl &ref)
Definition: joint-translation.hpp:303
pinocchio::ConstraintBase
Definition: constraint-base.hpp:48
PINOCCHIO_CONSTRAINT_TYPEDEF_TPL
#define PINOCCHIO_CONSTRAINT_TYPEDEF_TPL(DERIVED)
Definition: constraint-base.hpp:27
pinocchio::MotionTranslationTpl
Definition: joint-translation.hpp:18
pinocchio::ConstraintTranslationTpl::ConstraintTranspose::operator*
const SizeDepType< 3 >::RowsReturn< MatrixDerived >::ConstType operator*(const Eigen::MatrixBase< MatrixDerived > &F) const
Definition: joint-translation.hpp:315
pinocchio::TransformTranslationTpl::PINOCCHIO_SE3_TYPEDEF_TPL
EIGEN_MAKE_ALIGNED_OPERATOR_NEW PINOCCHIO_SE3_TYPEDEF_TPL(TransformTranslationTpl)
pinocchio::InertiaTpl
Definition: spatial/fwd.hpp:52
pinocchio::traits
Common traits structure to fully define base classes for CRTP.
Definition: fwd.hpp:44
pinocchio::TransformTranslationTpl::Vector3
traits< TransformTranslationTpl >::Vector3 Vector3
Definition: joint-translation.hpp:211
pinocchio::JointModelTranslationTpl::shortname
std::string shortname() const
Definition: joint-translation.hpp:550
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::Constraint_t
ConstraintTranslationTpl< Scalar, Options > Constraint_t
Definition: joint-translation.hpp:423
pinocchio::JointModelTranslationTpl::classname
static std::string classname()
Definition: joint-translation.hpp:549
PINOCCHIO_EIGEN_REF_TYPE
#define PINOCCHIO_EIGEN_REF_TYPE(D)
Definition: eigen-macros.hpp:25
pinocchio::MotionTranslation
MotionTranslationTpl< double > MotionTranslation
Definition: joint-translation.hpp:18
pinocchio::ConstraintPrismaticUnalignedTpl
Definition: joint-prismatic-unaligned.hpp:184
pinocchio::JointModelTranslationTpl::PINOCCHIO_JOINT_TYPEDEF_TEMPLATE
PINOCCHIO_JOINT_TYPEDEF_TEMPLATE(JointDerived)
pinocchio::alphaSkew
void alphaSkew(const Scalar alpha, const Eigen::MatrixBase< Vector3 > &v, const Eigen::MatrixBase< Matrix3 > &M)
Computes the skew representation of a given 3d vector multiplied by a given scalar....
Definition: skew.hpp:124
pinocchio::MotionTpl< Scalar, Options >
dcrba.NV
NV
Definition: dcrba.py:444
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::JointDataDerived
JointDataTranslationTpl< Scalar, Options > JointDataDerived
Definition: joint-translation.hpp:421
dpendulum.NQ
int NQ
Definition: dpendulum.py:8
meshcat-viewer.qs
qs
Definition: meshcat-viewer.py:130
pinocchio::operator^
MotionDerived::MotionPlain operator^(const MotionDense< MotionDerived > &m1, const MotionPlanarTpl< S2, O2 > &m2)
Definition: joint-planar.hpp:339
pinocchio::SE3GroupAction< TransformTranslationTpl< Scalar, Options > >::ReturnType
traits< TransformTranslationTpl< Scalar, Options > >::PlainType ReturnType
Definition: joint-translation.hpp:203
pinocchio::traits< JointTranslationTpl< _Scalar, _Options > >::D_t
Eigen::Matrix< Scalar, NV, NV, Options > D_t
Definition: joint-translation.hpp:430
pinocchio::MotionTranslationTpl::MOTION_TYPEDEF_TPL
EIGEN_MAKE_ALIGNED_OPERATOR_NEW MOTION_TYPEDEF_TPL(MotionTranslationTpl)
pinocchio::MotionDense::angular
ConstAngularType angular() const
Definition: motion-base.hpp:21
pinocchio::TransformTranslationTpl
Definition: joint-translation.hpp:177
pinocchio
Main pinocchio namespace.
Definition: timings.cpp:28
pinocchio::JointModelBase::id
JointIndex id() const
Definition: joint-model-base.hpp:121
pinocchio::JointDataTranslationTpl::U
U_t U
Definition: joint-translation.hpp:463
pinocchio::ConstraintTranslationTpl::nv_impl
int nv_impl() const
Definition: joint-translation.hpp:298


pinocchio
Author(s):
autogenerated on Tue Feb 13 2024 03:43:59