Public Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
kinematics_metrics::KinematicsMetrics Class Reference

Compute different kinds of metrics for kinematics evaluation. Currently includes manipulability. More...

#include <kinematics_metrics.h>

Public Member Functions

bool getManipulability (const moveit::core::RobotState &state, const moveit::core::JointModelGroup *joint_model_group, double &condition_number, bool translation=false) const
 Get the manipulability = sigma_min/sigma_max where sigma_min and sigma_max are the smallest and largest singular values of the Jacobian matrix J. More...
 
bool getManipulability (const moveit::core::RobotState &state, const std::string &group_name, double &condition_number, bool translation=false) const
 Get the manipulability = sigma_min/sigma_max where sigma_min and sigma_max are the smallest and largest singular values of the Jacobian matrix J. More...
 
bool getManipulabilityEllipsoid (const moveit::core::RobotState &state, const moveit::core::JointModelGroup *joint_model_group, Eigen::MatrixXcd &eigen_values, Eigen::MatrixXcd &eigen_vectors) const
 Get the (translation) manipulability ellipsoid for a given group at a given joint configuration. More...
 
bool getManipulabilityEllipsoid (const moveit::core::RobotState &state, const std::string &group_name, Eigen::MatrixXcd &eigen_values, Eigen::MatrixXcd &eigen_vectors) const
 Get the (translation) manipulability ellipsoid for a given group at a given joint configuration. More...
 
bool getManipulabilityIndex (const moveit::core::RobotState &state, const moveit::core::JointModelGroup *joint_model_group, double &manipulability_index, bool translation=false) const
 Get the manipulability for a given group at a given joint configuration. More...
 
bool getManipulabilityIndex (const moveit::core::RobotState &state, const std::string &group_name, double &manipulability_index, bool translation=false) const
 Get the manipulability for a given group at a given joint configuration. More...
 
const double & getPenaltyMultiplier () const
 
 KinematicsMetrics (const moveit::core::RobotModelConstPtr &robot_model)
 Construct a KinematicsMetricss from a RobotModel. More...
 
void setPenaltyMultiplier (double multiplier)
 

Protected Attributes

moveit::core::RobotModelConstPtr robot_model_
 

Private Member Functions

double getJointLimitsPenalty (const moveit::core::RobotState &state, const moveit::core::JointModelGroup *joint_model_group) const
 Defines a multiplier for the manipulabilty = 1 - exp ( -penalty_multipler_ * product_{i=1}{n} (distance_to_lower_limit * distance_to_higher_limit/(joint_range*joint_range))) where n is the number of joints in the group. Floating joints are ignored in this computation. Planar joints with finite bounds are considered. Set penalty_multiplier_ to 0 if you don't want this multiplier to have any effect on the manipulability measures. See "Workspace Geometric Characterization and Manipulability of Industrial Robots", Ming-June, Tsia, PhD Thesis, Ohio State University, 1986, for more details. More...
 

Private Attributes

double penalty_multiplier_
 

Detailed Description

Compute different kinds of metrics for kinematics evaluation. Currently includes manipulability.

Definition at line 82 of file kinematics_metrics.h.

Constructor & Destructor Documentation

◆ KinematicsMetrics()

kinematics_metrics::KinematicsMetrics::KinematicsMetrics ( const moveit::core::RobotModelConstPtr &  robot_model)
inline

Construct a KinematicsMetricss from a RobotModel.

Definition at line 86 of file kinematics_metrics.h.

Member Function Documentation

◆ getJointLimitsPenalty()

double kinematics_metrics::KinematicsMetrics::getJointLimitsPenalty ( const moveit::core::RobotState state,
const moveit::core::JointModelGroup joint_model_group 
) const
private

Defines a multiplier for the manipulabilty = 1 - exp ( -penalty_multipler_ * product_{i=1}{n} (distance_to_lower_limit * distance_to_higher_limit/(joint_range*joint_range))) where n is the number of joints in the group. Floating joints are ignored in this computation. Planar joints with finite bounds are considered. Set penalty_multiplier_ to 0 if you don't want this multiplier to have any effect on the manipulability measures. See "Workspace Geometric Characterization and Manipulability of Industrial Robots", Ming-June, Tsia, PhD Thesis, Ohio State University, 1986, for more details.

Returns
multiplier that is multiplied with every manipulability measure computed here

Definition at line 76 of file kinematics_metrics.cpp.

◆ getManipulability() [1/2]

bool kinematics_metrics::KinematicsMetrics::getManipulability ( const moveit::core::RobotState state,
const moveit::core::JointModelGroup joint_model_group,
double &  condition_number,
bool  translation = false 
) const

