DART 6.10.1
Loading...
Searching...
No Matches
dart::dynamics::SharedLibraryIkFast Class Reference

IkFast-based analytical inverse kinematics class. More...

#include <SharedLibraryIkFast.hpp>

Inheritance diagram for dart::dynamics::SharedLibraryIkFast:
dart::dynamics::IkFast dart::dynamics::InverseKinematics::Analytical dart::dynamics::InverseKinematics::GradientMethod dart::common::Subject

Public Types

enum  IkType {
  TRANSFORM_6D , ROTATION_3D , TRANSLATION_3D , DIRECTION_3D ,
  RAY_4D , LOOKAT_3D , TRANSLATION_DIRECTION_5D , TRANSLATION_XY_2D ,
  TRANSLATION_XY_ORIENTATION_3D , TRANSLATION_LOCAL_GLOBAL_6D , TRANSLATION_X_AXIS_ANGLE_4D , TRANSLATION_Y_AXIS_ANGLE_4D ,
  TRANSLATION_Z_AXIS_ANGLE_4D , TRANSLATION_X_AXIS_ANGLE_Z_NORM_4D , TRANSLATION_Y_AXIS_ANGLE_X_NORM_4D , TRANSLATION_Z_AXIS_ANGLE_Y_NORM_4D ,
  UNKNOWN
}
 Inverse kinematics types supported by IkFast. More...
 
enum  Validity_t { VALID = 0 , OUT_OF_REACH = 1 << 0 , LIMIT_VIOLATED = 1 << 1 }
 Bitwise enumerations that are used to describe some properties of each solution produced by the analytical IK. More...
 
enum  ExtraDofUtilization { UNUSED = 0 , PRE_ANALYTICAL , POST_ANALYTICAL , PRE_AND_POST_ANALYTICAL }
 If there are extra DOFs in the IK module which your Analytical solver implementation does not make use of, those DOFs can be used to supplement the analytical solver using Jacobian transpose iteration. More...
 
typedef std::function< bool(const Eigen::VectorXd &_better, const Eigen::VectorXd &_worse, const InverseKinematics *_ik)> QualityComparison
 

Public Member Functions

 SharedLibraryIkFast (InverseKinematics *ik, const std::string &filePath, const std::vector< std::size_t > &dofMap, const std::vector< std::size_t > &freeDofMap, const std::string &methodName="IKFast", const Analytical::Properties &properties=Analytical::Properties())
 Constructor.
 
auto clone (InverseKinematics *newIK) const -> std::unique_ptr< GradientMethod > override
 Enable this GradientMethod to be cloned to a new IK module.
 
const std::vector< InverseKinematics::Analytical::Solution > & computeSolutions (const Eigen::Isometry3d &desiredBodyTf) override
 Use this function to fill the entries of the mSolutions variable.
 
Eigen::Isometry3d computeFk (const Eigen::VectorXd &parameters)
 Computes forward kinematics given joint positions where the dimension is the same as getNumJoints2().
 
const std::vector< std::size_t > & getDofs () const override
 Returns the indices of the DegreeOfFreedoms that are part of the joints that IkFast solves for.
 
const std::vector< std::size_t > & getFreeDofs () const
 Returns the indices of the DegreeOfFreedoms that are part of the joints that IkFast solves but the values should be set by the user in prior.
 
virtual bool isConfigured () const
 Returns true if this IkFast is ready to solve.
 
std::size_t getNumFreeParameters2 () const
 Returns the number of free parameters users has to set apriori.
 
std::size_t getNumJoints2 () const
 Returns the total number of indices of the chane.
 
IkType getIkType2 () const
 Returns the IK type.
 
const std::string getKinematicsHash2 () const
 Returns a hash of all the chain values used for double checking that the correct IK is used.
 
std::string getIkFastVersion2 () const
 Returns the IkFast version used to generate this file.
 
const std::vector< Solution > & getSolutions ()
 Get the solutions for this IK module, along with a tag indicating whether each solution is valid.
 
const std::vector< Solution > & getSolutions (const Eigen::Isometry3d &_desiredTf)
 Get the solutions for this IK module, along with a tag indicating whether each solution is valid.
 
void computeGradient (const Eigen::Vector6d &_error, Eigen::VectorXd &_grad) override
 You should not need to override this function.
 
void setPositions (const Eigen::VectorXd &_config)
 Set the configuration of the DOFs.
 
Eigen::VectorXd getPositions () const
 Get the configuration of the DOFs.
 
void setExtraDofUtilization (ExtraDofUtilization _utilization)
 Set how you want extra DOFs to be utilized by the IK module.
 
ExtraDofUtilization getExtraDofUtilization () const
 Get how extra DOFs are being utilized by the IK module.
 
void setExtraErrorLengthClamp (double _clamp)
 Set how much to clamp the error vector that gets applied to extra DOFs.
 
