-
Notifications
You must be signed in to change notification settings - Fork 405
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add free drive mode support #718
base: master
Are you sure you want to change the base?
Add free drive mode support #718
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
tested on AMC-H 👍
Hi, thank you for contributing to this project. However, there are already two PRs open with that functionality. If you have anything to add there, please comment in those. |
@fmauch the initial prs/drafts
already have been working for us - as commented - but were not merged due to #546 (comment) and the work done in UniversalRobots/Universal_Robots_Client_Library#138 now #718 makes use of said URCL extension and still was closed in favor of the older, declined PRs above... |
@fmauch |
One problem is time. We are currently following up on this and plan to get it to a mergeable state until ROSCon. @VinDp will mainly work on this.
I mainly closed this one because it was the third one and id didn't mention looking at the others. I've taken a closer look at #546, #573 and this one and indeed, this one seems to have the best approach. Sorry for not looking at this in more detail before. That being said, I see one main concern about this approach: Since this is using the freedrive support of the ur_driver, the reverse_interfaces is being kept active, so any other controller will stay active. From my understanding that would mean that the JTC will keep sending the last position of the latest trajectory all the time. Once freedrive mode is exited, the program running on the robot will return to reading the commands being sent on the reverse interface which will still be the old ones, I suppose. @VinDp will test this on a real robot later this week to confirm / disprove my assumption. I would much more love to have this into an own controller that can actually claim the command interfaces, so the JTC has to be deactivated and re-activated explicitly. We'll do that for ROS 2 as we don't have the option to advertise ROS interfaces from the hardware interface directly. |
thanks @fmauch @VinDp for getting back at this |
We've just tested things and unfortunately my assumption was correct. The robot didn't jump in our faces because of UniversalRobots/Universal_Robots_Client_Library#184 but it would have moved back to the place where it was before activating freedrive, as the joint controller keeps setting the same command. I think the only way to get around this safely is to enforce not having a controller active while freedrive is active. The most reliable way for doing that would be to wrap the freedrive functionality into a separate controller as we plan to do in ROS 2. |
Suggested implementation of a free drive mode capability.
ref: #525