-
Notifications
You must be signed in to change notification settings - Fork 13.6k
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
Removed Functionality: Remove collision avoidance interface on PX4 side #24172
base: main
Are you sure you want to change the base?
Conversation
Signed-off-by: Silvan <[email protected]>
Remove yaw_acceptance and altitude_acceptance_radius fields as they were only filled by now removed avoidance controller. Signed-off-by: Silvan <[email protected]>
Signed-off-by: Silvan <[email protected]>
🔎 FLASH Analysispx4_fmu-v5x [Total VM Diff: -5520 byte (-0.27 %)]
px4_fmu-v6x [Total VM Diff: -5576 byte (-0.29 %)]
Updated: 2025-01-06T08:07:26 |
#include <uORB/topics/vehicle_trajectory_bezier.h> | ||
#include <uORB/topics/vehicle_trajectory_waypoint.h> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe we could even remove these two uORB messages and sub-messages. They were only used for avoidance - @bastianhjaeger would you agree?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking deeper still, we could probably then also remove the entire Bezier library.
https://github.com/PX4/PX4-Autopilot/tree/main/src/lib/bezier
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bezier
can for sure go. If vehicle_trajectory_waypoint
is not used nowhere, than sure too. Good catch.
Plus the corresponding mavlink pieces once these are gone. #24172 (comment) |
Solved Problem
We have archived the ROS side of the avoidance some time ago, and the interface on the PX4 side is not actively maintained (most of the initial contributors have left or have a changed focus). With the introduction of external flight modes we have arguably a better way of implementing it, and thus I propose to remove the interface on the PX4 side completely. This saves us quite some flash (5.5k), removes code complexity and prevents new developers to be sent on the wrong (old) track.
Solution
Remove CollisionAvoidance library (which was used in FlightTask), remove health check for avoidance, remove
COM_OBS_AVOID
, remove from messagePositionControllerStatus.msg
the fieldsyaw_acceptance
andaltitude_acceptance
that were exclusively used for avoidance and with that also remove some acceptance logic from Navigator.Changelog Entry
For release notes:
Alternatives
We could for a start only not build it but leave in code base (as it's already done for constrained builds). If somebody would complain we could revert more easily. Wouldn't resolve the lingering of a not-maintained PX4 code then though.