double getExtraErrorLengthClamp () const
 Get how much we will clamp the error vector that gets applied to extra DOFs.
 
void setQualityComparisonFunction (const QualityComparison &_func)
 Set the function that will be used to compare the qualities of two solutions.
 
void resetQualityComparisonFunction ()
 Reset the quality comparison function to the default method.
 
Properties getAnalyticalProperties () const
 Get the Properties for this Analytical class.
 
void constructDofMap ()
 Construct a mapping from the DOFs of getDofs() to their indices within the Node's list of dependent DOFs.
 
void evalGradient (const Eigen::VectorXd &_q, Eigen::Map< Eigen::VectorXd > _grad)
 This function is used to handle caching the gradient vector and interfacing with the solver.
 
const std::string & getMethodName () const
 Get the name of this GradientMethod.
 
void clampGradient (Eigen::VectorXd &_grad) const
 Clamp the gradient based on the clamp settings of this GradientMethod.
 
void setComponentWiseClamp (double _clamp=DefaultIKGradientComponentClamp)
 Set the component-wise clamp for this GradientMethod.
 
double getComponentWiseClamp () const
 Get the component-wise clamp for this GradientMethod.
 
void applyWeights (Eigen::VectorXd &_grad) const
 Apply weights to the gradient based on the weight settings of this GradientMethod.
 
void setComponentWeights (const Eigen::VectorXd &_weights)
 Set the weights that will be applied to each component of the gradient.
 
const Eigen::VectorXd & getComponentWeights () const
 Get the weights of this GradientMethod.
 
void convertJacobianMethodOutputToGradient (Eigen::VectorXd &grad, const std::vector< std::size_t > &dofs)
 Convert the gradient that gets generated by Jacobian methods into a gradient that can be used by a GradientDescentSolver.
 
Properties getGradientMethodProperties () const
 Get the Properties of this GradientMethod.
 
void clearCache ()
 Clear the cache to force the gradient to be recomputed.
 
InverseKinematicsgetIK ()
 Returns the IK module that this GradientMethod belongs to.
 
const InverseKinematicsgetIK () const
 Returns the IK module that this GradientMethod belongs to.
 

Protected Types

using IkFastFuncGetInt = int(*)()
 
using IkFastFuncGetIntPtr = int *(*)()
 
using IkFastFuncComputeIk = bool(*)(const IkReal *targetTranspose, const IkReal *targetRotation, const IkReal *freeParams, ikfast::IkSolutionListBase< IkReal > &solutions)
 
using IkFastFuncComputeFk = void(*)(const IkReal *parameters, IkReal *targetTranspose, IkReal *targetRotation)
 
using IkFastFuncGetConstCharPtr = const char *(*)()
 

Protected Member Functions

int getNumFreeParameters () const override
 Returns the number of free parameters users has to set apriori.
 
int * getFreeParameters () const override
 Returns the indicies of the free parameters indexed by the chain joints.
 
int getNumJoints () const override
 Returns the total number of indices of the chane.
 
int getIkRealSize () const override
 Returns the size in bytes of the configured number type.
 
int getIkType () const override
 Returns the IK type.
 
bool computeIk (const IkReal *targetTranspose, const IkReal *targetRotation, const IkReal *freeParams, ikfast::IkSolutionListBase< IkReal > &solutions) override
 Computes the inverse kinematics solutions using the generated IKFast code.
 
void computeFk (const IkReal *parameters, IkReal *targetTranspose, IkReal *targetRotation) override
 Computes the forward kinematics solutions using the generated IKFast code.
 
const char * getKinematicsHash () override
 Returns a hash of all the chain values used for double checking that the correct IK is used.
 
const char * getIkFastVersion () override
 Returns the IkFast version used to generate this file.
 
void configure () const override
 Configure IkFast.
 
virtual void addExtraDofGradient (Eigen::VectorXd &grad, const Eigen::Vector6d &error, ExtraDofUtilization utilization)
 This function will compute a gradient which utilizes the extra DOFs that go unused by the Analytical solution and then it will add the components of that gradient to the output parameter: grad.
 
void checkSolutionJointLimits ()
 Go through the mSolutions vector and tag entries with LIMIT_VIOLATED if any components of their configuration are outside of their position limits.
 
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

std::string mFilePath
 File path to the ikfast shared library.
 
std::shared_ptr< common::SharedLibrarymSharedLibrary
 
IkFastFuncGetInt mGetNumFreeParameters
 
IkFastFuncGetIntPtr mGetFreeParameters
 
IkFastFuncGetInt mGetNumJoints
 
IkFastFuncGetInt mGetIkRealSize
 
IkFastFuncGetInt mGetIkType
 
IkFastFuncComputeIk mComputeIk
 
IkFastFuncComputeFk mComputeFk
 
IkFastFuncGetConstCharPtr mGetKinematicsHash
 
