Differential action model for free forward dynamics in multibody systems. More...
#include <free-fwddyn.hpp>
Public Types | |
typedef ActuationModelAbstractTpl< Scalar > | ActuationModelAbstract |
typedef DifferentialActionModelAbstractTpl< Scalar > | Base |
typedef ConstraintModelManagerTpl< Scalar > | ConstraintModelManager |
typedef CostModelSumTpl< Scalar > | CostModelSum |
typedef DifferentialActionDataFreeFwdDynamicsTpl< Scalar > | Data |
typedef DifferentialActionDataAbstractTpl< Scalar > | DifferentialActionDataAbstract |
typedef MathBaseTpl< Scalar > | MathBase |
typedef MathBase::MatrixXs | MatrixXs |
typedef StateMultibodyTpl< Scalar > | StateMultibody |
typedef MathBase::VectorXs | VectorXs |
![]() | |
typedef DifferentialActionDataAbstractTpl< Scalar > | DifferentialActionDataAbstract |
typedef MathBaseTpl< Scalar > | MathBase |
typedef MathBase::MatrixXs | MatrixXs |
typedef StateAbstractTpl< Scalar > | StateAbstract |
typedef MathBase::VectorXs | VectorXs |
Public Member Functions | |
DifferentialActionModelFreeFwdDynamicsTpl (std::shared_ptr< StateMultibody > state, std::shared_ptr< ActuationModelAbstract > actuation, std::shared_ptr< CostModelSum > costs, std::shared_ptr< ConstraintModelManager > constraints=nullptr) | |
virtual void | calc (const std::shared_ptr< DifferentialActionDataAbstract > &data, const Eigen::Ref< const VectorXs > &x) |
virtual void | calc (const std::shared_ptr< DifferentialActionDataAbstract > &data, const Eigen::Ref< const VectorXs > &x, const Eigen::Ref< const VectorXs > &u) |
Compute the system acceleration, and cost value. | |
virtual void | calcDiff (const std::shared_ptr< DifferentialActionDataAbstract > &data, const Eigen::Ref< const VectorXs > &x) |
virtual void | calcDiff (const std::shared_ptr< DifferentialActionDataAbstract > &data, const Eigen::Ref< const VectorXs > &x, const Eigen::Ref< const VectorXs > &u) |
Compute the derivatives of the contact dynamics, and cost function. | |
virtual bool | checkData (const std::shared_ptr< DifferentialActionDataAbstract > &data) |
Check that the given data belongs to the free forward-dynamics data. | |
virtual std::shared_ptr< DifferentialActionDataAbstract > | createData () |
Create the free forward-dynamics data. | |
const std::shared_ptr< ActuationModelAbstract > & | get_actuation () const |
Return the actuation model. | |
const VectorXs & | get_armature () const |
Return the armature vector. | |
const std::shared_ptr< ConstraintModelManager > & | get_constraints () const |
Return the constraint model manager. | |
const std::shared_ptr< CostModelSum > & | get_costs () const |
Return the cost model. | |
virtual const VectorXs & | get_g_lb () const |
Return the lower bound of the inequality constraints. | |
virtual const VectorXs & | get_g_ub () const |
Return the upper bound of the inequality constraints. | |
virtual std::size_t | get_ng () const |
Return the number of inequality constraints. | |
virtual std::size_t | get_ng_T () const |
Return the number of equality terminal constraints. | |
virtual std::size_t | get_nh () const |
Return the number of equality constraints. | |
virtual std::size_t | get_nh_T () const |
Return the number of equality terminal constraints. | |
pinocchio::ModelTpl< Scalar > & | get_pinocchio () const |
Return the Pinocchio model. | |
virtual void | print (std::ostream &os) const |
Print relevant information of the free forward-dynamics model. | |
virtual void | quasiStatic (const std::shared_ptr< DifferentialActionDataAbstract > &data, Eigen::Ref< VectorXs > u, const Eigen::Ref< const VectorXs > &x, const std::size_t maxiter=100, const Scalar tol=Scalar(1e-9)) |
Computes the quasic static commands. | |
void | set_armature (const VectorXs &armature) |
Modify the armature vector. | |
![]() | |
DifferentialActionModelAbstractTpl (std::shared_ptr< StateAbstract > state, const std::size_t nu, const std::size_t nr=0, const std::size_t ng=0, const std::size_t nh=0, const std::size_t ng_T=0, const std::size_t nh_T=0) | |
Initialize the differential action model. | |
bool | get_has_control_limits () const |
Indicates if there are defined control limits. | |
std::size_t | get_nr () const |
Return the dimension of the cost-residual vector. | |
std::size_t | get_nu () const |
Return the dimension of the control input. | |
const std::shared_ptr< StateAbstract > & | get_state () const |
Return the state. | |
const VectorXs & | get_u_lb () const |
Return the control lower bound. | |
const VectorXs & | get_u_ub () const |
Return the control upper bound. | |
VectorXs | quasiStatic_x (const std::shared_ptr< DifferentialActionDataAbstract > &data, const VectorXs &x, const std::size_t maxiter=100, const Scalar tol=Scalar(1e-9)) |
void | set_g_lb (const VectorXs &g_lb) |
Modify the lower bound of the inequality constraints. | |
void | set_g_ub (const VectorXs &g_ub) |
Modify the upper bound of the inequality constraints. | |
void | set_u_lb (const VectorXs &u_lb) |
Modify the control lower bounds. | |
void | set_u_ub (const VectorXs &u_ub) |
Modify the control upper bounds. | |
Public Attributes | |
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef _Scalar | Scalar |
![]() | |
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef _Scalar | Scalar |
Protected Attributes | |
VectorXs | g_lb_ |
Lower bound of the inequality constraints. | |
VectorXs | g_ub_ |
< Lower bound of the inequality constraints | |
std::size_t | nu_ |
< Upper bound of the inequality constraints | |
std::shared_ptr< StateAbstract > | state_ |
< Control dimension | |
![]() | |
VectorXs | g_lb_ |
Lower bound of the inequality constraints. | |
VectorXs | g_ub_ |
Lower bound of the inequality constraints. | |
bool | has_control_limits_ |
std::size_t | ng_ |
Number of inequality constraints. | |
std::size_t | ng_T_ |
Number of inequality terminal constraints. | |
std::size_t | nh_ |
Number of equality constraints. | |
std::size_t | nh_T_ |
Number of equality terminal constraints. | |
std::size_t | nr_ |
Dimension of the cost residual. | |
std::size_t | nu_ |
Control dimension. | |
std::shared_ptr< StateAbstract > | state_ |
Model of the state. | |
VectorXs | u_lb_ |
Lower control limits. | |
VectorXs | u_ub_ |
Upper control limits. | |
VectorXs | unone_ |
Neutral state. | |
Additional Inherited Members | |
![]() | |
void | update_has_control_limits () |
Update the status of the control limits (i.e. if there are defined limits) | |
Differential action model for free forward dynamics in multibody systems.
This class implements free forward dynamics, i.e.,
\[ \mathbf{M}\dot{\mathbf{v}} + \mathbf{h}(\mathbf{q},\mathbf{v}) = \boldsymbol{\tau}, \]
where \(\mathbf{q}\in Q\), \(\mathbf{v}\in\mathbb{R}^{nv}\) are the configuration point and generalized velocity (its tangent vector), respectively; \(\boldsymbol{\tau}\) is the torque inputs and \(\mathbf{h}(\mathbf{q},\mathbf{v})\) are the Coriolis effect and gravity field.
The derivatives of the system acceleration is computed efficiently based on the analytical derivatives of Articulate Body Algorithm (ABA) as described in [carpentier-rss18].
The stack of cost functions is implemented in CostModelSumTpl
. The computation of the free forward dynamics and its derivatives are carrying out inside calc()
and calcDiff()
functions, respectively. It is also important to remark that calcDiff()
computes the derivatives using the latest stored values by calc()
. Thus, we need to run calc()
first.
Definition at line 59 of file free-fwddyn.hpp.
typedef DifferentialActionModelAbstractTpl<Scalar> Base |
Definition at line 65 of file free-fwddyn.hpp.
typedef DifferentialActionDataFreeFwdDynamicsTpl<Scalar> Data |
Definition at line 66 of file free-fwddyn.hpp.
typedef DifferentialActionDataAbstractTpl<Scalar> DifferentialActionDataAbstract |
Definition at line 68 of file free-fwddyn.hpp.
typedef StateMultibodyTpl<Scalar> StateMultibody |
Definition at line 69 of file free-fwddyn.hpp.
typedef CostModelSumTpl<Scalar> CostModelSum |
Definition at line 70 of file free-fwddyn.hpp.
typedef ConstraintModelManagerTpl<Scalar> ConstraintModelManager |
Definition at line 71 of file free-fwddyn.hpp.
typedef ActuationModelAbstractTpl<Scalar> ActuationModelAbstract |
Definition at line 72 of file free-fwddyn.hpp.
typedef MathBaseTpl<Scalar> MathBase |
Definition at line 73 of file free-fwddyn.hpp.
typedef MathBase::VectorXs VectorXs |
Definition at line 74 of file free-fwddyn.hpp.
typedef MathBase::MatrixXs MatrixXs |
Definition at line 75 of file free-fwddyn.hpp.
|
virtual |
Compute the system acceleration, and cost value.
It computes the system acceleration using the free forward-dynamics.
[in] | data | Free forward-dynamics data |
[in] | x | State point \(\mathbf{x}\in\mathbb{R}^{ndx}\) |
[in] | u | Control input \(\mathbf{u}\in\mathbb{R}^{nu}\) |
Implements DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Compute the derivatives of the contact dynamics, and cost function.
[in] | data | Free forward-dynamics data |
[in] | x | State point \(\mathbf{x}\in\mathbb{R}^{ndx}\) |
[in] | u | Control input \(\mathbf{u}\in\mathbb{R}^{nu}\) |
Implements DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Create the free forward-dynamics data.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Check that the given data belongs to the free forward-dynamics data.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Computes the quasic static commands.
The quasic static commands are the ones produced for a the reference posture as an equilibrium point, i.e. for \(\mathbf{f}(\mathbf{q},\mathbf{v}=\mathbf{0},\mathbf{u})=\mathbf{0}\)
[in] | data | Differential action data |
[out] | u | Quasic static commands |
[in] | x | State point (velocity has to be zero) |
[in] | maxiter | Maximum allowed number of iterations |
[in] | tol | Tolerance |
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Return the number of inequality constraints.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Return the number of equality constraints.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Return the number of equality terminal constraints.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Return the number of equality terminal constraints.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Return the lower bound of the inequality constraints.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Return the upper bound of the inequality constraints.
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
|
virtual |
Print relevant information of the free forward-dynamics model.
[out] | os | Output stream object |
Reimplemented from DifferentialActionModelAbstractTpl< _Scalar >.
EIGEN_MAKE_ALIGNED_OPERATOR_NEW typedef _Scalar Scalar |
Definition at line 64 of file free-fwddyn.hpp.
|
protected |
Lower bound of the inequality constraints.
Definition at line 365 of file diff-action-base.hpp.
|
protected |
< Lower bound of the inequality constraints
Definition at line 366 of file diff-action-base.hpp.
|
protected |
< Upper bound of the inequality constraints
Definition at line 357 of file diff-action-base.hpp.
|
protected |
< Control dimension
Definition at line 363 of file diff-action-base.hpp.