Skip to content
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

[Proposal] Drive to point/configuration controller plugin for wheeled vehicles #2379

Open
sauk2 opened this issue Apr 22, 2024 · 3 comments · May be fixed by #2679
Open

[Proposal] Drive to point/configuration controller plugin for wheeled vehicles #2379

sauk2 opened this issue Apr 22, 2024 · 3 comments · May be fixed by #2679
Assignees
Labels
enhancement New feature or request

Comments

@sauk2
Copy link
Contributor

sauk2 commented Apr 22, 2024

Desired behavior

Currently, Gazebo provides plugins for wheeled vehicles/robots (DiffDrive, AckermannSteering) that work using /cmd_vel and can be integrated with velocity-based controllers (VelocityControl) for precise movement. However, this may not always work for use cases requiring movement to a specific position on the global map. A position controller plugin for wheeled vehicles would address this gap, making it convenient to simulate point-to-point movement without the need to write external controllers or use other packages.

Alternatives considered

  • Using existing velocity-based controllers
  • Implementing controllers within ROS and sending commands over ros-gz-bridge

Implementation suggestion

Control problem

Note: The implementation follows the ideas outlined in Chapter 4 (pp. 130-141) of Corke et. al.[1]

The vehicle uses a bicycle model to describe its behaviour.

image
Figure 1: Bicycle model of a wheeled vehicle [1]

The following equations describe the control of a vehicle moving towards a goal $(x^{*}, y^{*})$ from its current position $(x, y)$

The linear error is minimised using the following equation,

$$v^{*} = K_v \sqrt{ (x^{*} - x)^2 + (y^{*} - y)^2 }$$

Angular error (in radians) is minimised using the following equations. The result should lie in the interval $[-\pi, \pi)$

$$\theta^{*} = atan2 \left( \frac{y^{*} - y}{x^{*} - x} \right)$$

$$\psi = K_h ( \theta^{*} - \theta )$$

Plugin structure

  • The plugin is attached to a model and should be used with DiffDrive and OdometryPublisher plugins.
  • It contains a callback to receive a position command and convert it to linear and angular velocities to be published on /cmd_vel (subscribed by DiffDrive)
  • The SDF is used to define linear P-gain, angular P-gain and allowable linear deviation that will be extracted during plugin initialisation.
  • The plugin implements the Configure function to subscribe to the position command topic and create a publisher for velocity messages.
  • The PostUpdate callback contains the logic described by the equations. The heading and linear errors are calculated and the velocity is published to /cmd_vel.
  • This is carried out by comparing the current position against the target position to calculate the linear and angular velocity commands.
  • A zero velocity command is published once the vehicle reaches the commanded position or falls inside the linear deviation.

Additional context

Result

Implementation of a simple 'drive to point' controller tested on the model used in the DiffDrive example.

diff_drive_controller.mp4

References

[1] Corke, P., Jachimczyk, W., Pillat, R. (2023). Mobile Robot Vehicles. In: Robotics, Vision and Control. Springer Tracts in Advanced Robotics, vol 147. Springer, Cham. https://doi.org/10.1007/978-3-031-07262-8_4

@sauk2 sauk2 added the enhancement New feature or request label Apr 22, 2024
@azeey
Copy link
Contributor

azeey commented May 24, 2024

@sauk2 are you interested in implementing this yourself?

@sauk2
Copy link
Contributor Author

sauk2 commented May 25, 2024

@sauk2 are you interested in implementing this yourself?

@azeey Yes, I can work on this implementation.

@azeey
Copy link
Contributor

azeey commented Jun 18, 2024

Thanks! I've assigned it to you.

@azeey azeey moved this from Inbox to To do in Core development Jul 15, 2024
@sauk2 sauk2 linked a pull request Nov 17, 2024 that will close this issue
9 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
Status: To do
Development

Successfully merging a pull request may close this issue.

2 participants