IkFastFuncGetConstCharPtr mGetIkFastVersion
 
std::vector< double > mFreeParams
 
bool mConfigured
 True if this IkFast is ready to solve.
 
std::vector< std::size_t > mDofs
 Indices of the DegreeOfFreedoms associated to the variable parameters of this IkFast.
 
std::vector< std::size_t > mFreeDofs
 Indices of the DegreeOfFreedoms associated to the free parameters of this IkFast.
 
std::vector< SolutionmSolutions
 Vector of solutions.
 
UniqueProperties mAnalyticalP
 Properties for this Analytical IK solver.
 
common::sub_ptr< InverseKinematicsmIK
 The IK module that this GradientMethod belongs to.
 
std::string mMethodName
 The name of this method.
 
Eigen::VectorXd mLastPositions
 The last positions that was passed to this GradientMethod.
 
Eigen::VectorXd mLastGradient
 The last gradient that was computed by this GradientMethod.
 
Properties mGradientP
 Properties for this GradientMethod.
 
std::set< Observer * > mObservers
 List of current Observers.
 

Private Attributes

std::array< IkReal, 9 > mTargetRotation
 Cache data for the target rotation used by IKFast.
 
std::array< IkReal, 3 > mTargetTranspose
 Cache data for the target translation used by IKFast.
 
std::vector< int > mDofMap
 This maps the DOFs provided by getDofs() to their index in the Node's list of dependent DOFs.
 
std::vector< std::size_t > mExtraDofs
 List of extra DOFs in the module which are not covered by the Analytical IK implementation.
 
std::vector< SolutionmValidSolutionsCache
 A cache for the valid solutions.
 
std::vector< SolutionmOutOfReachCache
 A cache for the out of reach solutions.
 
std::vector< SolutionmLimitViolationCache
 A cache for solutions that violate joint limits.
 
Eigen::VectorXd mConfigCache
 A cache for storing the current configuration.
 
Eigen::VectorXd mRestoreConfigCache
 A cache for storing the current configuration so that it can be restored later.
 
Eigen::VectorXd mExtraDofGradCache
 A cache for storing the gradient for the extra DOFs.
 
Eigen::VectorXd mInitialPositionsCache
 Cache used by convertJacobianMethodOutputToGradient to avoid reallocating this vector on each iteration.
 

Detailed Description

IkFast-based analytical inverse kinematics class.

The detail of IkFast can be found here: http://openrave.org/docs/0.8.2/openravepy/ikfast/

Member Typedef Documentation

◆ IkFastFuncComputeFk

using dart::dynamics::SharedLibraryIkFast::IkFastFuncComputeFk = void (*)( const IkReal* parameters, IkReal* targetTranspose, IkReal* targetRotation)
protected

◆ IkFastFuncComputeIk

using dart::dynamics::SharedLibraryIkFast::IkFastFuncComputeIk = bool (*)( const IkReal* targetTranspose, const IkReal* targetRotation, const IkReal* freeParams, ikfast::IkSolutionListBase<IkReal>& solutions)
protected

◆ IkFastFuncGetConstCharPtr

◆ IkFastFuncGetInt

◆ IkFastFuncGetIntPtr

◆ QualityComparison

typedef std::function<bool( const Eigen::VectorXd& _better, const Eigen::VectorXd& _worse, const InverseKinematics* _ik)> dart::dynamics::InverseKinematics::Analytical::QualityComparison
inherited

Member Enumeration Documentation

◆ ExtraDofUtilization

If there are extra DOFs in the IK module which your Analytical solver implementation does not make use of, those DOFs can be used to supplement the analytical solver using Jacobian transpose iteration.

This enumeration is used to indicate whether you want those DOFs to be used before applying the analytical solution, after applying the analytical solution, or not be used at all.

Jacobian transpose is used for the extra DOFs because it is inexpensive and robust to degenerate Jacobians which are common in low dimensional joint spaces. The primary advantage of pseudoinverse methods over Jacobian transpose methods is their precision, but analytical methods are even more precise than pseudoinverse methods, so that precision is not needed in this case.

If you want the extra DOFs to use a different method than Jacobian transpose, you can create two seperate IK modules (one which is analytical and one with the iterative method of your choice) and combine them in a HierarchicalIK.

Enumerator
UNUSED 
PRE_ANALYTICAL 
POST_ANALYTICAL 
PRE_AND_POST_ANALYTICAL 

◆ IkType

Inverse kinematics types supported by IkFast.

Enumerator
TRANSFORM_6D 

End effector reaches desired 6D transformation.

ROTATION_3D 

End effector reaches desired 3D rotation.

TRANSLATION_3D 

End effector origin reaches desired 3D translation.

DIRECTION_3D 

Direction on end effector coordinate system reaches desired direction.

RAY_4D 

