DART 6.10.1
|
The HierarchicalIK class provides a convenient way of setting up a hierarchical inverse kinematics optimization problem which combines several InverseKinematics problems into one. More...
#include <HierarchicalIK.hpp>
Classes | |
class | Constraint |
The HierarchicalIK::Constraint Function is simply used to merge the constraints of the InverseKinematics modules that belong to the hierarchy of this HierarchicalIK module. More... | |
class | Function |
This class should be inherited by optimizer::Function classes that have a dependency on the HierarchicalIK module that they belong to. More... | |
class | Objective |
The HierarchicalIK::Objective Function is simply used to merge the objective and null space objective functions that are being held by this HierarchicalIK module. More... | |
Public Member Functions | |
virtual | ~HierarchicalIK ()=default |
Virtual destructor. | |
bool | solve (bool applySolution=true) |
Solve the IK Problem. | |
bool | solve (Eigen::VectorXd &positions, bool applySolution=true) |
Same as solve(bool), but the positions vector will be filled with the solved positions. | |
bool | findSolution (Eigen::VectorXd &positions) |
Finds a solution of the IK problem without applying the solution. | |
bool | solveAndApply (bool allowIncompleteResult=true) |
Identical to findSolution(), but this function applies the solution when the solver successfully found a solution or allowIncompleteResult is set to true. | |
bool | solveAndApply (Eigen::VectorXd &positions, bool allowIncompleteResult=true) |
Identical to solveAndApply(bool), but position will be filled with the solved positions. | |
virtual std::shared_ptr< HierarchicalIK > | clone (const SkeletonPtr &_newSkel) const =0 |
Clone this HierarchicalIK module. | |
void | setObjective (const std::shared_ptr< optimizer::Function > &_objective) |
Set the objective function for this HierarchicalIK. | |
const std::shared_ptr< optimizer::Function > & | getObjective () |
Get the objective function for this HierarchicalIK. | |
std::shared_ptr< const optimizer::Function > | getObjective () const |
Get the objective function for this HierarchicalIK. | |
void | setNullSpaceObjective (const std::shared_ptr< optimizer::Function > &_nsObjective) |
Set the null space objective for this HierarchicalIK. | |
const std::shared_ptr< optimizer::Function > & | getNullSpaceObjective () |
Get the null space objective for this HierarchicalIK. | |
std::shared_ptr< const optimizer::Function > | getNullSpaceObjective () const |
Get the null space objective for this HierarchicalIK. | |
bool | hasNullSpaceObjective () const |
Returns true if this HierarchicalIK has a null space objective. | |
const std::shared_ptr< optimizer::Problem > & | getProblem () |
Get the Problem that is being maintained by this HierarchicalIK module. | |
std::shared_ptr< const optimizer::Problem > | getProblem () const |
Get the Problem that is being maintained by this HierarchicalIK module. | |
void | resetProblem (bool _clearSeeds=false) |
Reset the Problem that is being maintained by this HierarchicalIK module. | |
void | setSolver (const std::shared_ptr< optimizer::Solver > &_newSolver) |
Set the Solver that should be used by this IK module, and set it up with the Problem that is configured by this IK module. | |
const std::shared_ptr< optimizer::Solver > & | getSolver () |
Get the Solver that is being used by this IK module. | |
std::shared_ptr< const optimizer::Solver > | getSolver () const |
Get the Solver that is being used by this IK module. | |
virtual void | refreshIKHierarchy ()=0 |
Refresh the IK hierarchy of this IK module. | |
const IKHierarchy & | getIKHierarchy () const |
Get the IK hierarchy of this IK module. | |
const std::vector< Eigen::MatrixXd > & | computeNullSpaces () const |
Compute the null spaces of each level of the hierarchy. | |
Eigen::VectorXd | getPositions () const |
Get the current joint positions of the Skeleton associated with this IK module. | |
void | setPositions (const Eigen::VectorXd &_q) |
Set the current joint positions of the Skeleton associated with this IK module. | |
SkeletonPtr | getSkeleton () |
Get the Skeleton that this IK module is associated with. | |
ConstSkeletonPtr | getSkeleton () const |
Get the Skeleton that this IK module is associated with. | |
SkeletonPtr | getAffiliation () |
This is the same as getSkeleton(). | |
ConstSkeletonPtr | getAffiliation () const |
This is the same as getSkeleton(). | |
void | clearCaches () |
Clear the caches of this IK module. | |
Protected Member Functions | |
HierarchicalIK (const SkeletonPtr &_skeleton) | |
Constructor. | |
void | initialize (const std::shared_ptr< HierarchicalIK > &my_ptr) |
Setup the module. | |
void | copyOverSetup (const std::shared_ptr< HierarchicalIK > &_otherIK) const |
Copy the setup of this HierarchicalIK module into another HierarchicalIK module. | |
void | sendDestructionNotification () const |
Send a destruction notification to all Observers. | |
void | addObserver (Observer *_observer) const |
Add an Observer to the list of Observers. | |
void | removeObserver (Observer *_observer) const |
Remove an Observer from the list of Observers. | |
Protected Attributes | |
WeakSkeletonPtr | mSkeleton |
Pointer to the Skeleton that this IK is tied to. | |
IKHierarchy | mHierarchy |
Cache for the IK hierarcy. | |
std::shared_ptr< optimizer::Problem > | mProblem |
The Problem that this IK module is maintaining. | |
std::shared_ptr< optimizer::Solver > | mSolver |
The Solver that this IK module will use. | |
optimizer::FunctionPtr | mObjective |
The Objective of this IK module. | |
optimizer::FunctionPtr | mNullSpaceObjective |
The null space Objective of this IK module. | |
std::weak_ptr< HierarchicalIK > | mPtr |
Weak pointer to self. | |
Eigen::VectorXd | mLastPositions |
Cache for the last positions. | |
std::vector< Eigen::MatrixXd > | mNullSpaceCache |
Cache for null space computations. | |
Eigen::MatrixXd | mPartialNullspaceCache |
Cache for a partial null space computation. | |
Eigen::JacobiSVD< math::Jacobian > | mSVDCache |
Cache for the null space SVD. | |
math::Jacobian | mJacCache |
Cache for Jacobians. | |
std::set< Observer * > | mObservers |
List of current Observers. | |
The HierarchicalIK class provides a convenient way of setting up a hierarchical inverse kinematics optimization problem which combines several InverseKinematics problems into one.
InverseKinematics problems with a larger hierarchy level will be projected into null spaces of the problems that have a smaller hierarchy number.
Note that the HierarchicalIK will only account for the InverseKinematics::ErrorMethod and InverseKinematics::GradientMethod that the IK modules specify; it will ignore any other constraints or objectives put into the IK modules' Problems. Any additional constraints or objectives that you want the HierarchicalIK to solve should be put directly into the HierarchicalIK's Problem.
|
virtualdefault |
Virtual destructor.
|
protected |
Constructor.
|
protectedinherited |
Add an Observer to the list of Observers.
void dart::dynamics::HierarchicalIK::clearCaches | ( | ) |
Clear the caches of this IK module.
It should generally not be necessary to call this function.
|
pure virtual |
Clone this HierarchicalIK module.
Implemented in dart::dynamics::CompositeIK, and dart::dynamics::WholeBodyIK.
const std::vector< Eigen::MatrixXd > & dart::dynamics::HierarchicalIK::computeNullSpaces | ( | ) | const |
Compute the null spaces of each level of the hierarchy.
|
protected |
Copy the setup of this HierarchicalIK module into another HierarchicalIK module.
bool dart::dynamics::HierarchicalIK::findSolution | ( | Eigen::VectorXd & | positions | ) |
Finds a solution of the IK problem without applying the solution.
[out] | positions | The solution of the IK problem. If the solver failed to find a solution then it will still set the position with the best guess. For example, iterative solvers will fill position with the last result of the iterations. |
SkeletonPtr dart::dynamics::HierarchicalIK::getAffiliation | ( | ) |
This is the same as getSkeleton().
It is used by the HierarchicalIKPtr to provide a common interface for the various IK smart pointer types.
ConstSkeletonPtr dart::dynamics::HierarchicalIK::getAffiliation | ( | ) | const |
This is the same as getSkeleton().
It is used by the HierarchicalIKPtr to provide a common interface for the various IK smart pointer types.
const IKHierarchy & dart::dynamics::HierarchicalIK::getIKHierarchy | ( | ) | const |
Get the IK hierarchy of this IK module.
const std::shared_ptr< optimizer::Function > & dart::dynamics::HierarchicalIK::getNullSpaceObjective | ( | ) |
Get the null space objective for this HierarchicalIK.
std::shared_ptr< const optimizer::Function > dart::dynamics::HierarchicalIK::getNullSpaceObjective | ( | ) | const |
Get the null space objective for this HierarchicalIK.
const std::shared_ptr< optimizer::Function > & dart::dynamics::HierarchicalIK::getObjective | ( | ) |
Get the objective function for this HierarchicalIK.
std::shared_ptr< const optimizer::Function > dart::dynamics::HierarchicalIK::getObjective | ( | ) | const |
Get the objective function for this HierarchicalIK.
Eigen::VectorXd dart::dynamics::HierarchicalIK::getPositions | ( | ) | const |
Get the current joint positions of the Skeleton associated with this IK module.
const std::shared_ptr< optimizer::Problem > & dart::dynamics::HierarchicalIK::getProblem | ( | ) |
Get the Problem that is being maintained by this HierarchicalIK module.
std::shared_ptr< const optimizer::Problem > dart::dynamics::HierarchicalIK::getProblem | ( | ) | const |
Get the Problem that is being maintained by this HierarchicalIK module.
SkeletonPtr dart::dynamics::HierarchicalIK::getSkeleton | ( | ) |
Get the Skeleton that this IK module is associated with.
ConstSkeletonPtr dart::dynamics::HierarchicalIK::getSkeleton | ( | ) | const |
Get the Skeleton that this IK module is associated with.
const std::shared_ptr< optimizer::Solver > & dart::dynamics::HierarchicalIK::getSolver | ( | ) |
Get the Solver that is being used by this IK module.
std::shared_ptr< const optimizer::Solver > dart::dynamics::HierarchicalIK::getSolver | ( | ) | const |
Get the Solver that is being used by this IK module.
bool dart::dynamics::HierarchicalIK::hasNullSpaceObjective | ( | ) | const |
Returns true if this HierarchicalIK has a null space objective.
|
protected |
Setup the module.
|
pure virtual |
Refresh the IK hierarchy of this IK module.
Implemented in dart::dynamics::CompositeIK, and dart::dynamics::WholeBodyIK.
|
protectedinherited |
Remove an Observer from the list of Observers.
void dart::dynamics::HierarchicalIK::resetProblem | ( | bool | _clearSeeds = false | ) |
Reset the Problem that is being maintained by this HierarchicalIK module.
This will clear out all Functions from the Problem and then configure the Problem to use this IK module's Objective and Constraint functions.
Setting _clearSeeds to true will clear out any seeds that have been loaded into the Problem.
|
protectedinherited |
Send a destruction notification to all Observers.
This will cause all Observers to behave as if this Subject has been permanently deleted, so it should only be called when that behavior is desired.
void dart::dynamics::HierarchicalIK::setNullSpaceObjective | ( | const std::shared_ptr< optimizer::Function > & | _nsObjective | ) |
Set the null space objective for this HierarchicalIK.
void dart::dynamics::HierarchicalIK::setObjective | ( | const std::shared_ptr< optimizer::Function > & | _objective | ) |
Set the objective function for this HierarchicalIK.
void dart::dynamics::HierarchicalIK::setPositions | ( | const Eigen::VectorXd & | _q | ) |
void dart::dynamics::HierarchicalIK::setSolver | ( | const std::shared_ptr< optimizer::Solver > & | _newSolver | ) |
Set the Solver that should be used by this IK module, and set it up with the Problem that is configured by this IK module.
bool dart::dynamics::HierarchicalIK::solve | ( | bool | applySolution = true | ) |
Solve the IK Problem.
By default, the Skeleton itself will retain the solved joint positions. If you pass in false for applySolution
, then the joint positions will be return to their original positions after the problem is solved.
bool dart::dynamics::HierarchicalIK::solve | ( | Eigen::VectorXd & | positions, |
bool | applySolution = true |
||
) |
Same as solve(bool), but the positions vector will be filled with the solved positions.
bool dart::dynamics::HierarchicalIK::solveAndApply | ( | bool | allowIncompleteResult = true | ) |
Identical to findSolution(), but this function applies the solution when the solver successfully found a solution or allowIncompleteResult
is set to true.
[in] | allowIncompleteResult | Allow to apply the solution even when the solver failed to find solution. This option would be useful when an iterative solver is used because they will often do a decent job of getting a result close to a solution even if it failed to find the solution. |
bool dart::dynamics::HierarchicalIK::solveAndApply | ( | Eigen::VectorXd & | positions, |
bool | allowIncompleteResult = true |
||
) |
Identical to solveAndApply(bool), but position
will be filled with the solved positions.
[out] | positions | The solution of the IK problem. If the solver failed to find a solution then it will still set the position with the best guess. For example, iterative solvers will fill positions with the last result of the iterations. |
[in] | allowIncompleteResult | Allow to apply the solution even when the solver failed to find solution. This option would be useful when an iterative solver is used because they will often do a decent job of getting a result close to a solution even if it failed to find the solution. |
|
protected |
Cache for the IK hierarcy.
|
mutableprotected |
Cache for Jacobians.
|
mutableprotected |
Cache for the last positions.
|
mutableprotected |
Cache for null space computations.
|
protected |
The null space Objective of this IK module.
|
protected |
The Objective of this IK module.
|
mutableprotectedinherited |
List of current Observers.
|
mutableprotected |
Cache for a partial null space computation.
|
protected |
The Problem that this IK module is maintaining.
|
protected |
Weak pointer to self.
|
protected |
Pointer to the Skeleton that this IK is tied to.
|
protected |
The Solver that this IK module will use.
|
mutableprotected |
Cache for the null space SVD.