|
mc_rtc
2.14.0
|
#include <mc_solver/EqualityConstraint.h>


Public Member Functions | |
| EqualityConstraintRobot (unsigned int rIndex) | |
Public Member Functions inherited from mc_solver::utils::EqualityConstraint< utils::UpdateRobot > | |
| EqualityConstraint (unsigned int rIndex) | |
| EqualityConstraint (const tasks::qp::ContactId &cid) | |
| EqualityConstraint (const mc_solver::QPSolver &solver, const tasks::qp::ContactId &cid) | |
| const Eigen::MatrixXd & | AEq () const override |
| std::string | descEq (const std::vector< rbd::MultiBody > &, int i) override |
Additional Inherited Members | |
Public Types inherited from mc_solver::utils::EqualityConstraint< utils::UpdateRobot > | |
| using | Base = Constraint< tasks::qp::Equality, utils::UpdateRobot > |
Protected Member Functions inherited from mc_solver::utils::Constraint< ConstraintT, UpdateT > | |
| template<typename U = UpdateT, typename = typename std::enable_if<std::is_same<U, utils::UpdateRobot>::value>::type> | |
| Constraint (unsigned int rIndex) | |
| template<typename U = UpdateT, typename = typename std::enable_if<std::is_same<U, utils::UpdateLambda>::value>::type> | |
| Constraint (const tasks::qp::ContactId &cid) | |
| template<typename U = UpdateT, typename = typename std::enable_if<std::is_same<U, utils::UpdateForce>::value>::type> | |
| Constraint (const mc_solver::QPSolver &solver, const tasks::qp::ContactId &cid) | |
| virtual | ~Constraint () |
| void | updateNrVars (const std::vector< rbd::MultiBody > &mbs, const tasks::qp::SolverData &data) override |
| void | update (const std::vector< rbd::MultiBody > &mbs, const std::vector< rbd::MultiBodyConfig > &mbcs, const tasks::qp::SolverData &data) override |
Helper class to write an equality constraint for Tasks. This constraint applies to alphaD for a given robot.
This implements \( A * \ddot{\mathbf{q}}_{rI} = b \)
Where \(rI\) is the robot index you provide at construction.
You must implement the following functions:
const Eigen::MatrixXd & A() const override; returns \(A\), must be of size (nrLines, alphaD.size())void compute() override; update constraint matrix and boundsint maxEq() const override; number of equality linesstd::string nameEq() const override; descriptive name of the constraintconst Eigen::VectorXd & bEq() const override; returns \(b\)
|
inlineexplicit |