Ray on end effector coordinate system reaches desired global ray.

LOOKAT_3D 

Direction on end effector coordinate system points to desired 3D position.

TRANSLATION_DIRECTION_5D 

End effector origin and direction reaches desired 3D translation and direction.

Can be thought of as Ray IK where the origin of the ray must coincide.

TRANSLATION_XY_2D 

End effector origin reaches desired XY translation position, Z is ignored.

The coordinate system with relative to the base link.

TRANSLATION_XY_ORIENTATION_3D 

2D translation along XY plane and 1D rotation around Z axis.

The offset of the rotation is measured starting at +X, so at +X is it 0, at +Y it is pi/2.

TRANSLATION_LOCAL_GLOBAL_6D 

Local point on end effector origin reaches desired 3D global point.

Because both local point and global point can be specified, there are 6 values.

TRANSLATION_X_AXIS_ANGLE_4D 

End effector origin reaches desired 3D translation, manipulator direction makes a specific angle with x-axis (defined in the manipulator base link’s coordinate system)

TRANSLATION_Y_AXIS_ANGLE_4D 

End effector origin reaches desired 3D translation, manipulator direction makes a specific angle with y-axis (defined in the manipulator base link’s coordinate system)

TRANSLATION_Z_AXIS_ANGLE_4D 

End effector origin reaches desired 3D translation, manipulator direction makes a specific angle with z-axis (defined in the manipulator base link’s coordinate system)

TRANSLATION_X_AXIS_ANGLE_Z_NORM_4D 

