aligator  0.14.0
A primal-dual augmented Lagrangian-type solver for nonlinear trajectory optimization.
Loading...
Searching...
No Matches
centroidal-translation.hpp
Go to the documentation of this file.
1#pragma once
2
4
5namespace aligator {
6
7template <typename Scalar> struct CentroidalCoMDataTpl;
8
9template <typename _Scalar>
11
12public:
13 using Scalar = _Scalar;
16 using BaseData = typename Base::Data;
18
19 CentroidalCoMResidualTpl(const int ndx, const int nu, const Vector3s &p_ref)
20 : Base(ndx, nu, 3)
21 , p_ref_(p_ref) {}
22
23 const Vector3s &getReference() const { return p_ref_; }
24 void setReference(const Eigen::Ref<const Vector3s> &p_new) { p_ref_ = p_new; }
25
26 void evaluate(const ConstVectorRef &x, BaseData &data) const;
27
28 void computeJacobians(const ConstVectorRef &, BaseData &data) const;
29
30 shared_ptr<BaseData> createData() const {
31 return std::make_shared<Data>(this);
32 }
33
34protected:
35 Vector3s p_ref_;
36};
37
38template <typename Scalar>
40 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
42
44};
45
46} // namespace aligator
47
48#ifdef ALIGATOR_ENABLE_TEMPLATE_INSTANTIATION
49#include "aligator/modelling/centroidal/centroidal-translation.txx"
50#endif
Main package namespace.
StageFunctionDataTpl< Scalar > Base
CentroidalCoMDataTpl(const CentroidalCoMResidualTpl< Scalar > *model)
CentroidalCoMResidualTpl(const int ndx, const int nu, const Vector3s &p_ref)
shared_ptr< BaseData > createData() const
Instantiate a Data object.
void evaluate(const ConstVectorRef &x, BaseData &data) const
CentroidalCoMDataTpl< Scalar > Data
void computeJacobians(const ConstVectorRef &, BaseData &data) const
void setReference(const Eigen::Ref< const Vector3s > &p_new)
StageFunctionDataTpl(const int ndx, const int nu, const int nr)
const int nu
Control dimension.
StageFunctionDataTpl< Scalar > Data
Represents unary functions of the form , with no control (or next-state) arguments.
StageFunctionTpl< Scalar > Base