Program Listing for File constraint-generic.hpp
↰ Return to documentation for file (include/pinocchio/multibody/constraint-generic.hpp
)
//
// Copyright (c) 2015-2019 CNRS, INRIA
// Copyright (c) 2016 Wandercraft, 86 rue de Paris 91400 Orsay, France.
//
#ifndef __pinocchio_multibody_constraint_generic_hpp__
#define __pinocchio_multibody_constraint_generic_hpp__
namespace pinocchio
{
template<int _Dim, typename _Scalar, int _Options>
struct traits< ConstraintTpl<_Dim, _Scalar, _Options> >
{
typedef _Scalar Scalar;
enum
{
LINEAR = 0,
ANGULAR = 3,
Options = _Options,
Dim = _Dim
};
typedef MotionTpl<Scalar,Options> JointMotion;
typedef Eigen::Matrix<Scalar,Dim,1,Options> JointForce;
typedef Eigen::Matrix<Scalar,6,Dim,Options> DenseBase;
typedef typename PINOCCHIO_EIGEN_REF_CONST_TYPE(DenseBase) ConstMatrixReturnType;
typedef typename PINOCCHIO_EIGEN_REF_TYPE(DenseBase) MatrixReturnType;
}; // traits ConstraintTpl
template<int Dim, typename Scalar, int Options>
struct SE3GroupAction< ConstraintTpl<Dim,Scalar,Options> >
{ typedef Eigen::Matrix<Scalar,6,Dim> ReturnType; };
template<int Dim, typename Scalar, int Options, typename MotionDerived>
struct MotionAlgebraAction< ConstraintTpl<Dim,Scalar,Options>, MotionDerived >
{ typedef Eigen::Matrix<Scalar,6,Dim> ReturnType; };
template<int _Dim, typename _Scalar, int _Options>
struct ConstraintTpl
: public ConstraintBase< ConstraintTpl<_Dim,_Scalar,_Options> >
{
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
typedef ConstraintBase<ConstraintTpl> Base;
friend class ConstraintBase<ConstraintTpl>;
PINOCCHIO_CONSTRAINT_TYPEDEF_TPL(ConstraintTpl)
enum { NV = _Dim };
using Base::nv;
template<typename D>
explicit ConstraintTpl(const Eigen::MatrixBase<D> & _S) : S(_S)
{
// There is currently a bug in Eigen/Core/util/StaticAssert.h in the use of the full namespace path
// TODO
EIGEN_STATIC_ASSERT_SAME_MATRIX_SIZE(DenseBase, D);
}
ConstraintTpl() : S()
{
EIGEN_STATIC_ASSERT(_Dim!=Eigen::Dynamic,
YOU_CALLED_A_DYNAMIC_SIZE_METHOD_ON_A_FIXED_SIZE_MATRIX_OR_VECTOR)
}
// It is only valid for dynamics size
explicit ConstraintTpl(const int dim) : S(6,dim)
{
EIGEN_STATIC_ASSERT(_Dim==Eigen::Dynamic,
YOU_CALLED_A_FIXED_SIZE_METHOD_ON_A_DYNAMIC_SIZE_MATRIX_OR_VECTOR)
}
static ConstraintTpl Zero(const int dim)
{
return ConstraintTpl(dim);
}
template<typename VectorLike>
JointMotion __mult__(const Eigen::MatrixBase<VectorLike> & vj) const
{
return JointMotion(S*vj);
}
struct Transpose
{
const ConstraintTpl & ref;
Transpose( const ConstraintTpl & ref ) : ref(ref) {}
template<typename Derived>
JointForce operator*(const ForceDense<Derived> & f) const
{ return (ref.S.transpose()*f.toVector()).eval(); }
template<typename D>
typename Eigen::Matrix<Scalar,NV,Eigen::Dynamic>
operator*(const Eigen::MatrixBase<D> & F)
{
return (ref.S.transpose()*F).eval();
}
};
Transpose transpose() const { return Transpose(*this); }
MatrixReturnType matrix_impl() { return S; }
ConstMatrixReturnType matrix_impl() const { return S; }
int nv_impl() const { return (int)S.cols(); }
template<typename S2,int O2>
friend typename ConstraintTpl<_Dim,_Scalar,_Options>::DenseBase
operator*(const InertiaTpl<S2,O2> & Y, const ConstraintTpl & S)
{
typedef typename ConstraintTpl::DenseBase ReturnType;
ReturnType res(6,S.nv());
motionSet::inertiaAction(Y,S.S,res);
return res;
}
template<typename S2,int O2>
friend Eigen::Matrix<_Scalar,6,_Dim>
operator*(const Eigen::Matrix<S2,6,6,O2> & Ymatrix, const ConstraintTpl & S)
{
typedef Eigen::Matrix<_Scalar,6,_Dim> ReturnType;
return ReturnType(Ymatrix*S.matrix());
}
DenseBase se3Action(const SE3Tpl<Scalar,Options> & m) const
{
DenseBase res(6,nv());
motionSet::se3Action(m,S,res);
return res;
}
DenseBase se3ActionInverse(const SE3Tpl<Scalar,Options> & m) const
{
DenseBase res(6,nv());
motionSet::se3ActionInverse(m,S,res);
return res;
}
template<typename MotionDerived>
DenseBase motionAction(const MotionDense<MotionDerived> & v) const
{
DenseBase res(6,nv());
motionSet::motionAction(v,S,res);
return res;
}
void disp_impl(std::ostream & os) const { os << "S =\n" << S << std::endl;}
bool isEqual(const ConstraintTpl & other) const
{
return S == other.S;
}
protected:
DenseBase S;
}; // class ConstraintTpl
} // namespace pinocchio
#endif // ifndef __pinocchio_multibody_constraint_generic_hpp__