pinocchio  3.3.1
A fast and flexible implementation of Rigid Body Dynamics algorithms and their analytical derivatives
aba.hpp
1 //
2 // Copyright (c) 2016-2021 CNRS INRIA
3 //
4 
5 #ifndef __pinocchio_algorithm_aba_hpp__
6 #define __pinocchio_algorithm_aba_hpp__
7 
8 #include "pinocchio/multibody/model.hpp"
9 #include "pinocchio/multibody/data.hpp"
10 #include "pinocchio/algorithm/check.hpp"
11 
12 namespace pinocchio
13 {
34  template<
35  typename Scalar,
36  int Options,
37  template<typename, int> class JointCollectionTpl,
38  typename ConfigVectorType,
39  typename TangentVectorType1,
40  typename TangentVectorType2>
44  const Eigen::MatrixBase<ConfigVectorType> & q,
45  const Eigen::MatrixBase<TangentVectorType1> & v,
46  const Eigen::MatrixBase<TangentVectorType2> & tau,
47  const Convention convention = Convention::LOCAL);
48 
71  template<
72  typename Scalar,
73  int Options,
74  template<typename, int> class JointCollectionTpl,
75  typename ConfigVectorType,
76  typename TangentVectorType1,
77  typename TangentVectorType2,
78  typename ForceDerived>
82  const Eigen::MatrixBase<ConfigVectorType> & q,
83  const Eigen::MatrixBase<TangentVectorType1> & v,
84  const Eigen::MatrixBase<TangentVectorType2> & tau,
85  const container::aligned_vector<ForceDerived> & fext,
86  const Convention rf = Convention::LOCAL);
87 
101  template<
102  typename Scalar,
103  int Options,
104  template<typename, int> class JointCollectionTpl,
105  typename ConfigVectorType>
106  const typename DataTpl<Scalar, Options, JointCollectionTpl>::RowMatrixXs & computeMinverse(
109  const Eigen::MatrixBase<ConfigVectorType> & q);
110 
124  template<typename Scalar, int Options, template<typename, int> class JointCollectionTpl>
125  const typename DataTpl<Scalar, Options, JointCollectionTpl>::RowMatrixXs & computeMinverse(
128 
129  PINOCCHIO_DEFINE_ALGO_CHECKER(ABA);
130 
131 } // namespace pinocchio
132 
133 /* --- Details -------------------------------------------------------------------- */
134 #include "pinocchio/algorithm/aba.hxx"
135 
136 #if PINOCCHIO_ENABLE_TEMPLATE_INSTANTIATION
137  #include "pinocchio/algorithm/aba.txx"
138 #endif // PINOCCHIO_ENABLE_TEMPLATE_INSTANTIATION
139 
140 #endif // ifndef __pinocchio_algorithm_aba_hpp__
Convention
List of convention to call algorithms.
Definition: fwd.hpp:74
Main pinocchio namespace.
Definition: treeview.dox:11
const DataTpl< Scalar, Options, JointCollectionTpl >::TangentVectorType & aba(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 > &tau, const Convention convention=Convention::LOCAL)
The Articulated-Body algorithm. It computes the forward dynamics, aka the joint accelerations given t...
const DataTpl< Scalar, Options, JointCollectionTpl >::RowMatrixXs & computeMinverse(const ModelTpl< Scalar, Options, JointCollectionTpl > &model, DataTpl< Scalar, Options, JointCollectionTpl > &data, const Eigen::MatrixBase< ConfigVectorType > &q)
Computes the inverse of the joint space inertia matrix using Articulated Body formulation.
VectorXs TangentVectorType
Dense vectorized version of a joint tangent vector (e.g. velocity, acceleration, etc)....
Definition: data.hpp:89