End effector origin reaches desired 3D translation, manipulator direction needs to be orthogonal to z-axis and be rotated at a certain angle starting from the x-axis (defined in the manipulator base link's coordinate system)

TRANSLATION_Y_AXIS_ANGLE_X_NORM_4D 

End effector origin reaches desired 3D translation, manipulator direction needs to be orthogonal to z-axis and be rotated at a certain angle starting from the y-axis (defined in the manipulator base link's coordinate system)

TRANSLATION_Z_AXIS_ANGLE_Y_NORM_4D 

End effector origin reaches desired 3D translation, manipulator direction needs to be orthogonal to z-axis and be rotated at a certain angle starting from the z-axis (defined in the manipulator base link's coordinate system)

UNKNOWN 

◆ Validity_t

Bitwise enumerations that are used to describe some properties of each solution produced by the analytical IK.

Enumerator
VALID 

The solution is completely valid and reaches the target.

OUT_OF_REACH 

The solution does not reach the target.

LIMIT_VIOLATED 

The solution has one or more joint positions that violate the joint limits.

Constructor & Destructor Documentation

◆ SharedLibraryIkFast()

dart::dynamics::SharedLibraryIkFast::SharedLibraryIkFast ( InverseKinematics ik,
const std::string &  filePath,
const std::vector< std::size_t > &  dofMap,
const std::vector< std::size_t > &  freeDofMap,
const std::string &  methodName = "IKFast",
const Analytical::Properties &  properties = Analytical::Properties() 
)

Constructor.

Parameters
[in]ikThe parent InverseKinematics solver that is associated with this gradient method.
[in]filePathThe path to the shared library of the IkFast binary file
[in]dofMapThe indices to the degrees-of-freedom that will be solved by IkFast. The number of DOFs can be varied depending on the IkFast solvers.
[in]freeDofMapThe indices to the DOFs that are not solved by the IkFast solver. The values of these DOFs should be set properly.
[in]methodNameThe name of this analytical inverse kinematics method.
[in]propertiesProperties of InverseKinematics::Analytical.

Member Function Documentation

◆ addExtraDofGradient()

void dart::dynamics::InverseKinematics::Analytical::addExtraDofGradient ( Eigen::VectorXd &  grad,
const Eigen::Vector6d error,
ExtraDofUtilization  utilization 
)
protectedvirtualinherited

This function will compute a gradient which utilizes the extra DOFs that go unused by the Analytical solution and then it will add the components of that gradient to the output parameter: grad.

You can override this function to customize how the extra DOFs are used. The default behavior is to use a simple Jacobian Transpose method.

The utilization flag will be PRE_ANALYTICAL if the function is being called before the Analytical solution is computed; it will be POST_ANALYTICAL if the function is being called after the Analytical solution is computed.

◆ addObserver()

void dart::common::Subject::addObserver ( Observer _observer) const
protectedinherited

Add an Observer to the list of Observers.

◆ applyWeights()

void dart::dynamics::InverseKinematics::GradientMethod::applyWeights ( Eigen::VectorXd &  _grad) const
inherited

Apply weights to the gradient based on the weight settings of this GradientMethod.

◆ checkSolutionJointLimits()

void dart::dynamics::InverseKinematics::Analytical::checkSolutionJointLimits ( )
protectedinherited

Go through the mSolutions vector and tag entries with LIMIT_VIOLATED if any components of their configuration are outside of their position limits.

This will NOT clear the LIMIT_VIOLATED flag from entries of mSolutions which are already tagged with it, even if they do not violate any limits.

◆ clampGradient()

void dart::dynamics::InverseKinematics::GradientMethod::clampGradient ( Eigen::VectorXd &  _grad) const
inherited

Clamp the gradient based on the clamp settings of this GradientMethod.

◆ clearCache()

void dart::dynamics::InverseKinematics::GradientMethod::clearCache ( )
inherited

Clear the cache to force the gradient to be recomputed.

It should generally not be necessary to call this function.

◆ clone()

auto dart::dynamics::SharedLibraryIkFast::clone ( InverseKinematics _newIK) const -> std::unique_ptr< GradientMethod >
overridevirtual

Enable this GradientMethod to be cloned to a new IK module.

Implements dart::dynamics::InverseKinematics::GradientMethod.

◆ computeFk() [1/2]

Eigen::Isometry3d dart::dynamics::IkFast::computeFk ( const Eigen::VectorXd &  parameters)
inherited

Computes forward kinematics given joint positions where the dimension is the same as getNumJoints2().

◆ computeFk() [2/2]

void dart::dynamics::SharedLibraryIkFast::computeFk ( const IkReal *  parameters,
IkReal *  targetTranspose,
IkReal *  targetRotation 
)
overrideprotectedvirtual

Computes the forward kinematics solutions using the generated IKFast code.

Implements dart::dynamics::IkFast.

◆ computeGradient()

void dart::dynamics::InverseKinematics::Analytical::computeGradient ( const Eigen::Vector6d _error,
Eigen::VectorXd &  _grad 
)
overridevirtualinherited

You should not need to override this function.

Instead, you should override computeSolutions.

Implements dart::dynamics::InverseKinematics::GradientMethod.

◆ computeIk()

bool dart::dynamics::SharedLibraryIkFast::computeIk ( const IkReal *  targetTranspose,
const IkReal *  targetRotation,
const IkReal *  pfree,
ikfast::IkSolutionListBase< IkReal > &  solutions 
)
overrideprotectedvirtual

Computes the inverse kinematics solutions using the generated IKFast code.

Implements dart::dynamics::IkFast.

◆ computeSolutions()

auto dart::dynamics::IkFast::computeSolutions ( const Eigen::Isometry3d &  _desiredBodyTf)
overridevirtualinherited

Use this function to fill the entries of the mSolutions variable.

Be sure to clear the mSolutions vector at the start, and to also return the mSolutions vector at the end. Note that you are not expected to evaluate any of the solutions for their quality. However, you should set the Solution::mValidity flag to OUT_OF_REACH for each solution that does not actually reach the desired transform, and you should call checkSolutionJointLimits() and the end of the function, which will set the LIMIT_VIOLATED flags of any configurations that are outside of the position limits.

Implements dart::dynamics::InverseKinematics::Analytical.

◆ configure()

void dart::dynamics::SharedLibraryIkFast::configure ( ) const
overrideprotectedvirtual

Configure IkFast.

If it's successfully configured, isConfigured() returns true.

Reimplemented from dart::dynamics::IkFast.

◆ constructDofMap()

void dart::dynamics::InverseKinematics::Analytical::constructDofMap ( )
inherited

Construct a mapping from the DOFs of getDofs() to their indices within the Node's list of dependent DOFs.

This will be called immediately after the Analytical is constructed; this one call is sufficient as long as the DOFs of Analytical::getDofs() is not changed. However, if your Analytical is able to change the DOFs that it operates on, then you will need to call this function each time the DOFs have changed.

◆ convertJacobianMethodOutputToGradient()

void dart::dynamics::InverseKinematics::GradientMethod::convertJacobianMethodOutputToGradient ( Eigen::VectorXd &  grad,
const std::vector< std::size_t > &  dofs 
)
inherited

Convert the gradient that gets generated by Jacobian methods into a gradient that can be used by a GradientDescentSolver.

Not all Joint types can be integrated using standard addition (e.g. FreeJoint and BallJoint), therefore Jacobian-based differential methods will tend to generate gradients that cannot be correctly used by a simple addition-based GradientDescentSolver. Running your gradient through this function before returning it will make the gradient suitable for a standard solver.

◆ evalGradient()

void dart::dynamics::InverseKinematics::GradientMethod::evalGradient ( const Eigen::VectorXd &  _q,
Eigen::Map< Eigen::VectorXd >  _grad 
)
inherited

This function is used to handle caching the gradient vector and interfacing with the solver.

◆ getAnalyticalProperties()

InverseKinematics::Analytical::Properties dart::dynamics::InverseKinematics::Analytical::getAnalyticalProperties ( ) const
inherited

Get the Properties for this Analytical class.

◆ getComponentWeights()

const Eigen::VectorXd & dart::dynamics::InverseKinematics::GradientMethod::getComponentWeights ( ) const
inherited

Get the weights of this GradientMethod.

◆ getComponentWiseClamp()

double dart::dynamics::InverseKinematics::GradientMethod::getComponentWiseClamp ( ) const
inherited

Get the component-wise clamp for this GradientMethod.

◆ getDofs()

auto dart::dynamics::IkFast::getDofs ( ) const
overridevirtualinherited

Returns the indices of the DegreeOfFreedoms that are part of the joints that IkFast solves for.

Implements dart::dynamics::InverseKinematics::Analytical.

◆ getExtraDofUtilization()

IK::Analytical::ExtraDofUtilization dart::dynamics::IK::Analytical::getExtraDofUtilization ( ) const
inherited

Get how extra DOFs are being utilized by the IK module.

◆ getExtraErrorLengthClamp()

double dart::dynamics::IK::Analytical::getExtraErrorLengthClamp ( ) const
inherited

Get how much we will clamp the error vector that gets applied to extra DOFs.

◆ getFreeDofs()

const std::vector< std::size_t > & dart::dynamics::IkFast::getFreeDofs ( ) const
inherited

Returns the indices of the DegreeOfFreedoms that are part of the joints that IkFast solves but the values should be set by the user in prior.

◆ getFreeParameters()

int * dart::dynamics::SharedLibraryIkFast::getFreeParameters ( ) const
overrideprotectedvirtual

Returns the indicies of the free parameters indexed by the chain joints.

Implements dart::dynamics::IkFast.

◆ getGradientMethodProperties()

InverseKinematics::GradientMethod::Properties dart::dynamics::InverseKinematics::GradientMethod::getGradientMethodProperties ( ) const
inherited

Get the Properties of this GradientMethod.

◆ getIK() [1/2]

InverseKinematics * dart::dynamics::InverseKinematics::GradientMethod::getIK ( )
inherited

Returns the IK module that this GradientMethod belongs to.

◆ getIK() [2/2]

const InverseKinematics * dart::dynamics::InverseKinematics::GradientMethod::getIK ( ) const
inherited

Returns the IK module that this GradientMethod belongs to.

◆ getIkFastVersion()

const char * dart::dynamics::SharedLibraryIkFast::getIkFastVersion ( )
overrideprotectedvirtual

Returns the IkFast version used to generate this file.

Implements dart::dynamics::IkFast.

◆ getIkFastVersion2()

std::string dart::dynamics::IkFast::getIkFastVersion2 ( ) const
inherited

Returns the IkFast version used to generate this file.

◆ getIkRealSize()

int dart::dynamics::SharedLibraryIkFast::getIkRealSize ( ) const
overrideprotectedvirtual

Returns the size in bytes of the configured number type.

Implements dart::dynamics::IkFast.

◆ getIkType()

int dart::dynamics::SharedLibraryIkFast::getIkType ( ) const
overrideprotectedvirtual

Returns the IK type.

Implements dart::dynamics::IkFast.

◆ getIkType2()

IkFast::IkType dart::dynamics::IkFast::getIkType2 ( ) const
inherited

Returns the IK type.

◆ getKinematicsHash()

const char * dart::dynamics::SharedLibraryIkFast::getKinematicsHash ( )
overrideprotectedvirtual

Returns a hash of all the chain values used for double checking that the correct IK is used.

Implements dart::dynamics::IkFast.

◆ getKinematicsHash2()

const std::string dart::dynamics::IkFast::getKinematicsHash2 ( ) const
inherited

Returns a hash of all the chain values used for double checking that the correct IK is used.

◆ getMethodName()

const std::string & dart::dynamics::InverseKinematics::GradientMethod::getMethodName ( ) const
inherited

Get the name of this GradientMethod.

◆ getNumFreeParameters()

int dart::dynamics::SharedLibraryIkFast::getNumFreeParameters ( ) const
overrideprotectedvirtual

Returns the number of free parameters users has to set apriori.

Implements dart::dynamics::IkFast.

◆ getNumFreeParameters2()

std::size_t dart::dynamics::IkFast::getNumFreeParameters2 ( ) const
inherited

Returns the number of free parameters users has to set apriori.

◆ getNumJoints()

int dart::dynamics::SharedLibraryIkFast::getNumJoints ( ) const
overrideprotectedvirtual

Returns the total number of indices of the chane.

Implements dart::dynamics::IkFast.

◆ getNumJoints2()

std::size_t dart::dynamics::IkFast::getNumJoints2 ( ) const
inherited

Returns the total number of indices of the chane.

◆ getPositions()

Eigen::VectorXd dart::dynamics::InverseKinematics::Analytical::getPositions ( ) const
inherited

Get the configuration of the DOFs.

The components of this vector will correspond to the DOFs provided by getDofs().

◆ getSolutions() [1/2]

const std::vector< IK::Analytical::Solution > & dart::dynamics::IK::Analytical::getSolutions ( )
inherited

Get the solutions for this IK module, along with a tag indicating whether each solution is valid.

This function will assume that you want to use the desired transform given by the IK module's current ErrorMethod.

◆ getSolutions() [2/2]

const std::vector< IK::Analytical::Solution > & dart::dynamics::IK::Analytical::getSolutions ( const Eigen::Isometry3d &  _desiredTf)
inherited

Get the solutions for this IK module, along with a tag indicating whether each solution is valid.

This function will compute the configurations using the given desired transform instead of using the IK module's current ErrorMethod.

◆ isConfigured()

bool dart::dynamics::IkFast::isConfigured ( ) const
virtualinherited

Returns true if this IkFast is ready to solve.

◆ removeObserver()

void dart::common::Subject::removeObserver ( Observer _observer) const
protectedinherited

Remove an Observer from the list of Observers.

◆ resetQualityComparisonFunction()

void dart::dynamics::InverseKinematics::Analytical::resetQualityComparisonFunction ( )
inherited

Reset the quality comparison function to the default method.

◆ sendDestructionNotification()

void dart::common::Subject::sendDestructionNotification ( ) const
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.

◆ setComponentWeights()

void dart::dynamics::InverseKinematics::GradientMethod::setComponentWeights ( const Eigen::VectorXd &  _weights)
inherited

Set the weights that will be applied to each component of the gradient.

If the number of components in _weights is smaller than the number of components in the gradient, then a weight of 1.0 will be applied to all components that are out of the range of _weights. Passing in an empty vector for _weights will effectively make all the gradient components unweighted.

◆ setComponentWiseClamp()

void dart::dynamics::InverseKinematics::GradientMethod::setComponentWiseClamp ( double  _clamp = DefaultIKGradientComponentClamp)
inherited

Set the component-wise clamp for this GradientMethod.

Each component of the gradient will be individually clamped to this size.

◆ setExtraDofUtilization()

void dart::dynamics::InverseKinematics::Analytical::setExtraDofUtilization ( ExtraDofUtilization  _utilization)
inherited

Set how you want extra DOFs to be utilized by the IK module.

◆ setExtraErrorLengthClamp()

void dart::dynamics::IK::Analytical::setExtraErrorLengthClamp ( double  _clamp)
inherited

Set how much to clamp the error vector that gets applied to extra DOFs.

◆ setPositions()

void dart::dynamics::InverseKinematics::Analytical::setPositions ( const Eigen::VectorXd &  _config)
inherited

Set the configuration of the DOFs.

The components of _config must correspond to the DOFs provided by getDofs().

◆ setQualityComparisonFunction()

void dart::dynamics::InverseKinematics::Analytical::setQualityComparisonFunction ( const QualityComparison _func)
inherited

Set the function that will be used to compare the qualities of two solutions.

This function should return true if the first argument is a better solution than the second argument.

By default, it will prefer the solution which has the smallest size for its largest change in joint angle. In other words, for each configuration that it is given, it will compare the largest change in joint angle for each configuration and pick the one that is smallest.

Note that outside of this comparison function, the Solutions will be split between which are valid, which are out-of-reach, and which are in violation of joint limits. Valid solutions will always be ranked above invalid solutions, and joint limit violations will always be ranked last.

Member Data Documentation

◆ mAnalyticalP

UniqueProperties dart::dynamics::InverseKinematics::Analytical::mAnalyticalP
protectedinherited

Properties for this Analytical IK solver.

◆ mComputeFk

IkFastFuncComputeFk dart::dynamics::SharedLibraryIkFast::mComputeFk
mutableprotected

◆ mComputeIk

IkFastFuncComputeIk dart::dynamics::SharedLibraryIkFast::mComputeIk
mutableprotected

◆ mConfigCache

Eigen::VectorXd dart::dynamics::InverseKinematics::Analytical::mConfigCache
privateinherited

A cache for storing the current configuration.

◆ mConfigured

bool dart::dynamics::IkFast::mConfigured
mutableprotectedinherited

True if this IkFast is ready to solve.

◆ mDofMap

std::vector<int> dart::dynamics::InverseKinematics::Analytical::mDofMap
privateinherited

This maps the DOFs provided by getDofs() to their index in the Node's list of dependent DOFs.

This map is constructed by constructDofMap().

◆ mDofs

std::vector<std::size_t> dart::dynamics::IkFast::mDofs
mutableprotectedinherited

Indices of the DegreeOfFreedoms associated to the variable parameters of this IkFast.

◆ mExtraDofGradCache

Eigen::VectorXd dart::dynamics::InverseKinematics::Analytical::mExtraDofGradCache
privateinherited

A cache for storing the gradient for the extra DOFs.

◆ mExtraDofs

std::vector<std::size_t> dart::dynamics::InverseKinematics::Analytical::mExtraDofs
privateinherited

List of extra DOFs in the module which are not covered by the Analytical IK implementation.

The index of each DOF is its dependency index in the JacobianNode (i.e. the column it applies to in the Node's Jacobian).

◆ mFilePath

std::string dart::dynamics::SharedLibraryIkFast::mFilePath
protected

File path to the ikfast shared library.

◆ mFreeDofs

std::vector<std::size_t> dart::dynamics::IkFast::mFreeDofs
mutableprotectedinherited

Indices of the DegreeOfFreedoms associated to the free parameters of this IkFast.

◆ mFreeParams

std::vector<double> dart::dynamics::IkFast::mFreeParams
mutableprotectedinherited

◆ mGetFreeParameters

IkFastFuncGetIntPtr dart::dynamics::SharedLibraryIkFast::mGetFreeParameters
mutableprotected

◆ mGetIkFastVersion

IkFastFuncGetConstCharPtr dart::dynamics::SharedLibraryIkFast::mGetIkFastVersion
mutableprotected

◆ mGetIkRealSize

IkFastFuncGetInt dart::dynamics::SharedLibraryIkFast::mGetIkRealSize
mutableprotected

◆ mGetIkType

IkFastFuncGetInt dart::dynamics::SharedLibraryIkFast::mGetIkType
mutableprotected

◆ mGetKinematicsHash

IkFastFuncGetConstCharPtr dart::dynamics::SharedLibraryIkFast::mGetKinematicsHash
mutableprotected

◆ mGetNumFreeParameters

IkFastFuncGetInt dart::dynamics::SharedLibraryIkFast::mGetNumFreeParameters
mutableprotected

◆ mGetNumJoints

IkFastFuncGetInt dart::dynamics::SharedLibraryIkFast::mGetNumJoints
mutableprotected

◆ mGradientP

Properties dart::dynamics::InverseKinematics::GradientMethod::mGradientP
protectedinherited

Properties for this GradientMethod.

◆ mIK

common::sub_ptr<InverseKinematics> dart::dynamics::InverseKinematics::GradientMethod::mIK
protectedinherited

The IK module that this GradientMethod belongs to.

◆ mInitialPositionsCache

Eigen::VectorXd dart::dynamics::InverseKinematics::GradientMethod::mInitialPositionsCache
privateinherited

Cache used by convertJacobianMethodOutputToGradient to avoid reallocating this vector on each iteration.

◆ mLastGradient

Eigen::VectorXd dart::dynamics::InverseKinematics::GradientMethod::mLastGradient
protectedinherited

The last gradient that was computed by this GradientMethod.

◆ mLastPositions

Eigen::VectorXd dart::dynamics::InverseKinematics::GradientMethod::mLastPositions
protectedinherited

The last positions that was passed to this GradientMethod.

◆ mLimitViolationCache

std::vector<Solution> dart::dynamics::InverseKinematics::Analytical::mLimitViolationCache
privateinherited

A cache for solutions that violate joint limits.

◆ mMethodName

std::string dart::dynamics::InverseKinematics::GradientMethod::mMethodName
protectedinherited

The name of this method.

◆ mObservers

std::set<Observer*> dart::common::Subject::mObservers
mutableprotectedinherited

List of current Observers.

◆ mOutOfReachCache

std::vector<Solution> dart::dynamics::InverseKinematics::Analytical::mOutOfReachCache
privateinherited

A cache for the out of reach solutions.

◆ mRestoreConfigCache

Eigen::VectorXd dart::dynamics::InverseKinematics::Analytical::mRestoreConfigCache
privateinherited

A cache for storing the current configuration so that it can be restored later.

This is different from mConfigCache which will not be used to restore the configuration.

◆ mSharedLibrary

std::shared_ptr<common::SharedLibrary> dart::dynamics::SharedLibraryIkFast::mSharedLibrary
mutableprotected

◆ mSolutions

std::vector<Solution> dart::dynamics::InverseKinematics::Analytical::mSolutions
protectedinherited

Vector of solutions.

◆ mTargetRotation

std::array<IkReal, 9> dart::dynamics::IkFast::mTargetRotation
privateinherited

Cache data for the target rotation used by IKFast.

◆ mTargetTranspose

std::array<IkReal, 3> dart::dynamics::IkFast::mTargetTranspose
privateinherited

Cache data for the target translation used by IKFast.

◆ mValidSolutionsCache

std::vector<Solution> dart::dynamics::InverseKinematics::Analytical::mValidSolutionsCache
privateinherited

A cache for the valid solutions.

The valid and invalid solution caches are kept separate so that they can each be sorted by quality individually. Valid solutions will always be at the top of mFinalResults even if their quality is scored below the invalid solutions.