-
Notifications
You must be signed in to change notification settings - Fork 124
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
Thoughts on supporting position and velocity PID control with Gazebo API #133
Comments
It took me a while to realize what you describe as "kinematic teleportation", see #172 😄 What you propose makes sense to me and is the way that velocity interface is implemented with, e.g., Isaac Sim. I had the same problem as you describe (velocity-controlled real hardware). I solved this by creating a fork of |
I'm glad you deciphered "kinematic teleportation" 😆 . I think I actually found that phrase in the Gazebo API docs and I kind of like it. I also made a fork and implemented PID control in What ultimately led me to writing a new plugin was that I didn't love how gazebo_ros2_control creates the controller manager and controller nodes for you from the urdf and yaml files. I preferred to start those nodes separately in a launch file so I could pass additional arguments and parameters to them. Looks like there's an issue for this here: #70. I didn't try to tackle it because it seemed like some pretty big changes that would be difficult to keep backwards compatibility. |
I don't know why gazebo_ros2_control was designed like this, I'll ask and comment on #70 If you'd like to create a PR with your velocity-controlled joints, I'm happy to review 😉 |
Hello! I saw some discussion about position and velocity PID control being removed from gazebo_ros2_control. I’m assuming this was to consolidate control logic in ros2_controllers effort_controllers/joint_position_controller and effort_controllers/joint_velocity_control?
The issue I’m running into is that using position or velocity interface with gazebo_ros2_control results in kinematic teleportation rather than simulated physics to move the joints. My guess is that the recommended solution is to use the effort controllers mentioned above (once they are ported to ros2_controllers).
However, I’m curious to hear what people think about adding support in gazebo_ros2_control to push the control logic to the simulation by using Gazebo’s JointController class in the
GazeboSystem::write
method? The advantage to this is that from an application level, it allows a direct swap between simulation and physical hardware by simply loading a different hardware interface plugin.In my experience it is common to have motor controllers with position and velocity command interfaces so the ros2_controllers I typically use are joint_trajectory_controller (with position and/or velocity command interface), position_controllers/joint_group_position_controller, and velocity_controllers/joint_group_velocity_controller. By pushing the control logic to Gazebo, it would more directly mirror the physical hardware where joint-level control is handled by the motor controllers instead of at the robot application level. Then I could keep using the same ros2 controllers between simulation and hardware instead of having a ros2 control effort controller just for simulation.
Thoughts?
The text was updated successfully, but these errors were encountered: