moveit2
The MoveIt Motion Planning Framework for ROS 2.
|
Representation and evaluation of kinematic constraints. More...
Classes | |
struct | ConstraintEvaluationResult |
Struct for containing the results of constraint evaluation. More... | |
class | KinematicConstraint |
Base class for representing a kinematic constraint. More... | |
class | JointConstraint |
Class for handling single DOF joint constraints. More... | |
class | OrientationConstraint |
Class for constraints on the orientation of a link. More... | |
class | PositionConstraint |
Class for constraints on the XYZ position of a link. More... | |
class | VisibilityConstraint |
Class for constraints on the visibility relationship between a sensor and a target. More... | |
class | KinematicConstraintSet |
A class that contains many different constraints, and can check RobotState *versus the full set. A set is satisfied if and only if all constraints are satisfied. More... | |
Functions | |
MOVEIT_CLASS_FORWARD (KinematicConstraint) | |
MOVEIT_CLASS_FORWARD (JointConstraint) | |
MOVEIT_CLASS_FORWARD (OrientationConstraint) | |
MOVEIT_CLASS_FORWARD (PositionConstraint) | |
MOVEIT_CLASS_FORWARD (VisibilityConstraint) | |
MOVEIT_CLASS_FORWARD (KinematicConstraintSet) | |
moveit_msgs::msg::Constraints | mergeConstraints (const moveit_msgs::msg::Constraints &first, const moveit_msgs::msg::Constraints &second) |
Merge two sets of constraints into one. More... | |
bool | isEmpty (const moveit_msgs::msg::Constraints &constr) |
Check if any constraints were specified. More... | |
std::size_t | countIndividualConstraints (const moveit_msgs::msg::Constraints &constr) |
moveit_msgs::msg::Constraints | constructGoalConstraints (const moveit::core::RobotState &state, const moveit::core::JointModelGroup *jmg, double tolerance_below, double tolerance_above) |
Generates a constraint message intended to be used as a goal constraint for a joint group. The full constraint will contain a vector of type JointConstraint, one for each DOF in the group. More... | |
moveit_msgs::msg::Constraints | constructGoalConstraints (const moveit::core::RobotState &state, const moveit::core::JointModelGroup *jmg, double tolerance=std::numeric_limits< double >::epsilon()) |
Generates a constraint message intended to be used as a goal constraint for a joint group. The full constraint will contain a vector of type JointConstraint, one for each DOF in the group. More... | |
moveit_msgs::msg::Constraints | constructGoalConstraints (const std::string &link_name, const geometry_msgs::msg::PoseStamped &pose, double tolerance_pos=1e-3, double tolerance_angle=1e-2) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint will contain a PositionConstraint and a OrientationConstraint, constructed from the pose. A sphere will be used to represent the constraint region for the PositionConstraint. More... | |
moveit_msgs::msg::Constraints | constructGoalConstraints (const std::string &link_name, const geometry_msgs::msg::PoseStamped &pose, const std::vector< double > &tolerance_pos, const std::vector< double > &tolerance_angle) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint will contain a PositionConstraint and a OrientationConstraint, constructed from the pose. A box will be used to represent the constraint region for the PositionConstraint. More... | |
moveit_msgs::msg::Constraints | constructGoalConstraints (const std::string &link_name, const geometry_msgs::msg::QuaternionStamped &quat, double tolerance=1e-2) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint message will contain only an OrientationConstraint. More... | |
moveit_msgs::msg::Constraints | constructGoalConstraints (const std::string &link_name, const geometry_msgs::msg::Point &reference_point, const geometry_msgs::msg::PointStamped &goal_point, double tolerance=1e-3) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint message will contain only a PositionConstraint. A sphere will be used to represent the constraint region. More... | |
moveit_msgs::msg::Constraints | constructGoalConstraints (const std::string &link_name, const geometry_msgs::msg::PointStamped &goal_point, double tolerance=1e-3) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint message will contain only a PositionConstraint. A sphere will be used to represent the constraint region. More... | |
bool | constructConstraints (const rclcpp::Node::SharedPtr &node, const std::string &constraints_param, moveit_msgs::msg::Constraints &constraints) |
extract constraint message from node parameters. More... | |
bool | resolveConstraintFrames (const moveit::core::RobotState &state, moveit_msgs::msg::Constraints &constraints) |
Resolves frames used in constraints to links in the robot model. More... | |
template<typename Derived > | |
std::tuple< Eigen::Matrix< typename Eigen::MatrixBase< Derived >::Scalar, 3, 1 >, bool > | CalcEulerAngles (const Eigen::MatrixBase< Derived > &R) |
Representation and evaluation of kinematic constraints.
std::tuple<Eigen::Matrix<typename Eigen::MatrixBase<Derived>::Scalar, 3, 1>, bool> kinematic_constraints::CalcEulerAngles | ( | const Eigen::MatrixBase< Derived > & | R | ) |
This's copied from https://gitlab.com/libeigen/eigen/-/blob/master/unsupported/Eigen/src/EulerAngles/EulerSystem.h#L187 Return the intrinsic Roll-Pitch-Yaw euler angles given the input rotation matrix and boolean indicating whether the there's a singularity in the input rotation matrix (true: the input rotation matrix don't have a singularity, false: the input rotation matrix have a singularity) The returned angles are in the ranges [-pi:pi]x[-pi/2:pi/2]x[-pi:pi]
Definition at line 88 of file kinematic_constraint.cpp.
bool kinematic_constraints::constructConstraints | ( | const rclcpp::Node::SharedPtr & | node, |
const std::string & | constraints_param, | ||
moveit_msgs::msg::Constraints & | constraints | ||
) |
extract constraint message from node parameters.
This can be used to construct a Constraints message from specifications provided from a yaml file. An example for a constraint yaml structure (loaded at constraint_param): """ name: constraint_name constraint_ids: [constraint_1, constraint_2] constraints: constraint_1: type: orientation frame_id: world link_name: tool0 orientation: [0, 0, 0] # [r, p, y] tolerances: [0.01, 0.01, 3.15] weight: 1.0 constraint_2: type: position frame_id: base_link link_name: tool0 target_offset: [0.1, 0.1, 0.1] # [x, y, z] region: x: [0.1, 0.4] # [min, max] y: [0.2, 0.3] z: [0.1, 0.6] weight: 1.0 """
[in] | params | Node node to load the parameters from |
[in] | params | string namespace from where to load the constraints parameters |
[out] | constraints | The constructed constraints message |
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const moveit::core::RobotState & | state, |
const moveit::core::JointModelGroup * | jmg, | ||
double | tolerance = std::numeric_limits<double>::epsilon() |
||
) |
Generates a constraint message intended to be used as a goal constraint for a joint group. The full constraint will contain a vector of type JointConstraint, one for each DOF in the group.
[in] | state | The state from which to generate goal joint constraints |
[in] | jmg | The group for which to generate joint constraints |
[in] | tolerance | A tolerance to apply both above and below for all constraints |
Definition at line 138 of file utils.cpp.
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const moveit::core::RobotState & | state, |
const moveit::core::JointModelGroup * | jmg, | ||
double | tolerance_below, | ||
double | tolerance_above | ||
) |
Generates a constraint message intended to be used as a goal constraint for a joint group. The full constraint will contain a vector of type JointConstraint, one for each DOF in the group.
[in] | state | The state from which to generate goal joint constraints |
[in] | jmg | The group for which to generate goal joint constraints |
[in] | tolerance_below | The below tolerance to apply to all constraints |
[in] | tolerance_above | The above tolerance to apply to all constraints |
Definition at line 144 of file utils.cpp.
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const std::string & | link_name, |
const geometry_msgs::msg::Point & | reference_point, | ||
const geometry_msgs::msg::PointStamped & | goal_point, | ||
double | tolerance = 1e-3 |
||
) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint message will contain only a PositionConstraint. A sphere will be used to represent the constraint region.
[in] | link_name | The link name for the PositionConstraint |
[in] | reference_point | A point corresponding to the target_point_offset of the PositionConstraint |
[in] | goal_point | The position associated with the constraint region |
[in] | tolerance | The radius associated with the sphere volume associated with the constraint region |
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const std::string & | link_name, |
const geometry_msgs::msg::PointStamped & | goal_point, | ||
double | tolerance = 1e-3 |
||
) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint message will contain only a PositionConstraint. A sphere will be used to represent the constraint region.
[in] | link_name | The link name for the PositionConstraint |
[in] | goal_point | The position associated with the constraint region |
[in] | tolerance | The radius associated with the sphere volume associated with the constraint region |
Definition at line 248 of file utils.cpp.
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const std::string & | link_name, |
const geometry_msgs::msg::PoseStamped & | pose, | ||
const std::vector< double > & | tolerance_pos, | ||
const std::vector< double > & | tolerance_angle | ||
) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint will contain a PositionConstraint and a OrientationConstraint, constructed from the pose. A box will be used to represent the constraint region for the PositionConstraint.
[in] | link_name | The link name for both constraints |
[in] | pose | The pose stamped to be used for the target region. |
[in] | tolerance_pos | The dimensions of the box (xyz) associated with the target region of the PositionConstraint |
[in] | tolerance_angle | The values to assign to the absolute tolerances (xyz) of the OrientationConstraint |
Definition at line 206 of file utils.cpp.
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const std::string & | link_name, |
const geometry_msgs::msg::PoseStamped & | pose, | ||
double | tolerance_pos = 1e-3 , |
||
double | tolerance_angle = 1e-2 |
||
) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint will contain a PositionConstraint and a OrientationConstraint, constructed from the pose. A sphere will be used to represent the constraint region for the PositionConstraint.
[in] | link_name | The link name for both constraints |
[in] | pose | The pose stamped to be used for the target region. |
[in] | tolerance_pos | The dimension of the sphere associated with the target region of the PositionConstraint |
[in] | tolerance_angle | The value to assign to the absolute tolerances of the OrientationConstraint |
moveit_msgs::msg::Constraints kinematic_constraints::constructGoalConstraints | ( | const std::string & | link_name, |
const geometry_msgs::msg::QuaternionStamped & | quat, | ||
double | tolerance = 1e-2 |
||
) |
Generates a constraint message intended to be used as a goal constraint for a given link. The full constraint message will contain only an OrientationConstraint.
[in] | link_name | The link name for the OrientationConstraint |
[in] | quat | The quaternion for the OrientationConstraint |
[in] | tolerance | The absolute axes tolerances to apply to the OrientationConstraint |
std::size_t kinematic_constraints::countIndividualConstraints | ( | const moveit_msgs::msg::Constraints & | constr | ) |
bool kinematic_constraints::isEmpty | ( | const moveit_msgs::msg::Constraints & | constr | ) |
moveit_msgs::msg::Constraints kinematic_constraints::mergeConstraints | ( | const moveit_msgs::msg::Constraints & | first, |
const moveit_msgs::msg::Constraints & | second | ||
) |
Merge two sets of constraints into one.
This just does appending of all constraints except joint constraints. For members of type JointConstraint, the bounds specified in the parameter first take precedence over parameter second
[in] | first | The first constraint to merge |
[in] | second | The second constraint to merge |
Definition at line 56 of file utils.cpp.
kinematic_constraints::MOVEIT_CLASS_FORWARD | ( | JointConstraint | ) |
kinematic_constraints::MOVEIT_CLASS_FORWARD | ( | KinematicConstraint | ) |
kinematic_constraints::MOVEIT_CLASS_FORWARD | ( | KinematicConstraintSet | ) |
kinematic_constraints::MOVEIT_CLASS_FORWARD | ( | OrientationConstraint | ) |
kinematic_constraints::MOVEIT_CLASS_FORWARD | ( | PositionConstraint | ) |
kinematic_constraints::MOVEIT_CLASS_FORWARD | ( | VisibilityConstraint | ) |
bool kinematic_constraints::resolveConstraintFrames | ( | const moveit::core::RobotState & | state, |
moveit_msgs::msg::Constraints & | constraints | ||
) |
Resolves frames used in constraints to links in the robot model.
The link_name field of a constraint is changed from the name of an object's frame or subframe to the name of the robot link that the object is attached to.
This is used in a planning request adapter which ensures that the planning problem is defined properly (the attached objects' frames are not known to the planner).
[in] | state | The RobotState used to resolve frames. |
[in] | constraints | The constraint to resolve. |