10#ifndef CROCODDYL_MULTIBODY_RESIDUALS_CONTACT_CONTROL_GRAVITY_HPP_ 11#define CROCODDYL_MULTIBODY_RESIDUALS_CONTACT_CONTROL_GRAVITY_HPP_ 13#include "crocoddyl/core/residual-base.hpp" 14#include "crocoddyl/multibody/data/contacts.hpp" 15#include "crocoddyl/multibody/states/multibody.hpp" 38template <
typename _Scalar>
42 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
45 typedef _Scalar Scalar;
53 typedef typename MathBase::VectorXs VectorXs;
54 typedef typename MathBase::MatrixXs MatrixXs;
63 const std::size_t nu);
73 std::shared_ptr<StateMultibody> state);
83 virtual void calc(
const std::shared_ptr<ResidualDataAbstract>& data,
84 const Eigen::Ref<const VectorXs>& x,
85 const Eigen::Ref<const VectorXs>& u)
override;
97 virtual void calc(
const std::shared_ptr<ResidualDataAbstract>& data,
98 const Eigen::Ref<const VectorXs>& x)
override;
108 virtual void calcDiff(
const std::shared_ptr<ResidualDataAbstract>& data,
109 const Eigen::Ref<const VectorXs>& x,
110 const Eigen::Ref<const VectorXs>& u)
override;
123 virtual void calcDiff(
const std::shared_ptr<ResidualDataAbstract>& data,
124 const Eigen::Ref<const VectorXs>& x)
override;
130 DataCollectorAbstract*
const data)
override;
142 template <
typename NewScalar>
150 virtual void print(std::ostream& os)
const override;
158 typename StateMultibody::PinocchioModel pin_model_;
161template <
typename _Scalar>
162struct ResidualDataContactControlGravTpl
163 :
public ResidualDataAbstractTpl<_Scalar> {
164 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
166 typedef _Scalar Scalar;
168 typedef ResidualDataAbstractTpl<Scalar> Base;
171 typedef pinocchio::DataTpl<Scalar> PinocchioData;
173 template <
template <
typename Scalar>
class Model>
174 ResidualDataContactControlGravTpl(Model<Scalar>*
const model,
175 DataCollectorAbstract*
const data)
176 : Base(model, data) {
177 StateMultibody* sm =
static_cast<StateMultibody*
>(model->get_state().get());
185 "Invalid argument: the shared data should be derived from " 186 "DataCollectorActMultibodyInContactTpl");
190 fext = d->contacts->fext;
193 virtual ~ResidualDataContactControlGravTpl() =
default;
196 std::shared_ptr<ActuationDataAbstractTpl<Scalar> >
198 pinocchio::container::aligned_vector<pinocchio::ForceTpl<Scalar> >
211#include "crocoddyl/multibody/residuals/contact-control-gravity.hxx" 213CROCODDYL_DECLARE_EXTERN_TEMPLATE_CLASS(
215CROCODDYL_DECLARE_EXTERN_TEMPLATE_STRUCT(
Abstract class for the actuation-mapping model.
std::shared_ptr< StateAbstract > state_
ResidualModelAbstractTpl(std::shared_ptr< StateAbstract > state, const std::size_t nr, const std::size_t nu, const bool q_dependent=true, const bool v_dependent=true, const bool u_dependent=true)
Initialize the residual model.
State multibody representation.
const std::shared_ptr< PinocchioModel > & get_pinocchio() const
Return the Pinocchio model (i.e., model of the rigid body system)
DataCollectorAbstract * shared