Get the manipulability = sigma_min/sigma_max where sigma_min and sigma_max are the smallest and largest singular values of the Jacobian matrix J.

Parameters
stateComplete kinematic state for the robot
joint_model_groupA pointer to the desired joint model group
condition_numberCondition number for JJ^T
Returns
False if the group was not found

Definition at line 237 of file kinematics_metrics.cpp.

◆ getManipulability() [2/2]

bool kinematics_metrics::KinematicsMetrics::getManipulability ( const moveit::core::RobotState state,
const std::string &  group_name,
double &  condition_number,
bool  translation = false 
) const

Get the manipulability = sigma_min/sigma_max where sigma_min and sigma_max are the smallest and largest singular values of the Jacobian matrix J.

Parameters
stateComplete kinematic state for the robot
group_nameThe group name (e.g. "arm")
condition_numberCondition number for JJ^T
Returns
False if the group was not found

Definition at line 227 of file kinematics_metrics.cpp.

◆ getManipulabilityEllipsoid() [1/2]

bool kinematics_metrics::KinematicsMetrics::getManipulabilityEllipsoid ( const moveit::core::RobotState state,
const moveit::core::JointModelGroup joint_model_group,
Eigen::MatrixXcd &  eigen_values,
Eigen::MatrixXcd &  eigen_vectors 
) const

Get the (translation) manipulability ellipsoid for a given group at a given joint configuration.

Parameters
stateComplete kinematic state for the robot
joint_model_groupA pointer to the desired joint model group
eigen_valuesThe eigen values for the translation part of JJ^T
eigen_vectorsThe eigen vectors for the translation part of JJ^T
Returns
False if the group was not found

Definition at line 208 of file kinematics_metrics.cpp.

◆ getManipulabilityEllipsoid() [2/2]

bool kinematics_metrics::KinematicsMetrics::getManipulabilityEllipsoid ( const moveit::core::RobotState state,
const std::string &  group_name,
Eigen::MatrixXcd &  eigen_values,
Eigen::MatrixXcd &  eigen_vectors 
) const

Get the (translation) manipulability ellipsoid for a given group at a given joint configuration.

Parameters
stateComplete kinematic state for the robot
group_nameThe group name (e.g. "arm")
eigen_valuesThe eigen values for the translation part of JJ^T
eigen_vectorsThe eigen vectors for the translation part of JJ^T
Returns
False if the group was not found

Definition at line 197 of file kinematics_metrics.cpp.

◆ getManipulabilityIndex() [1/2]

bool kinematics_metrics::KinematicsMetrics::getManipulabilityIndex ( const moveit::core::RobotState state,
const moveit::core::JointModelGroup joint_model_group,
double &  manipulability_index,
bool  translation = false 
) const

Get the manipulability for a given group at a given joint configuration.

Parameters
stateComplete kinematic state for the robot
joint_model_groupA pointer to the desired joint model group
manipulability_indexThe computed manipulability = sqrt(det(JJ^T))
Returns
False if the group was not found

Definition at line 136 of file kinematics_metrics.cpp.

◆ getManipulabilityIndex() [2/2]

bool kinematics_metrics::KinematicsMetrics::getManipulabilityIndex ( const moveit::core::RobotState state,
const std::string &  group_name,
double &  manipulability_index,
bool  translation = false 
) const

Get the manipulability for a given group at a given joint configuration.

Parameters
stateComplete kinematic state for the robot
group_nameThe group name (e.g. "arm")
manipulability_indexThe computed manipulability = sqrt(det(JJ^T))
Returns
False if the group was not found

Definition at line 126 of file kinematics_metrics.cpp.

◆ getPenaltyMultiplier()

const double& kinematics_metrics::KinematicsMetrics::getPenaltyMultiplier ( ) const
inline

Definition at line 164 of file kinematics_metrics.h.

◆ setPenaltyMultiplier()

void kinematics_metrics::KinematicsMetrics::setPenaltyMultiplier ( double  multiplier)
inline

Definition at line 159 of file kinematics_metrics.h.

Member Data Documentation

◆ penalty_multiplier_

double kinematics_metrics::KinematicsMetrics::penalty_multiplier_
private

Definition at line 188 of file kinematics_metrics.h.

◆ robot_model_

moveit::core::RobotModelConstPtr kinematics_metrics::KinematicsMetrics::robot_model_
protected

Definition at line 170 of file kinematics_metrics.h.


The documentation for this class was generated from the following files:


moveit_core
Author(s): Ioan Sucan , Sachin Chitta , Acorn Pooley
autogenerated on Tue Dec 24 2024 03:27:15