11 #include <type_traits>
14 #include <boost/fusion/container/vector.hpp>
16 #include "pinocchio/macros.hpp"
17 #include "pinocchio/eigen-common.hpp"
18 #include "pinocchio/fwd.hpp"
20 #include "pinocchio/math.hpp"
22 #include "pinocchio/spatial.hpp"
24 #include "pinocchio/multibody.hpp"
25 #include "pinocchio/multibody/joint.hpp"
26 #include "pinocchio/multibody/visitor.hpp"
28 #include "pinocchio/algorithm/check.hpp"
94 template<
typename,
int>
class JointCollectionTpl,
95 typename ConfigVectorType,
96 typename TangentVectorType1,
97 typename TangentVectorType2,
103 const ModelTpl<Scalar, Options, JointCollectionTpl> & model,
104 DataTpl<Scalar, Options, JointCollectionTpl> & data,
105 const Eigen::MatrixBase<ConfigVectorType> & q,
106 const Eigen::MatrixBase<TangentVectorType1> & v,
107 const Eigen::MatrixBase<TangentVectorType2> & a,
108 const Tensor1 & d2tau_dqdq,
109 const Tensor2 & d2tau_dvdv,
110 const Tensor3 & dtau_dqdv,
111 const Tensor4 & dtau_dadq);
154 template<
typename,
int>
class JointCollectionTpl,
155 typename ConfigVectorType,
156 typename TangentVectorType1,
157 typename TangentVectorType2>
159 const ModelTpl<Scalar, Options, JointCollectionTpl> & model,
160 DataTpl<Scalar, Options, JointCollectionTpl> & data,
161 const Eigen::MatrixBase<ConfigVectorType> & q,
162 const Eigen::MatrixBase<TangentVectorType1> & v,
163 const Eigen::MatrixBase<TangentVectorType2> & a)
165 (data.d2tau_dqdq).setZero();
166 (data.d2tau_dvdv).setZero();
167 (data.d2tau_dqdv).setZero();
168 (data.d2tau_dadq).setZero();
171 model, data, q.derived(), v.derived(), a.derived(), data.d2tau_dqdq, data.d2tau_dvdv,
172 data.d2tau_dqdv, data.d2tau_dadq);
178 #include "pinocchio/src/algorithm/rnea-second-order-derivatives.hxx"
Main pinocchio namespace.
void ComputeRNEASecondOrderDerivatives(const ModelTpl< Scalar, Options, JointCollectionTpl > &model, DataTpl< Scalar, Options, JointCollectionTpl > &data, const Eigen::MatrixBase< ConfigVectorType > &q, const Eigen::MatrixBase< TangentVectorType1 > &v, const Eigen::MatrixBase< TangentVectorType2 > &a, const Tensor1 &d2tau_dqdq, const Tensor2 &d2tau_dvdv, const Tensor3 &dtau_dqdv, const Tensor4 &dtau_dadq)
Computes the Second-Order partial derivatives of the Recursive Newton Euler Algorithm w....