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

Better management of RPP path pruning when cusp points are detected #4763

Open
wants to merge 1 commit into
base: humble
Choose a base branch
from

Conversation

andreacelani
Copy link


Basic Info

Info Please fill out this column
Ticket(s) this addresses (#4757)
Primary OS tested on (Ubuntu 22.04.5)
Robotic platform tested on (custom Gazebo simulation with Ackermann model)
Does this PR contain AI generated software? (No)

Description of contribution in a few bullet points

the contribution make RPP controller follows better the path given by planner. There is no skip of path points even with tight maneuvers.
This apply to all models (diff drive, ackermann and omni)

fixed.RPP.webm

Description of documentation updates required from your changes

Added the following parameters. They are the same found in MPPI controller

  • inversion_xy_tolerance
  • inversion_yaw_tolerance

the parameters are useful to terminate an inversion and start the following the next portion of the path


Future work that may be required in bullet points

original RPP coding style has been follow (one single file cpp file). MPPI has more structured organization with a dedicated path_handler.cpp file
-->

For Maintainers:

  • Check that any new parameters added are updated in docs.nav2.org
  • Check that any significant change is added to the migration guide
  • Check that any new features OR changes to existing behaviors are reflected in the tuning guide
  • Check that any new functions have Doxygen added
  • Check that any new features have test coverage
  • Check that any new plugins is added to the plugins page
  • If BT Node, Additionally: add to BT's XML index of nodes for groot, BT package's readme table, and BT library lists

Copy link
Contributor

mergify bot commented Nov 24, 2024

This pull request is in conflict. Could you fix it @andreacelani?

@andreacelani andreacelani changed the base branch from main to humble November 24, 2024 11:38
Copy link
Contributor

mergify bot commented Nov 24, 2024

@andreacelani, all pull requests must be targeted towards the main development branch.
Once merged into main, it is possible to backport to @humble, but it must be in main
to have these changes reflected into new distributions.

Copy link
Member

@SteveMacenski SteveMacenski left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Heed the CI bots - we need this in main before we can have it in humble so that all new distributions and current releases can have this update (i.e. jazzy which I assume you'll also want eventually 😉 ). Also on linting and DCO sign offs for quality control.

You can leave this PR open after fixing the DCO and linting issues, but also need a main version of it. Generally I'd recommend closing this PR and opening a main for us to discuss over and fix issues on - then once we merge open a humble version. That way any fixes for main get waterfalled into humble without trying to maintain 2 PRs simultaneously and perhaps miss some details by accident.

I did a good sweep at it and generally look good to me other than missing test coverage / linting issues. I'll do a detailed sweep after the main version of this PR is opened, but generally seems good. I assume you tested this fix?

{
auto && theta = fmod(angles + M_PI, 2.0 * M_PI);
if (theta < 0)
theta += 360;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isn't this in radians?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes radians, I translated a function from degree to radians but it looks like I forgot to update theta += 360 to theta += 2.0 * M_PI

* @return Shortest distance between angles
*/
template<typename F, typename T>
auto shortest_angular_distance(
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I believe both of these functions can be used from angles rather than reimplemented https://github.com/ros/angles

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I suppose so. I follow MPPI controller utils.hpp implementation in humble. I see Nav2 Rolling switched to angles dependency

@@ -166,38 +160,6 @@ TEST(RegulatedPurePursuitTest, createCarrotMsg)
EXPECT_EQ(rtn->point.z, 0.01);
}

TEST(RegulatedPurePursuitTest, findVelocitySignChange)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

make sure to add tests for your new methods (isWithinInversionTolerances prunePlan removePosesAfterFirstInversion findFirstPathInversion)

@SteveMacenski
Copy link
Member

@andreacelani any update?

@andreacelani
Copy link
Author

@SteveMacenski sorry I had not time, heavy period at work! 😅 I'm moving to main and add tests to new methods

@SteveMacenski
Copy link
Member

Thank you @andreacelani ❤️

Just checking in :-)

@andreacelani
Copy link
Author

@SteveMacenski I trying to switch to Rolling but my ROS2 is humble. Any advice/workaround to build the main (rolling) while in humble? Or should I install everything in a VM? Thank you

@SteveMacenski
Copy link
Member

Use a docker container, typically. OSRF has Jazzy / Rolling docker images that you can mount your workspace into. I have some docs on it if you need help setting up https://docs.nav2.org/tutorials/docs/docker_dev.html

@SteveMacenski
Copy link
Member

@andreacelani I'm hoping this is something you can get done this month, are you able to?

@andreacelani
Copy link
Author

I hope so, I'm really slowly but I'm working on it. Now I'm fighting with PoseStampedArray message that you can find in Nav2 rolling but not in Ros2 rolling docker image. I'll get out of it 😅

@SteveMacenski
Copy link
Member

What I did was clone geometry2 into my workspace, then colcon build --packages-up-to geometry_msgs --parallel-workers 1 and then source the workspace, finally colcon build the full space and you should be good to go (its annoying, but getting that built and sourced first makes later things use the workspace version of the package on the next re-build)

@mikeferguson
Copy link
Contributor

mikeferguson commented Jan 16, 2025

I wasn't using the docker images - but I found I had to delete the build/install folders after adding common_interfaces to the workspace - my hypothesis is that there was some left over Cmake generated files that were still pointing to /opt/ros for geometry_msgs stuff (kept getting errors with no header found for PoseStampedArray). Once I cleaned out the build/install folders, build ran fine (even doing it all at once, with unlimited workers)

@SteveMacenski
Copy link
Member

Indeed, I would also expect that, sorry for not mentioning that 😦

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

Successfully merging this pull request may close these issues.

3 participants