-
Notifications
You must be signed in to change notification settings - Fork 526
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
Adding a hybrid JointTrajectory/velocity-forwarding controller. #383
base: kinetic-devel
Are you sure you want to change the base?
Adding a hybrid JointTrajectory/velocity-forwarding controller. #383
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.
Thanks for your contribution!
I am not sure if we can merge this as-is, because the behavior is not well-defined in case the velocity command gets processed while an action is active.
In addition it is not really generic, because it only works for the velocity interface.
IMHO this behavior should be implemented by switching the controllers instead, example: cob_control_mode_adapter.
It was motivated by the annoyance of unloading and loading a new controller when I wanted to switch types.
You only need to load each controller once. Afterwards you can switch between them easily.
...trajectory_controller/include/joint_trajectory_controller/joint_trajectory_controller_impl.h
Show resolved
Hide resolved
traj_or_jog_controller/include/traj_or_jog_controller/export_traj_or_jog_controllers.h
Outdated
Show resolved
Hide resolved
traj_or_jog_controller/include/traj_or_jog_controller/traj_or_jog_controller.h
Show resolved
Hide resolved
Thank you, @ipa-mdl. I took care of the minor comments. I think that leaves just a few more things to discuss: 1. The velocity is not well-defined when trajectory execution is interrupted. The most recent commit adds a setHoldPosition() and a stopping() to make sure the robot halts (briefly, in a controlled way) when a trajectory is interrupted by a real-time command. Here's a video of how that looks at full speed. The trajectory is upward, the initial jogging is downward. 2. The controller is not generic. I changed the namespace so it's under /velocity_controllers/TrajOrJogController, i.e. just another generic velocity controller. There's no reason why a position version wouldn't work, too, but it will take some work to blend the commands. 3. It makes more sense to manage controller switching with a separate, multiplexer-like node. In my opinion that's not true, although I'm glad to have the sample code you pointed me to. That's more complexity and an extra 300+ lines of code. Ideally, you would have only one controller running and it could accept any command type, no switching needed. This moves toward the ideal solution. |
Thanks for your updates, I will review them later.
The switching(=controller managing) is the whole point of
That's no sample code. It's a released, ready-for-use node, which enables switching between trajectory, velocity or position control with a silence filter. I think 300 lines of code are quite fair ;) |
@ipa-mdl OK, thanks for the comments, although I don't completely agree. I still think the management of controller switching with a separate multiplexer node introduces extra latency and complexity. Might as well put both velocity controller types together since it takes very little effort to do so and the pause during switching will be minimized. Also, why did the authors define so many functions as virtual if they did not intend for these basic controllers to be expanded? Let me ask a question... I need to implement a compliance controller. It will probably be a node that publishes a vector of joint speeds. These compliance joint speeds should sum with the vector of joint speeds to a JointTrajectoryController or a JointGroupVelocityController. What is your vision of how something like that should be implemented? I am interested in your opinion so I have a shot at getting it merged. Let me know if I need to explain what compliance is. Some options I can think of:
Thanks! I'm interested in what @bmagyar has to say, too. |
@AndyZe could you better motivate why you think that? I'm not sure what I think about this debate between modular controllers vs hybrid controllers that have multiple controllers within them. |
Let's look at it this way. Who do you think does the best motion control in the world? Boston Dynamics, I would say. I don't think Boston Dynamics is pausing to load and unload controllers. |
That's a bit of an argument by authority. |
This is a new type of controller that accepts trajectory goals or real-time jogging commands. It can switch between the two smoothly. It was motivated by the annoyance of unloading and loading a new controller when I wanted to switch types. I would also like to inherit from this controller, later on, to make a compliant controller that can accept trajectories or velocity commands. This seems like the first step towards that goal.
It inherits from JointTrajectoryController and executes trajectories pretty much the same way. There is a bit of code added, on top of that, to accept real-time commands and forward them, like a JointGroupVelocityController. The real-time commands always interrupt trajectory execution if there is an active trajectory.
Here's a video of testing on a hardware UR3. It shows a couple trajectory/jog/trajectory/jog cycles.