-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
SmacPlanner hybrid can generate path that pass inside lethal area #4735
Comments
I think to debug it better, we might also need your costmap params. Any by the way, are you showing the global costmap in the image above? |
Thanks for your response.
Unfortunately, we have two custom layers (obstacle_filter and fov_filter), but the section of the costmap traversed by the path is in our static costmap, which is added by the static_layer. |
I'm not quite seeing the issue that you're reporting in these details. It looks like the footprint that you're using is a footprint polygon, but your global costmap parameters show that you're using a radius footprint, so that doesn't quite line up. If using the polygon footprint, the image you showed seems valid, there's no collision with the environment in that example. There's a nice debugging topic in the Smac Planner now that you can use to visualize the footprints of the output plan overlayed in rviz, which you can turn on with the Note that the blue is not lethal space, its inflated space. If the centerpoint of the robot intersected with that blue space, then it would be in collision. It is perfectly fine for the edges of your robot platform / footprint to enter that area though. |
Hi Steve, Thanks for your response. My main question is about understanding why the generated path (yellow line) crosses into the inflated area (no-go zone). As I understand it, the Smac planner should never return a path that goes through cells marked as INSCRIBED_INFLATED_OBSTACLE or LETHAL_OBSTACLE. However, in the image in the post, we see the path passing through the blue area, which is designated as INSCRIBED_INFLATED_OBSTACLE. Thanks in advance! |
I think you mean the green line (?) :-)
Ah, understood. You've misunderstood the intent of the inflation. If you had a circular footprint specified using the When using a non-circular footprint using the For footprint collision checking, the center cost doesn't actually tell us a whole lot about its general cost status -- though that center point should also not be in collision with the inscribed, inflated cost due to ... being still inscribed / inflated. We actually use that feature as a an optimization: we calculate from the robot's footprint the furthest distance from the center of the robot specified in your I hope that explains things clearly. Now, in looking over your image in explaining this, I noticed that your inflation is poorly setup. You should actually be seeing this error warning in your logs about it https://github.com/ros-navigation/navigation2/blob/main/nav2_costmap_2d/plugins/inflation_layer.cpp#L177-L185. With this not properly set to be at least the robot's largest distance, then we can't query some non-zero center point cost when in closer proximity to obstacles. If you log / print https://github.com/ros-navigation/navigation2/blob/main/nav2_smac_planner/src/smac_planner_hybrid.cpp#L225 you should see that this cost is then zero/ |
@FrGrQuim any feedback on that explaination and if this is still a concern? |
@FrGrQuim final check in here! |
Hi @SteveMacenski , Sorry for the lack of response. We've been struggling to find a way to reproduce this issue, and some more critical problems on our side have taken priority. However, we recently encountered the issue again. I will try to provide you with a rosbag today that contains as much relevant information as possible to help you understand the bug. Regarding your response, the footprint you see in the screenshot is the one from the collision monitor, but for the planner and costmap, we use the robot radius. So unless the two are linked, I’m pretty sure the path planner is using the circular footprint. The issue we’re facing at the application level is that we have an IsPathValid node, which triggers path recomputation when the path is not valid. The problem is that the generated path (green line, sorry for the confusion) touches the INSCRIBED_INFLATED_OBSTACLE, causing the system to continuously loop between the generated path and IsPathValid returning FAILURE (path is not valid). |
Here is a rosbag where you can see the issue : not_valid_path_generated.zip |
That would probably be your issue then. Is it in collision with the footprint the Smac Planner knows about (i.e. global costmap)? If not, then its working as expected. If you are in confined spaces and running into issues, then I think you need to use the actual footprint, not an approximate (or use a conservative radius).
Also, Iron's been EOL for some time. Can you reproduce this on another distribution? It may be that we discovered and resolved this problem some time ago, but since Iron isn't an active distribution, fixes have halted on it. |
Just to clarify, when I mention that the planner uses the circular radius, I am referring to the robot_radius.
There are no physical collisions, don't worry. The issue is purely virtual. It arises because the SmacPlanner generates a path that is considered invalid by the IsPathValid service, which is part of the planner_server. Since both IsPathValid and the SmacPlanner are managed by the same planner_server (along with the global costmap), I assumed they share the same footprint/robot_radius and then the same rules for detecting virtual collisions. Given this assumption, I don't understand how it is possible for a freshly generated path to be considered invalid by the planner_server that has generated it. Regarding the distribution we use, we plan to upgrade to Jazzy, but there are higher-priority tasks that need to be completed first. |
See https://github.com/ros-navigation/navigation2/tree/main/nav2_smac_planner#potential-fields. I think you do not have a good inflation setup and you would see warnings / errors in your terminal if you had a non-EOL distribution. The inflation radius must be large enough for run-time optimizations w.r.t. cost checks against the center point of the robot. The inflation radius must be strictly greater than or equal to the robot's largest cross sectional radius (ie. so if a 10x10 cm box, it would need to be Its likely in Iron that not only is this error not present, but the underlying checks to make sure we have a validly configured costmap inflation radius aren't performed, so its not doing or checking the right thing. Increase your inflation radius and I think you should be good to go. P.S. Issues like this are the risk one takes by using a non-supported ROS 2 distribution - I would highly encourage upgrading. Iron stopped recieving updates in Nav2 nearly 6 months ago |
Bug report
Required Info:
Steps to reproduce issue
Ask to SmacPlanner to compute a path to an accessible goal.
Expected behavior
SmacPlanner fails to compute a path or give a path that don't pass by the lethal inflation.
Actual behavior
Additional information
Planner parameters:
The text was updated successfully, but these errors were encountered: