aligator  0.14.0
A primal-dual augmented Lagrangian-type solver for nonlinear trajectory optimization.
Loading...
Searching...
No Matches
angular-momentum.hpp
Go to the documentation of this file.
1#pragma once
2
4
5namespace aligator {
6
7template <typename Scalar> struct AngularMomentumDataTpl;
8
17
18template <typename _Scalar>
20
21public:
22 using Scalar = _Scalar;
25 using BaseData = typename Base::Data;
27
28 AngularMomentumResidualTpl(const int ndx, const int nu, const Vector3s &L_ref)
29 : Base(ndx, nu, 3)
30 , L_ref_(L_ref) {}
31
32 const Vector3s &getReference() const { return L_ref_; }
33 void setReference(const Eigen::Ref<const Vector3s> &L_new) { L_ref_ = L_new; }
34
35 void evaluate(const ConstVectorRef &x, BaseData &data) const;
36
37 void computeJacobians(const ConstVectorRef &, BaseData &data) const;
38
39 shared_ptr<BaseData> createData() const {
40 return std::make_shared<Data>(this);
41 }
42
43protected:
44 Vector3s L_ref_;
45};
46
47template <typename Scalar>
54
55} // namespace aligator
56
57#ifdef ALIGATOR_ENABLE_TEMPLATE_INSTANTIATION
58#include "aligator/modelling/centroidal/angular-momentum.txx"
59#endif
Main package namespace.
AngularMomentumDataTpl(const AngularMomentumResidualTpl< Scalar > *model)
StageFunctionDataTpl< Scalar > Base
This residual returns the angular momentum for a centroidal model with state .
void computeJacobians(const ConstVectorRef &, BaseData &data) const
AngularMomentumResidualTpl(const int ndx, const int nu, const Vector3s &L_ref)
shared_ptr< BaseData > createData() const
Instantiate a Data object.
void evaluate(const ConstVectorRef &x, BaseData &data) const
void setReference(const Eigen::Ref< const Vector3s > &L_new)
AngularMomentumDataTpl< Scalar > Data
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