Skip to content

Commit

Permalink
Handle edge case in calcJacobianTransformErrorDiff
Browse files Browse the repository at this point in the history
  • Loading branch information
Levi-Armstrong committed Jul 13, 2024
1 parent 0de0151 commit e44b7c3
Showing 1 changed file with 6 additions and 5 deletions.
11 changes: 6 additions & 5 deletions tesseract_common/src/utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -172,11 +172,12 @@ Eigen::VectorXd calcJacobianTransformErrorDiff(const Eigen::Isometry3d& target,
std::pair<Eigen::Vector3d, double> perturbed_pose_rotation_err =
calcRotationalErrorDecomposed(perturbed_pose_err.rotation());

// They should always pointing in the same direction
#ifndef NDEBUG
if (std::abs(pose_rotation_err.second) > 0.01 && perturbed_pose_rotation_err.first.dot(pose_rotation_err.first) < 0)
throw std::runtime_error("calcJacobianTransformErrorDiff, angle axes are pointing in oposite directions!");
#endif
// They should always pointing in the same direction, but when error is close to zero this can flip so we will correct
if (perturbed_pose_rotation_err.first.dot(pose_rotation_err.first) < 0)
{
perturbed_pose_rotation_err.first *= -1;
perturbed_pose_rotation_err.second *= -1;
}

// Angle axis has a discontinity at PI so need to correctly handle this calculating jacobian difference
Eigen::VectorXd perturbed_err;
Expand Down

0 comments on commit e44b7c3

Please sign in to comment.