Skip to content

Commit

Permalink
[effort_controllers] JointGroupPositionController: Check output of an…
Browse files Browse the repository at this point in the history
…gles::shortest_angular_distance_with_large_limits

The current implementation does not check the output of
angles::shortest_angular_distance_with_large_limits which indicates if
the returned distance is an unspecified (and potentially wrong) case.

This commit checks the return statement and adds a detailed warning.

Secondly, the implementation in
angles::shortest_angular_distance_with_large_limits is only valid if the
`from` argument is within the range given by the upper and lower joint
limit. As thus, the current_position is now enforced/clamped to the
joint limits.
  • Loading branch information
wxmerkt committed Sep 3, 2020
1 parent 745f2ab commit edc35b3
Showing 1 changed file with 15 additions and 1 deletion.
16 changes: 15 additions & 1 deletion effort_controllers/src/joint_group_position_controller.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -150,12 +150,26 @@ namespace effort_controllers
// Compute position error
if (joint_urdfs_[i]->type == urdf::Joint::REVOLUTE)
{
angles::shortest_angular_distance_with_large_limits(
// angles::shortest_angular_distance_with_large_limits assumes implicitly (and only works correctly) if
// current_position (`from`) is within the valid range. As thus, we need to enforce the joint limits
// prior to passing it as an argument to angles::shortest_angular_distance_with_large_limits:
enforceJointLimits(current_position, i);

bool is_valid = angles::shortest_angular_distance_with_large_limits(
current_position,
command_position,
joint_urdfs_[i]->limits->lower,
joint_urdfs_[i]->limits->upper,
error);

// Warn if angles::shortest_angular_distance_with_large_limits indicates that it could not correctly
// determine the error. This could potentially lead to unsafe behaviour.
// Note, an epsilon margin to reduce the enforced joint limits by a small epsilon could resolve a
// number of floating point issues in angles::shortest_angular_distance_with_large_limits.
if (!is_valid)
{
ROS_WARN_STREAM("Error in angles::shortest_angular_distance_with_large_limits for joint #" << i << ", q_current=" << current_position << ", q_command=" << command_position << ", q_lb=" << joint_urdfs_[i]->limits->lower << ", q_ub=" << joint_urdfs_[i]->limits->upper << ", error=" << error << " - NOT SAFE!");
}
}
else if (joint_urdfs_[i]->type == urdf::Joint::CONTINUOUS)
{
Expand Down

0 comments on commit edc35b3

Please sign in to comment.