-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
[Reg Pure Pursuit] Support reverse direction #2327
Comments
Our (similar) ROS1 planner can travel any path in both directions by indeed moving the carrot to the other side of the robot. However this doesn't mean it can do reeds-shepp since that would change the target velocity half-way a path. We currently solve this by simply dividing into sections and sending them sequentially to the controller. Is this what you're suggesting here? |
Precisely, I’d welcome the contribution if possible! Glad great minds think alike with what you built internally 😉 |
Where in the typical global planner -> local planner flow would this splitting best occur? It feels like an intermediate step, like global planner -> plan parser/splitter -> local planner. (Our reeds-shepp capable robot uses a global planner which does the splitting into parts already, so we didn't solve this architectural piece yet). |
Because the RPP controller allows the reversing, I think this logic belongs there. Other algorithms / controllers might not need / want that separation to handle it. I say put it in RPP directly and if we find a reason to use it in multiple places, we can abstract it out into a library in
The only planners that generate backward motion is the Hybrid-A* (and soon to be State Lattice planner). This includes orientation headings, not just the points. You can easily break out the forward / reverse directions if you have the headings! P.S. If you're open to sharing more about that global planner, I'd be curious on the algorithm and how happy you are with it (and if you tried the smac planner, especially with these changes #2352 which speeds up another 30% and dramatically increases path quality, seriously, its night and day due to some new work I added; way smoother, way in the middle of spaces, way faster in footprint checking if not using just the robot radius estimation) |
This was exactly the code I was trying to prevent. But then again, doesn't seem too bad. Orientation is correct in our paths so no problems there. Our global planner does full field coverage (I believe you had an issue open for this, can't find). So that cannot be compared to the smac planner. We do want to go ROS2/navigation2 with this FCPP this year, so when we get to this we'll certainly have some interface discussions and code to share 👍. |
Is there something wrong with that? It would seem to be to be a very fast and reliable method (using the dot project to find if the signs change) -- we only need to march through the path in the local costmap window (since any further out isn't used by the controllers) so at most we're talking maybe 20-30 points.
As part of the RPP supporting backwards, that seems very reasonable to have a max speed in reverse parameter (or a % of the forward speed)
Awesome! |
No, not if the paths are proper. But we've had issues in the past where the global plan contained almost duplicate points from segments being stitched together. Now we should fix the global planner to not do this, but it is something to be aware off. |
My further thoughts on navigating the robot in the reverse direction. In the yesterdays work group meeting I came up with the problem of the robot hitting the obstacle when moving in the reverse direction. This still seem to be a valid point. Assume your robot does not have eyes behind and suddenly a dynamic obstacle that pops out it in the environment (maybe in / very close to your global path), this might be the case where the scanners might not pick up the obstacle and if the robot is going in the reverse direction, there maybe some incident which we would not like to have. I would say that it can be added as an parameter and a word of caution needs to be given to the user. Thoughts? |
It shouldn't be necessary if you don't have a planner that plans backwards. If a plan has backward motion supported, then this controller is not "smart" to know that, it just needs to follow the path given. If you would not like reversing behavior, then the planner giving paths to this controller should not contain them |
Then I could supposedly assume that, it is the choice that the user has to make on whether they want to use a planner that generates a path supporting a backward motion (Planner using Reeds-Shepp for instance), depending upon their robot. In that case I totally agree on your point that the controller need not be "smart". |
I had some time to look into this problem further. It would be great if we have some thoughts from the community on the particular solution I'm proposing:
Combing them and having them as a single robust solution for the path following, seems to be the challenging part and could use BT to handle the cusps (?). Maybe, there could be a much more effective way to handle this? P.S: Here we are considering Reeps-Shepps model that is part of SMAC planner for generating the global path! |
So the question is: who's in charge of chopping up the path in segments?
|
This will be the best solution I guess. Maybe if the global planner is able to provide with some more information such as a particular waypoint is a cusp point or not (?)
Eventually needing the robot to reach to a stop at the cusp, before it gets an another path and continuing the motion. |
So what I think:
So the 2 most open questions are:
Is that not what its doing already? Draw a cusp on a piece of paper and then draw tangent lines at some points along it. At some point, the arrows turn from going up into the cusp to down after the cusp. If you projected those vectors on to each other, you should see in the "normal" path that there is indeed some projection from one point to the next. But on a cusp, that wouldn't be true. My recollection of vector algebra is that a projection is the same thing as a dot product. So there's some relationship about the changing of signs to signal that it is a cusp. And since this is vector orientations, its invariant on homogeneous transformations so there's no reason to think that the translation from map->odom frame would interfere with this detection method. I think that should work? The only concern I'd have is if you tried to feed a path into it that had rigid 90 degree turns. The projection would be 0 just as if it were a cusp (which I suppose in a sense, it is). But honestly, that sounds like kind of a cool behavior to have your robot stop, rotate, and continue at 90 degree turns. Its much less "cool" though if its not just an occasionally designed 90 degree turn but the result of a naive grid A* so there's lots of them frequently. But in that case, the orientation vectors probably aren't populated because there's no meaningful se2 collision checking in a naive-grid-search. So if the vectors aren't populated, the projection will always be 1 and therefore we shouldn't expect it to trigger the behavior. |
Quick update: Indeed the dot product did the trick in determining the cusp
The only trouble at the moment, I'm having now is to hold the last point as the carrot location, because of the updates from the global planner that consistently changing.
|
You don't need to hold the last point, you can re-detect it each iteration as the updates come in. For all we know, a replan actually made that maneuver move, so you shouldn't be storing that between replans. |
Its hard to tell from that short gif, can you extend it before and after so we can see the path / transition more clearly? Potentially set your robot to use differential mechanics? |
Ooooooooooohhhhhhhhhhhh that looks niiiiiiiiiiiiiice. |
Thanks! I need to further test it for some more cases and will give a PR soon! |
Merging imminently |
The SMAC planner supports both the Reeds-Shepp & Dubin motion models for ackermann / legged robots.
The Dubin model can only move forward which RPP encapsulates perfectly. However Reeds-Shepp can allow the robot to reverse at a cusp (and point the opposite direction). So at these points we should move the carrot from the front of the robot to the reverse of the robot in those situations and invert the velocity so we can support reversing as well.
This figure shows a simple geometric view of the reverse cusping: https://github.com/leggedrobotics/se2_navigation/blob/master/pure_pursuit_core/doc/path_conventions.pdf
As well on the path smoother, do in sections
The text was updated successfully, but these errors were encountered: