Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Add approximate solution joint jump threshold parameter #42

Merged
merged 3 commits into from
May 5, 2023

Conversation

sea-bass
Copy link
Collaborator

@sea-bass sea-bass commented May 2, 2023

We have seen some joint jumps when using pick_ik with MoveIt Servo, where approximate solutions are enabled.

This seems to me like a workaround to a deeper bug that we haven't yet found, so keeping in draft for now.

Copy link
Contributor

@tylerjw tylerjw left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems good if it is useful in your testing. Let me know when you'd like me to cut a release.

@tylerjw
Copy link
Contributor

tylerjw commented May 2, 2023

I see the ci failures and will fix those for you separately.

@sea-bass
Copy link
Collaborator Author

sea-bass commented May 2, 2023

I see the ci failures and will fix those for you separately.

I think I just fixed it, was just testing this branch on an older version of pick_ik.

Not sure if I want to merge this yet, so let's hang on until I take this out of draft? When I'm back from vacation I may want to spend a little more time chasing down the root cause instead of slapping yet another parameter on this, if possible.

Specifically, I'm not entirely sure why the position/orientation thresholds passed when the arm was clearly teleporting a large distance, and why the joint angle check is even needed.

@sea-bass
Copy link
Collaborator Author

sea-bass commented May 2, 2023

I took a closer look and everything seems in order... I even checked the thread-safeness of the forward kinematics function thinking maybe something was off there?

This might just be a necessary parameter because approx. solutions with the global solver can really make the arm teleport to a redundant solution.

@sea-bass sea-bass marked this pull request as ready for review May 2, 2023 23:49
@sea-bass sea-bass requested a review from tylerjw May 2, 2023 23:51
@sea-bass
Copy link
Collaborator Author

sea-bass commented May 5, 2023

I finally found what's going on. It's actually nothing to do with pick_ik, so let's for sure merge this @tylerjw.

When MoveIt servo is near a singularity, the Jacobian based twist computation puts the target pose to really weird places. When using a local solver like the built-in one in Servo, KDL, or even pick_ik without the memetic solver, then the IK simply fails and returns the original solution. But pick_ik global solver returns an approximate solution that is closer to this garbage pose.

So... not to brag or anything, but pick_ik is just too good for MoveIt Servo 😎

anyways, adding in this extra "distance from initial joint config" parameter helps protect against these big jumps when the end effector is where it was commanded, but that just happens to be really far from the robot's current state.

@tylerjw tylerjw merged commit a02ca7a into main May 5, 2023
@delete-merged-branch delete-merged-branch bot deleted the approx-joint-threshold branch May 5, 2023 15:00
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants