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

Identify and fix problem with servo jerk limiter sometimes stopping truck to long when making low speed precision adjustments during move_base (teb) #2

Open
samiamlabs opened this issue Jun 17, 2017 · 6 comments
Labels

Comments

@samiamlabs
Copy link
Owner

No description provided.

@samiamlabs samiamlabs changed the title Identify and fix problem with servo jerk limiter "locking" sometimes stopping truck when making low speed precision adjustments Identify and fix problem with servo jerk limiter sometimes stopping truck to long when making low speed precision adjustments Jun 17, 2017
@samiamlabs samiamlabs changed the title Identify and fix problem with servo jerk limiter sometimes stopping truck to long when making low speed precision adjustments Identify and fix problem with servo jerk limiter sometimes stopping truck to long when making low speed precision adjustments during move_base (teb) Jun 17, 2017
@samiamlabs samiamlabs added the bug label Jun 17, 2017
@cosmicog
Copy link

cosmicog commented Jan 9, 2020

Hello, how can I reproduce this issue?

Based on my observations, this controller looks more compatible with ros navigation than ackermann_steering_controller which is for a different but a similar vehicle type.

@samiamlabs
Copy link
Owner Author

Hi!

I'm not exactly sure what you mean by "reproduce".

The controller was originally made for https://minireach.readthedocs.io/en/latest/demo.html
I was not allowed to open source the main part of that project though.

I have a demo project that uses the controller here: https://github.com/samiamlabs/dyno/blob/master/dyno_control/launch/tricycle_controllers.launch

@cosmicog
Copy link

cosmicog commented Jan 9, 2020

Generally reproducing a bug in software development means, supplying the causes for the bug and seeing the result that is reported in the issue. The developer team or the person (me) who is willing to try to fix it needs to see the bug in-the-act so can inspect it.

Instead of writing a new one, I switched to your controller while I was trying to tweak ackermann_steering_controller in order to use it on a tricycle robot. My bot also need to do precise movements at some point, but I'm not there yet, haven't started working on precise movements for approaching to e.g. charging dock. But in navigation, it works well.

@samiamlabs
Copy link
Owner Author

Sorry, that was not well formulated by me.

What I meant was that I did not understand exactly what you wanted help with. It is hard to just provide something like a system configuration and failing test like in a pure software project because this issue has to do with interaction with real servo hardware.

Was not sure if you had TEB fully working and configured with the controller, if you had a real or a simulated robot etc...

The problem was observed using the specific steer servo we used in the "minireach" project.
Small changes in command rotational velocity will cause large changes in the desired steer position at low translational speeds. The fact that it takes time to get the steering to be in the right position for the desired combination is also a huge issue for TEB at low speeds.

The servo controller allowed for quite a lot of jerk in our case. This is good from a control perspective in terms of following the desired path but causes a lot of vibrations and noise on the real hardware.
Using a low jerk limit for steer in the tricycle_controller in order to decrease noise in the servo seemed to cause the robot to stop completely sometimes.

Our use case for this was controlling forklifts, and we determined that TEB and this driver was probably not good enough for the precision required for positioning the forklift for loading and unloading operations in tight corridors in any real application. We were thinking about writing a custom mpc based alternative for TEB for this.

Btw, I'm no longer working on any projects where we use this driver, and pretty much all my new stuff is in ROS2...

@cosmicog
Copy link

cosmicog commented Jan 9, 2020

Thanks for the detailed explanation. I'll use this controller for a while and then, I'll think about the situation. And also will migrate to ROS2. Right now, I just need a demo of a vehicle, I might not even need to make it go further than demoing it, so I'm okay with this issue for now. Got my point, thanks again.

@samiamlabs
Copy link
Owner Author

Great!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants