6 #ifndef __pinocchio_joint_prismatic_hpp__ 7 #define __pinocchio_joint_prismatic_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/spatial-axis.hpp" 14 #include "pinocchio/utils/axis-label.hpp" 21 template<
typename Scalar,
int Options,
int axis>
27 template<
typename Scalar,
int Options,
int axis,
typename MotionDerived>
33 template<
typename _Scalar,
int _Options,
int _axis>
38 typedef Eigen::Matrix<Scalar,3,1,Options>
Vector3;
39 typedef Eigen::Matrix<Scalar,6,1,Options>
Vector6;
40 typedef Eigen::Matrix<Scalar,6,6,Options>
Matrix6;
56 template<
typename _Scalar,
int _Options,
int _axis>
58 :
MotionBase < MotionPrismaticTpl<_Scalar,_Options,_axis> >
60 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
71 inline PlainReturnType
plain()
const {
return Axis() * m_v; }
73 template<
typename OtherScalar>
79 template<
typename Derived>
83 other.
linear()[_axis] += (OtherScalar) m_v;
86 template<
typename MotionDerived>
89 for(Eigen::DenseIndex k = 0; k < 3; ++k)
94 template<
typename S2,
int O2,
typename D2>
101 template<
typename S2,
int O2>
105 se3Action_impl(m,res);
109 template<
typename S2,
int O2,
typename D2>
119 template<
typename S2,
int O2>
123 se3ActionInverse_impl(m,res);
127 template<
typename M1,
typename M2>
137 template<
typename M1>
150 return m_v == other.
m_v;
158 template<
typename Scalar,
int Options,
int axis,
typename MotionDerived>
159 typename MotionDerived::MotionPlain
163 typename MotionDerived::MotionPlain
res(m2);
168 template<
typename MotionDerived,
typename S2,
int O2,
int axis>
170 typename MotionDerived::MotionPlain
178 template<
typename _Scalar,
int _Options,
int _axis>
189 typedef Eigen::Matrix<Scalar,3,1,Options>
Vector3;
190 typedef Eigen::Matrix<Scalar,3,3,Options>
Matrix3;
201 template<
typename Scalar,
int Options,
int axis>
205 template<
typename _Scalar,
int _Options,
int axis>
208 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
216 : m_displacement(displacement)
221 PlainType
res(PlainType::Identity());
222 res.rotation().setIdentity();
223 res.translation()[
axis] = m_displacement;
228 operator PlainType()
const {
return plain(); }
230 template<
typename S2,
int O2>
236 res.translation()[
axis] += m_displacement;
244 ConstLinearRef
translation()
const {
return CartesianAxis3()*displacement(); };
245 AngularType
rotation()
const {
return AngularType(3,3); }
259 template<
typename _Scalar,
int _Options,
int axis>
275 template<
typename Scalar,
int Options,
int axis>
279 template<
typename Scalar,
int Options,
int axis,
typename MotionDerived>
283 template<
typename Scalar,
int Options,
int axis,
typename ForceDerived>
287 template<
typename Scalar,
int Options,
int axis,
typename ForceSet>
289 {
typedef typename Eigen::MatrixBase<ForceSet>::ConstRowXpr
ReturnType; };
291 template<
typename _Scalar,
int _Options,
int axis>
293 :
ConstraintBase < ConstraintPrismaticTpl <_Scalar,_Options,axis> >
295 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
303 template<
typename Vector1Like>
304 JointMotion
__mult__(
const Eigen::MatrixBase<Vector1Like> &
v)
const 306 EIGEN_STATIC_ASSERT_VECTOR_SPECIFIC_SIZE(Vector1Like,1);
307 assert(v.size() == 1);
308 return JointMotion(v[0]);
311 template<
typename S2,
int O2>
322 template<
typename S2,
int O2>
340 template<
typename ForceDerived>
343 {
return f.
linear().template segment<1>(
axis); }
346 template<
typename Derived>
351 return F.row(LINEAR+
axis);
371 template<
typename MotionDerived>
385 template<
typename S1,
int O1,
typename S2,
int O2,
int axis>
394 template<
typename S1,
int O1,
typename S2,
int O2>
400 static inline ReturnType
run(
const Inertia & Y,
410 res << m, S1(0), S1(0), S1(0), m*z, -m*y;
416 template<
typename S1,
int O1,
typename S2,
int O2>
422 static inline ReturnType
run(
const Inertia & Y,
433 res << S1(0), m, S1(0), -m*z, S1(0), m*
x;
439 template<
typename S1,
int O1,
typename S2,
int O2>
445 static inline ReturnType
run(
const Inertia & Y,
456 res << S1(0), S1(0), m, m*y, -m*
x, S1(0);
463 template<
typename M6Like,
typename S2,
int O2,
int axis>
472 template<
typename M6Like,
typename Scalar,
int Options,
int axis>
477 static inline ReturnType
run(
const Eigen::MatrixBase<M6Like> & Y,
480 EIGEN_STATIC_ASSERT_MATRIX_SPECIFIC_SIZE(M6Like,6,6);
481 return Y.derived().col(Inertia::LINEAR +
axis);
486 template<
typename _Scalar,
int _Options,
int _axis>
498 template<
typename _Scalar,
int _Options,
int axis>
515 typedef Eigen::Matrix<Scalar,6,NV,Options>
U_t;
516 typedef Eigen::Matrix<Scalar,NV,NV,Options>
D_t;
517 typedef Eigen::Matrix<Scalar,6,NV,Options>
UD_t;
525 template<
typename Scalar,
int Options,
int axis>
529 template<
typename Scalar,
int Options,
int axis>
533 template<
typename _Scalar,
int _Options,
int axis>
536 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
556 , UDinv(UD_t::Zero())
561 return std::string(
"JointDataP") + axisLabel<axis>();
567 template<
typename NewScalar,
typename Scalar,
int Options,
int axis>
573 template<
typename _Scalar,
int _Options,
int axis>
575 :
public JointModelBase< JointModelPrismaticTpl<_Scalar,_Options,axis> >
577 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
587 JointDataDerived
createData()
const {
return JointDataDerived(); }
589 template<
typename ConfigVector>
590 void calc(JointDataDerived & data,
591 const typename Eigen::MatrixBase<ConfigVector> & qs)
const 594 const Scalar &
q = qs[
idx_q()];
595 data.M.displacement() =
q;
598 template<
typename ConfigVector,
typename TangentVector>
599 void calc(JointDataDerived & data,
600 const typename Eigen::MatrixBase<ConfigVector> & qs,
601 const typename Eigen::MatrixBase<TangentVector> & vs)
const 603 calc(data,qs.derived());
606 const S2 &
v = vs[
idx_v()];
607 data.v.linearRate() =
v;
610 template<
typename Matrix6Like>
611 void calc_aba(JointDataDerived & data,
const Eigen::MatrixBase<Matrix6Like> & I,
const bool update_I)
const 613 data.U = I.col(Inertia::LINEAR +
axis);
614 data.Dinv[0] =
Scalar(1)/I(Inertia::LINEAR +
axis, Inertia::LINEAR +
axis);
615 data.UDinv.noalias() = data.U * data.Dinv[0];
623 return std::string(
"JointModelP") + axisLabel<axis>();
628 template<
typename NewScalar>
653 #include <boost/type_traits.hpp> 657 template<
typename Scalar,
int Options,
int axis>
659 :
public integral_constant<bool,true> {};
661 template<
typename Scalar,
int Options,
int axis>
663 :
public integral_constant<bool,true> {};
665 template<
typename Scalar,
int Options,
int axis>
667 :
public integral_constant<bool,true> {};
669 template<
typename Scalar,
int Options,
int axis>
671 :
public integral_constant<bool,true> {};
674 #endif // ifndef __pinocchio_joint_prismatic_hpp__ JointCollectionTpl const Eigen::MatrixBase< ConfigVectorType > const Eigen::MatrixBase< TangentVectorType > & v
ConstraintPrismaticTpl< Scalar, Options, axis > Constraint_t
TransposeConst transpose() const
#define PINOCCHIO_SE3_TYPEDEF_TPL(Derived)
MotionPrismaticTpl< Scalar, Options, axis > Motion_t
JointModelPrismaticTpl< double, 0, 0 > JointModelPX
Forward declaration of the multiplication operation return type. Should be overloaded, otherwise it will procude a compilation error.
MultiplicationOp< Inertia, Constraint >::ReturnType ReturnType
SE3GroupAction< ConstraintPrismaticTpl >::ReturnType se3Action(const SE3Tpl< S2, O2 > &m) const
const DenseBase ConstMatrixReturnType
const Vector3 ConstAngularType
int idx_q(const JointModelTpl< Scalar, Options, JointCollectionTpl > &jmodel)
Visit a JointModelTpl through JointIdxQVisitor to get the index in the full model configuration space...
PlainReturnType plain() const
void calc_aba(JointDataDerived &data, const Eigen::MatrixBase< Matrix6Like > &I, const bool update_I) const
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...
Return type of the Constraint::Transpose * ForceSet operation.
DenseBase matrix_impl() const
MotionPlain se3Action_impl(const SE3Tpl< S2, O2 > &m) const
JointPrismaticTpl< double, 0, 1 > JointPY
MotionTpl< Scalar, Options > ReturnType
Return type of the ation of a Motion onto an object of type D.
DenseBase MatrixReturnType
#define MOTION_TYPEDEF_TPL(Derived)
JointDataDerived createData() const
PINOCCHIO_EIGEN_REF_CONST_TYPE(Matrix6Like) operator*(const Eigen
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef JointPrismaticTpl< _Scalar, _Options, axis > JointDerived
SpatialAxis< LINEAR+axis > Axis
JointModelPrismaticTpl< double, 0, 1 > JointModelPY
void setTo(MotionDense< MotionDerived > &other) const
JointIndex id(const JointModelTpl< Scalar, Options, JointCollectionTpl > &jmodel)
Visit a JointModelTpl through JointIdVisitor to get the index of the joint in the kinematic chain...
#define PINOCCHIO_JOINT_DATA_BASE_DEFAULT_ACCESSOR
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef JointPrismaticTpl< _Scalar, _Options, axis > JointDerived
MotionAlgebraAction< OtherSpatialType, Derived >::ReturnType cross(const OtherSpatialType &d) const
Eigen::Matrix< Scalar, 3, 1, Options > Vector3
static ReturnType run(const Inertia &Y, const Constraint &)
SE3GroupAction< ConstraintPrismaticTpl >::ReturnType se3ActionInverse(const SE3Tpl< S2, O2 > &m) const
static std::string classname()
JointDataPrismaticTpl< double, 0, 0 > JointDataPX
ConstraintPrismaticTpl< S2, O2, 0 > Constraint
InertiaTpl< S1, O1 > Inertia
JointModelBase< JointModelPrismaticTpl > Base
void addTo(MotionDense< Derived > &other) const
static ReturnType run(const Inertia &Y, const Constraint &)
ForceDense< ForceDerived >::ConstLinearType::template ConstFixedSegmentReturnType< 1 >::Type ReturnType
JointModelPrismaticTpl< NewScalar, Options, axis > cast() const
Eigen::Matrix< Scalar, 6, NV, Options > U_t
JointCollectionTpl const Eigen::MatrixBase< ConfigVectorType > & q
#define PINOCCHIO_EIGEN_CONST_CAST(TYPE, OBJ)
Macro for an automatic const_cast.
Eigen::Matrix< Scalar, 6, 1, Options > Vector6
PINOCCHIO_JOINT_DATA_BASE_DEFAULT_ACCESSOR Constraint_t S
MotionDerived::MotionPlain operator+(const MotionPlanarTpl< Scalar, Options > &m1, const MotionDense< MotionDerived > &m2)
static ReturnType run(const Inertia &Y, const Constraint &)
JointPrismaticTpl< Scalar, Options, axis > JointDerived
const ConstraintPrismaticTpl & ref
Eigen::Matrix< Scalar, 6, 1, Options > DenseBase
MotionPrismaticTpl< Scalar, Options, axis > JointMotion
JointModelPrismaticTpl< Scalar, Options, axis > JointModelDerived
ConstraintPrismaticTpl< Scalar, Options, axis > Constraint
void se3Action_impl(const SE3Tpl< S2, O2 > &m, MotionDense< D2 > &v) const
#define PINOCCHIO_JOINT_DATA_BASE_ACCESSOR_DEFAULT_RETURN_TYPE
ConstLinearType linear() const
Return the linear part of the force vector.
InertiaTpl< S1, O1 > Inertia
MotionPlain motionAction(const MotionDense< M1 > &v) const
MotionPrismaticTpl(const Scalar &v)
const Vector3 & lever() const
bool isEqual_impl(const MotionPrismaticTpl &other) const
JointPrismaticTpl< double, 0, 0 > JointPX
ConstLinearType linear() const
bool isEqual(const ConstraintPrismaticTpl &) const
JointDataPrismaticTpl< Scalar, Options, axis > JointDataDerived
MultiplicationOp< Eigen::MatrixBase< M6Like >, Constraint >::ReturnType ReturnType
#define PINOCCHIO_JOINT_DATA_TYPEDEF_TEMPLATE(Joint)
Eigen::Matrix< Scalar, 6, 1, Options > ReturnType
MotionZeroTpl< Scalar, Options > Bias_t
MotionPlain se3ActionInverse_impl(const SE3Tpl< S2, O2 > &m) const
JointDataPrismaticTpl< double, 0, 1 > JointDataPY
static std::string classname()
Axis::CartesianAxis3 CartesianAxis3
JointPrismaticTpl< Scalar, Options, axis > JointDerived
MultiplicationOp< Inertia, Constraint >::ReturnType ReturnType
Eigen::Matrix< Scalar, 6, 1, Options > ReturnType
Eigen::Matrix< Scalar, NV, NV, Options > D_t
const Vector3 ConstLinearType
Eigen::Matrix< Scalar, 6, NV, Options > UD_t
ConstraintForceSetOp< ConstraintPrismaticTpl, Derived >::ReturnType operator*(const Eigen::MatrixBase< Derived > &F)
MotionPrismaticTpl __mult__(const OtherScalar &alpha) const
JointModelPrismaticTpl< NewScalar, Options, axis > type
ConstraintPrismaticTpl< S2, O2, 2 > Constraint
JointMotion __mult__(const Eigen::MatrixBase< Vector1Like > &v) const
void motionAction(const MotionDense< M1 > &v, MotionDense< M2 > &mout) const
void calc(JointDataDerived &data, const typename Eigen::MatrixBase< ConfigVector > &qs) const
Eigen::Matrix< Scalar, NV, 1, Options > TangentVector_t
#define PINOCCHIO_EIGEN_REF_TYPE(D)
ConstraintPrismaticTpl< S2, O2, 1 > Constraint
std::string shortname() const
M6Like::ConstColXpr ReturnType
Main pinocchio namespace.
ReturnTypeNotDefined ReturnType
Base class for rigid transformation.
MotionAlgebraAction< ConstraintPrismaticTpl, MotionDerived >::ReturnType motionAction(const MotionDense< MotionDerived > &m) const
void setIndexes(JointModelTpl< Scalar, Options, JointCollectionTpl > &jmodel, JointIndex id, int q, int v)
Visit a JointModelTpl through JointSetIndexesVisitor to set the indexes of the joint in the kinematic...
MotionTpl< Scalar, Options > ReturnType
Eigen::Matrix< Scalar, 6, 6, Options > Matrix6
JointModelPrismaticTpl< double, 0, 2 > JointModelPZ
const Scalar & linearRate() const
void se3ActionInverse_impl(const SE3Tpl< S2, O2 > &m, MotionDense< D2 > &v) const
Common traits structure to fully define base classes for CRTP.
Eigen::Matrix< S2, 6, 1, O2 > ReturnType
JointDataPrismaticTpl< double, 0, 2 > JointDataPZ
PINOCCHIO_JOINT_DATA_BASE_ACCESSOR_DEFAULT_RETURN_TYPE typedef Eigen::Matrix< Scalar, NQ, 1, Options > ConfigVector_t
InertiaTpl< S1, O1 > Inertia
TransformPrismaticTpl< Scalar, Options, axis > Transformation_t
#define PINOCCHIO_CONSTRAINT_TYPEDEF_TPL(DERIVED)
ConstAngularType angular() const
Eigen::MatrixBase< ForceSet >::ConstRowXpr ReturnType
static void motionAction(const MotionDense< MotionDerived > &v, const Eigen::MatrixBase< Mat > &iF, Eigen::MatrixBase< MatRet > const &jF)
Action of a motion on a set of forces, represented by a 6xN matrix whose each column represent a spat...
MultiplicationOp< Inertia, Constraint >::ReturnType ReturnType
static ReturnType run(const Eigen::MatrixBase< M6Like > &Y, const Constraint &)
Type of the cast of a class C templated by Scalar and Options, to a new NewScalar type...
Eigen::Matrix< Scalar, 1, 1, Options > JointForce
MotionDerived::MotionPlain operator^(const MotionDense< MotionDerived > &m1, const MotionPlanarTpl< S2, O2 > &m2)
SpatialAxis< _axis+LINEAR > Axis
Return type of the Constraint::Transpose * Force operation.
std::string shortname() const
MatrixDerived plain(const Eigen::PlainObjectBase< MatrixDerived > &m)
void calc(JointDataDerived &data, const typename Eigen::MatrixBase< ConfigVector > &qs, const typename Eigen::MatrixBase< TangentVector > &vs) const
ConstAngularRef rotation() const
ReturnTypeNotDefined ReturnType
JointPrismaticTpl< double, 0, 2 > JointPZ
MultiplicationOp< InertiaTpl< Scalar, Options >, ConstraintDerived >::ReturnType operator*(const InertiaTpl< Scalar, Options > &Y, const ConstraintBase< ConstraintDerived > &constraint)
.
TransposeConst(const ConstraintPrismaticTpl &ref)
#define PINOCCHIO_JOINT_TYPEDEF_TEMPLATE(Joint)