Program Listing for File impulse-base.hpp

Return to documentation for file (include/crocoddyl/multibody/impulse-base.hpp)

// BSD 3-Clause License
//
// Copyright (C) 2019-2025, LAAS-CNRS, University of Edinburgh,
//                          Heriot-Watt University
// Copyright note valid unless otherwise stated in individual files.
// All rights reserved.

#ifndef CROCODDYL_MULTIBODY_IMPULSE_BASE_HPP_
#define CROCODDYL_MULTIBODY_IMPULSE_BASE_HPP_

#include "crocoddyl/core/utils/deprecate.hpp"
#include "crocoddyl/multibody/force-base.hpp"
#include "crocoddyl/multibody/fwd.hpp"
#include "crocoddyl/multibody/states/multibody.hpp"

namespace crocoddyl {

class ImpulseModelBase {
 public:
  virtual ~ImpulseModelBase() = default;

  CROCODDYL_BASE_CAST(ImpulseModelBase, ImpulseModelAbstractTpl)
};

template <typename _Scalar>
class ImpulseModelAbstractTpl : public ImpulseModelBase {
 public:
  EIGEN_MAKE_ALIGNED_OPERATOR_NEW

  typedef _Scalar Scalar;
  typedef MathBaseTpl<Scalar> MathBase;
  typedef ImpulseDataAbstractTpl<Scalar> ImpulseDataAbstract;
  typedef StateMultibodyTpl<Scalar> StateMultibody;
  typedef typename MathBase::VectorXs VectorXs;
  typedef typename MathBase::MatrixXs MatrixXs;

  ImpulseModelAbstractTpl(std::shared_ptr<StateMultibody> state,
                          const pinocchio::ReferenceFrame type,
                          const std::size_t nc);

  DEPRECATED(
      "Use constructor that passes the type type of contact, this assumes is "
      "pinocchio::LOCAL",
      ImpulseModelAbstractTpl(std::shared_ptr<StateMultibody> state,
                              const std::size_t nc);)
  virtual ~ImpulseModelAbstractTpl() = default;

  virtual void calc(const std::shared_ptr<ImpulseDataAbstract>& data,
                    const Eigen::Ref<const VectorXs>& x) = 0;
  virtual void calcDiff(const std::shared_ptr<ImpulseDataAbstract>& data,
                        const Eigen::Ref<const VectorXs>& x) = 0;

  virtual void updateForce(const std::shared_ptr<ImpulseDataAbstract>& data,
                           const VectorXs& force) = 0;
  void updateForceDiff(const std::shared_ptr<ImpulseDataAbstract>& data,
                       const MatrixXs& df_dx) const;
  void setZeroForce(const std::shared_ptr<ImpulseDataAbstract>& data) const;
  void setZeroForceDiff(const std::shared_ptr<ImpulseDataAbstract>& data) const;

  virtual std::shared_ptr<ImpulseDataAbstract> createData(
      pinocchio::DataTpl<Scalar>* const data);

  const std::shared_ptr<StateMultibody>& get_state() const;
  std::size_t get_nc() const;
  DEPRECATED("Use get_nc().", std::size_t get_ni() const;)
  std::size_t get_nu() const;

  pinocchio::FrameIndex get_id() const;

  void set_id(const pinocchio::FrameIndex id);

  void set_type(const pinocchio::ReferenceFrame type);

  pinocchio::ReferenceFrame get_type() const;

  template <class Scalar>
  friend std::ostream& operator<<(std::ostream& os,
                                  const ImpulseModelAbstractTpl<Scalar>& model);

  virtual void print(std::ostream& os) const;

 protected:
  std::shared_ptr<StateMultibody> state_;
  std::size_t nc_;
  pinocchio::FrameIndex id_;
  pinocchio::ReferenceFrame type_;
  ImpulseModelAbstractTpl() : state_(nullptr), nc_(0), id_(0) {};
};

template <typename _Scalar>
struct ImpulseDataAbstractTpl : public ForceDataAbstractTpl<_Scalar> {
  EIGEN_MAKE_ALIGNED_OPERATOR_NEW

  typedef _Scalar Scalar;
  typedef MathBaseTpl<Scalar> MathBase;
  typedef ForceDataAbstractTpl<Scalar> Base;
  typedef typename MathBase::VectorXs VectorXs;
  typedef typename MathBase::MatrixXs MatrixXs;
  typedef typename pinocchio::SE3Tpl<Scalar> SE3;

  template <template <typename Scalar> class Model>
  ImpulseDataAbstractTpl(Model<Scalar>* const model,
                         pinocchio::DataTpl<Scalar>* const data)
      : Base(model, data),
        dv0_dq(model->get_nc(), model->get_state()->get_nv()),
        dtau_dq(model->get_state()->get_nv(), model->get_state()->get_nv()) {
    dv0_dq.setZero();
    dtau_dq.setZero();
  }
  virtual ~ImpulseDataAbstractTpl() = default;

  using Base::df_dx;
  using Base::f;
  using Base::frame;
  using Base::Jc;
  using Base::jMf;
  using Base::pinocchio;

  typename SE3::ActionMatrixType fXj;
  MatrixXs dv0_dq;
  MatrixXs dtau_dq;
};

}  // namespace crocoddyl

/* --- Details -------------------------------------------------------------- */
/* --- Details -------------------------------------------------------------- */
/* --- Details -------------------------------------------------------------- */
#include "crocoddyl/multibody/impulse-base.hxx"

CROCODDYL_DECLARE_EXTERN_TEMPLATE_CLASS(crocoddyl::ImpulseModelAbstractTpl)
CROCODDYL_DECLARE_EXTERN_TEMPLATE_STRUCT(crocoddyl::ImpulseDataAbstractTpl)

#endif  // CROCODDYL_MULTIBODY_IMPULSE_BASE_HPP_