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

[behavior_tree] support both ports and blackboard #4060

Merged

Conversation

facontidavide
Copy link
Contributor

@facontidavide facontidavide commented Jan 19, 2024

Basic Info

Info Please fill out this column
Ticket(s) this addresses #4059
Primary OS tested on Ubuntu 22.04
Robotic platform tested on None
Does this PR contain AI generated software? No

Description of contribution in a few bullet points

  • cosmetic: use haltTree() more consistently.

  • Blackboard::get is marked [[nodiscard]] in BT.CPP 4.x. To prevent future warnings, I added EXPECT_TRUE in the test where the compiler would complain.

  • Simplified deconflictPortAndParamFrame. T2 will always be a const BT::TreeNode*, so why writing more verbose code?

  • Accessing directly the blackboard instead of using inputPort is an anti-pattern. getInputPortOrBlackboard is a temporary workaround that doesn't change that radically. A good solution must be discussed more broadly

Ports are defined for few BT nodes. If the port is defined, we will use that, otherwise we fallback to reading the blackboard, as we are currently doing.

Description of documentation updates required from your changes

Comments added in the modified/added functions


Future work that may be required in bullet points

None of this change should affect the current behavior of the existing code.
In the future, we shoulkd consider how to avoid accessing the blackboard directly.

For Maintainers:

  • Check that any new parameters added are updated in navigation.ros.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

@facontidavide facontidavide force-pushed the support_port_and_blackboard branch from 33b515f to c6f3a29 Compare January 22, 2024 17:16
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.

Generally seems good to me. These ports need to be added to navigation.ros.org for each of the BT nodes that were added & to the migration guide explaining that these now have the option to take in an input port for goal/goals

@facontidavide
Copy link
Contributor Author

@SteveMacenski I added a small utility to generate automatically the nav2_tree_node.xml file (as I originally intended).

See this commit, that also automates the creation of a list of plugins.

The auto-generated XML is radically different. See attachment.

nav2_tree_nodes.zip

@facontidavide facontidavide force-pushed the support_port_and_blackboard branch from 7258ed4 to 9dd4648 Compare January 25, 2024 12:30
@SteveMacenski
Copy link
Member

SteveMacenski commented Jan 25, 2024

@SteveMacenski I added a small utility to generate automatically the nav2_tree_node.xml file (as I originally intended).

Remove that. PRs should be single feaetures with single implementations. Open another PR if you plan to add in additional features unrelated to this one please. That's how we get megaPRs with never ending review cycles. One thing at a time, if they're not innately coupled. Good process saves us all time and effort 😉

@facontidavide facontidavide force-pushed the support_port_and_blackboard branch from 9dd4648 to c6f3a29 Compare January 26, 2024 08:16
@facontidavide facontidavide changed the title behavior_tree: support both ports and blackboard [behavior_tree] support both ports and blackboard Jan 26, 2024
@facontidavide
Copy link
Contributor Author

Done: #4073

@facontidavide facontidavide force-pushed the support_port_and_blackboard branch from 8bb0c7c to 7e293d6 Compare January 26, 2024 08:53
@SteveMacenski
Copy link
Member

These ports need to be added to navigation.ros.org for each of the BT nodes that were added & to the migration guide explaining that these now have the option to take in an input port for goal/goals

@facontidavide
Copy link
Contributor Author

ok, I will check what to change in navigation.ros.org

@SteveMacenski
Copy link
Member

How's this going? I think its just peanuts and this can be merged :-). You did the hard stuff already

@facontidavide
Copy link
Contributor Author

Added the fixes as discussed. Ready to merge?

Signed-off-by: Davide Faconti <[email protected]>
Signed-off-by: Davide Faconti <[email protected]>
@facontidavide facontidavide force-pushed the support_port_and_blackboard branch from 99cc898 to 2701ca9 Compare February 5, 2024 09:48
@SteveMacenski
Copy link
Member

LGTM on this code, but missing the documentation updates

@facontidavide
Copy link
Contributor Author

facontidavide commented Feb 9, 2024

@SteveMacenski I will submit the change to the documentation today.

Heads up! Some of the changes in this PR might be short-lived, once we migrate to BT.CPP 4.6 (to be released soon),

This new syntax is possible (4 different ways to express the default value of a port):

  static PortsList providedPorts()
  {
    return {BT::InputPort<Point2D>("input", "no default value"),
            BT::InputPort<Point2D>("pointA", Point2D{1, 2}, "default value is [1,2]"),
            BT::InputPort<Point2D>("pointB", "{point}", "default value inside blackboard {point}"),
            BT::InputPort<Point2D>("pointC", "5,6", "default value is [5,6]"),
            BT::InputPort<Point2D>("pointD", "{=}", "default value inside blackboard {pointD}")};
  }

https://github.com/BehaviorTree/BehaviorTree.CPP/blob/master/tests/gtest_ports.cpp#L423-L482
This means that the new code in NAV2 will be:

BT::InputPort<std::vector<geometry_msgs::msg::PoseStamped>>("goals","{=}", "Vector of navigation goals"),
BT::InputPort<geometry_msgs::msg::PoseStamped>("goal", "{=}, "Navigation goal"),

That means: "If I am lazy and don't specify the port in the XML, search in the blackboard using the SAME name of the port".
But this specific PR tries to stay compatible with BT.CPP 3.8, therefore I will postpone this change.

facontidavide added a commit to BehaviorTree/navigation.ros.org that referenced this pull request Feb 9, 2024
@facontidavide
Copy link
Contributor Author

Aaaaand... done! @SteveMacenski
ros-navigation/docs.nav2.org#524

Note that I am not adding anything to the migration guide because it is TOO early, in my opinion

  1. There will be more changes
  2. The changes in this specific PR are backward compatible and no action should be taken.

So, let me postpone that documentation improvement to future PRs!

@SteveMacenski
Copy link
Member

So, let me postpone that documentation improvement to future PRs!

Perfectly fine, this is just for the fact that ports so API changed and its easier to keep those always in sync than remember in the back of my mind the places where I know it needs to change later. The migration guide for the larger v4 migration can certainly wait, but mentioning that the blackboard or port can be used for goal/goals is worth mentioning.

once we migrate to BT.CPP 4.6

Whats your stable v4 version? We're not going to be able to be on your bleeding edge version of v4, its too much risk for too large an audience to go there until its had baking time with early adopters

@facontidavide
Copy link
Contributor Author

facontidavide commented Feb 9, 2024

Whats your stable v4 version? We're not going to be able to be on your bleeding edge version of v4, its too much risk for too large an audience to go there until its had baking time with early adopters

Technically speaking all the versions are stable... I have unit tests 😄

But from a behavioral point of view (pun not intended), after 4.6 I have no plan to add features. Only bugfixes until Jazzy.

And I will release 4.6 the next week. My proposed changes to Nav2 will depend on that version.
Also, I wan to point out that some of the features in 4.6 are being created specifically for Nav2, to help migration 😉

@SteveMacenski
Copy link
Member

SteveMacenski commented Feb 9, 2024

This is just pending on a minor docs update if you can do that, we can have this merged in an hour.

And I will release 4.6 the next week. My proposed changes to Nav2 will depend on that version. Also, I wan to point out that some of the features in 4.6 are being created specifically for Nav2, to help migration 😉

I guess my conservative "I don't want to break 100+ companies" mind says not to use 4.6 and instead use 4.5 until 4.6 has been around for at least a quarter and the top ~5 bugs have been reported/fixed. But, I also don't know how many core changes were made in that subversion update. Was it major or minor updates (and/or major to existing features or adding new features that wouldn't effect existing ones)? I'm more open to potential breaks in new features we don't use yet in the core of Nav2 than I would be for potential breaks in core things in Nav2 folks rely on. ROS 2 has not-so-good reputation due to RWM vendor breakages and issues, I want to make sure Nav2 doesn't fall into the same camp.

4.X still gets folks into groot2 😉

@mikeferguson
Copy link
Contributor

"I don't want to break 100+ companies"

Oh come on! That strategy seems to work fine for MoveIt!

@SteveMacenski
Copy link
Member

SteveMacenski commented Feb 10, 2024

It'd be a shame if something happened to your robot, see..

image

@facontidavide
Copy link
Contributor Author

I think you are making some assumptions about "cutting edge" but.cpp that are not correct, and I need to disagree.

I can only agree with you about the importance of stability, but let me repeat myself: the latest changes are specifically created to help migration to Nav2.

Once I have the change log, we can discuss it further.

SteveMacenski pushed a commit to ros-navigation/docs.nav2.org that referenced this pull request Feb 12, 2024
* Update the default ports

Related to ros-navigation/navigation2#4060

* fix tables
@SteveMacenski SteveMacenski merged commit ab9b101 into ros-navigation:main Feb 12, 2024
9 of 11 checks passed
ajtudela pushed a commit to grupo-avispa/navigation2 that referenced this pull request Mar 7, 2024
* check result of blackboard->get and use halTree

Signed-off-by: Davide Faconti <[email protected]>

* remove unused header

Signed-off-by: Davide Faconti <[email protected]>

* BT: add port inputs when missing and use getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* add description

Signed-off-by: Davide Faconti <[email protected]>

* change return value of getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* updated tree XML

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>
stevedanomodolor pushed a commit to stevedanomodolor/navigation2 that referenced this pull request Mar 25, 2024
* check result of blackboard->get and use halTree

Signed-off-by: Davide Faconti <[email protected]>

* remove unused header

Signed-off-by: Davide Faconti <[email protected]>

* BT: add port inputs when missing and use getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* add description

Signed-off-by: Davide Faconti <[email protected]>

* change return value of getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* updated tree XML

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>
Signed-off-by: stevedan <[email protected]>
stevedanomodolor added a commit to stevedanomodolor/navigation2 that referenced this pull request Mar 25, 2024
Signed-off-by: stevedan <[email protected]>

New MPPI Cost Critic (Contrib: Brice Renaudeau) (ros-navigation#4090)

* Share code

Signed-off-by: Brice <[email protected]>

* Update inflation_cost_critic.hpp

- copyright
- ifndef

Signed-off-by: Brice <[email protected]>

* fix lint cpp

- extra space

Signed-off-by: Brice <[email protected]>

* Fix Smac Planner confined collision checker  (ros-navigation#4055)

* Update collision_checker.cpp

Signed-off-by: Steve Macenski <[email protected]>

* Fix tests

Signed-off-by: Steve Macenski <[email protected]>

* Update test_a_star.cpp

Signed-off-by: Steve Macenski <[email protected]>

---------

Signed-off-by: Brice <[email protected]>

* Prevent analytic expansions from shortcutting Smac Planner feasible paths (ros-navigation#3962)

* a potential solution to smac shortcutting

* costmap reoslution

* some fixes

* completed prototype

* some fixes for collision detection and performance

* completing shortcutting fix

* updating tests

* adding readme

---------

Signed-off-by: Steve Macenski <[email protected]>
Signed-off-by: Brice <[email protected]>

* change pointer free order in amcl to avoid use-after-free bug mentioned in ros-navigation#4068 (ros-navigation#4070)

Signed-off-by: GoesM <[email protected]>
Co-authored-by: GoesM <[email protected]>
Signed-off-by: Brice <[email protected]>

* [Smac Planner] Massive Improvement of Behavior for SE2 Footprint Checking (ie non-circular robots) In Confined Settings (ros-navigation#4067)

* prototype to test SE2 footprint H improvements

* some fixes

* fixed

* invert logic

* Working final prototype to be tested

* complete unit test conversions

* Update inflation_layer.hpp

Signed-off-by: Steve Macenski <[email protected]>

---------

Signed-off-by: Steve Macenski <[email protected]>
Signed-off-by: Brice <[email protected]>

* Adding new Smac paper to readme

Signed-off-by: Steve Macenski <[email protected]>
Signed-off-by: Brice <[email protected]>

* Update README.md

Signed-off-by: Steve Macenski <[email protected]>
Signed-off-by: Brice <[email protected]>

* [behavior_tree] don't repeat yourself in "blackboard->set" (ros-navigation#4074)

* don't repeat yourself: templates in tests

Signed-off-by: Davide Faconti <[email protected]>

* misse change

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>
Signed-off-by: Brice <[email protected]>

* Allow path end pose deviation revive (ros-navigation#4065)

* Support stitching paths in compute path to poses

* Update nav2_planner/src/planner_server.cpp

Co-authored-by: Steve Macenski <[email protected]>

* Rename parameter to allow_path_through_poses_goal_deviation

* Fix description

* restore nav2_params

* missing whitespace

* lint fix

* removed parameter

Signed-off-by: gg <[email protected]>

* Update planner_server.hpp

* Update planner_server.cpp

---------

Signed-off-by: gg <[email protected]>
Co-authored-by: pepisg <[email protected]>
Co-authored-by: Pedro Alejandro González <[email protected]>
Co-authored-by: Steve Macenski <[email protected]>
Signed-off-by: Brice <[email protected]>

* Updated code to use getInflationLayer() method (ros-navigation#4076)

* updated code to use getInflationLayer method

Signed-off-by: Jose Faria <[email protected]>

* Fix linting

Signed-off-by: Jose Faria <[email protected]>

---------

Signed-off-by: Jose Faria <[email protected]>
Signed-off-by: Brice <[email protected]>

* 1594 twist stamped publisher (ros-navigation#4077)

* Add TwistStamped to controller_server via TwistPublisher util

* Add a new util class for publishing either Twist or TwistStamped
* Add a new parameter for selecting to stamp the twist data
* Consume TwistPublisher in nav2_controller

Signed-off-by: Ryan Friedman <[email protected]>

* Fix small issues

* Unused variable
* Incorrect doxygen

Signed-off-by: Ryan Friedman <[email protected]>

* Remove stored node and assert

Signed-off-by: Ryan Friedman <[email protected]>

* Add tests for node

* Facing timeout even though it does the same thing as velocity smoother test

Signed-off-by: Ryan Friedman <[email protected]>

* Add missing spin call to solve timeout

Signed-off-by: Ryan Friedman <[email protected]>

* Fix copyright (me instead of intel)

Signed-off-by: Ryan Friedman <[email protected]>

* Add full test coverage with subscriber

Signed-off-by: Ryan Friedman <[email protected]>

* Remove unused rclcpp fixture

* Can't use it due to needing to join the pub thread after rclcpp shuts down

Signed-off-by: Ryan Friedman <[email protected]>

* Use TwistStamped in nav2_behaviors

Signed-off-by: Ryan Friedman <[email protected]>

* Use TwistStamped in collision monitor node

Signed-off-by: Ryan Friedman <[email protected]>

* Add TwistStamped readme updates to velocity smoother

Signed-off-by: Ryan Friedman <[email protected]>

* Add TwistSubscriber implementation

Signed-off-by: Ryan Friedman <[email protected]>

* Fix syntax errors

Signed-off-by: Ryan Friedman <[email protected]>

* Use TwistSubscriber in test_velocity_smoother

Signed-off-by: Ryan Friedman <[email protected]>

* Use TwistSubscriber in assisted_teleop

Signed-off-by: Ryan Friedman <[email protected]>

* Use TwistSubscriber in collision monitor node

Signed-off-by: Ryan Friedman <[email protected]>

* Use TwistSubscriber in velocity smoother

Signed-off-by: Ryan Friedman <[email protected]>

* Remove unused code

Signed-off-by: Ryan Friedman <[email protected]>

* add timestamp and frame_id to TwistStamped message

* Add missing utility include

Signed-off-by: Ryan Friedman <[email protected]>

* Document TwistPublisher and TwistSubscriber usage

Signed-off-by: Ryan Friedman <[email protected]>

* Use pass-by-reference

* Instead of std::move(std::unique_ptr<TwistStamped>)

Signed-off-by: Ryan Friedman <[email protected]>

* Finish twist subscriber tests

Signed-off-by: Ryan Friedman <[email protected]>

* Add other constructor and docs

Signed-off-by: Ryan Friedman <[email protected]>

* Fix linter issues

Signed-off-by: Ryan Friedman <[email protected]>

* Manually fix paren alignment

Signed-off-by: Ryan Friedman <[email protected]>

* Remove GSoC reference

Signed-off-by: Ryan Friedman <[email protected]>

* Document twist bool param in README

Signed-off-by: Ryan Friedman <[email protected]>

* Handle twistPublisher in collision monitor

* Implement behavior in the stamped callback
* Unstamped callback calls the stamped callback
* Switch to unique pointer for publisher

Signed-off-by: Ryan Friedman <[email protected]>

* Convert to using TwistStamped interally

* Use incoming twistStamped timestamp if available
* Convert all internal representations to use TwistStamped

Signed-off-by: Ryan Friedman <[email protected]>

* Remove nav2_util usage instructions

Signed-off-by: Ryan Friedman <[email protected]>

* Remove unused Twist only subscriber

Signed-off-by: Ryan Friedman <[email protected]>

* More linter fixes

Signed-off-by: Ryan Friedman <[email protected]>

* Prefer working with unique_ptr for cmd_vel

* This makes it easier to switch to std::move instead of dereference on
  publish

Signed-off-by: Ryan Friedman <[email protected]>

* Completing twist stamped migration

* shared to unique ptr

Signed-off-by: Steve Macenski <[email protected]>

* twist add stamps and properly propogated

* nav2_util: fix for compiling with clang

- Resolve error: moving a temporary object prevents copy elision [-Werror,-Wpessimizing-move]

Signed-off-by: Rhys Mainwaring <[email protected]>

---------

Signed-off-by: Ryan Friedman <[email protected]>
Signed-off-by: Steve Macenski <[email protected]>
Signed-off-by: Rhys Mainwaring <[email protected]>
Co-authored-by: pedro-fuoco <[email protected]>
Co-authored-by: Steve Macenski <[email protected]>
Co-authored-by: Rhys Mainwaring <[email protected]>
Signed-off-by: Brice <[email protected]>

* Change costmap_queue to shared library (ros-navigation#4072)

Signed-off-by: cybaol <[email protected]>
Signed-off-by: Brice <[email protected]>

* fix include of hpp

Signed-off-by: Brice Renaudeau <[email protected]>

* inflation cost optmiizations and cleanu

* rename, add defaults, and docs

* smoke test addition

* lintg

* normalize weight

* update readme

* increment cache

* Update cost_critic.hpp

Signed-off-by: Steve Macenski <[email protected]>

* Update cost_critic.cpp

Signed-off-by: Steve Macenski <[email protected]>

---------

Signed-off-by: Brice <[email protected]>
Signed-off-by: Steve Macenski <[email protected]>
Signed-off-by: GoesM <[email protected]>
Signed-off-by: Davide Faconti <[email protected]>
Signed-off-by: gg <[email protected]>
Signed-off-by: Jose Faria <[email protected]>
Signed-off-by: Ryan Friedman <[email protected]>
Signed-off-by: Rhys Mainwaring <[email protected]>
Signed-off-by: cybaol <[email protected]>
Signed-off-by: Brice Renaudeau <[email protected]>
Co-authored-by: BriceRenaudeau <[email protected]>
Co-authored-by: GoesM <[email protected]>
Co-authored-by: GoesM <[email protected]>
Co-authored-by: Davide Faconti <[email protected]>
Co-authored-by: Joshua Wallace <[email protected]>
Co-authored-by: pepisg <[email protected]>
Co-authored-by: Pedro Alejandro González <[email protected]>
Co-authored-by: jncfa <[email protected]>
Co-authored-by: Ryan <[email protected]>
Co-authored-by: pedro-fuoco <[email protected]>
Co-authored-by: Rhys Mainwaring <[email protected]>
Co-authored-by: Kino <[email protected]>

[behavior_tree] support both ports and blackboard (ros-navigation#4060)

* check result of blackboard->get and use halTree

Signed-off-by: Davide Faconti <[email protected]>

* remove unused header

Signed-off-by: Davide Faconti <[email protected]>

* BT: add port inputs when missing and use getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* add description

Signed-off-by: Davide Faconti <[email protected]>

* change return value of getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* updated tree XML

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>

Use ament_export_targets for all targets (ros-navigation#4112)

* Matches new internal ALIAS targets
* Use ALIAS targets for all internal linkage
* Remove unnecessary calls to ament_target_dependencies in test code
* Export includes in proper folders for overlays in colcon

Signed-off-by: Ryan Friedman <[email protected]>

adding new Friends of Nav2 Sponsors!

Update README.md (ros-navigation#4114)

Signed-off-by: Steve Macenski <[email protected]>

CI green P3 (ros-navigation#4117)

Refactors `possible_inscribed_cost` to `possible_circumscribed_cost` in collision checker for smac_planner and mppi_controller (ros-navigation#4113). (ros-navigation#4118)

* Utilizes circumscribed radius to assess potential collision points on the robot.
* Ensures safety when the robot's center is outside the circumscribed radius, eliminating additional checks and optimizing CPU usage.
Signed-off-by: Alan Xue <[email protected]>

Added cast to float to getClosestAngularBin return for behavior consistency (ros-navigation#4123)

* Added cast to float to getClosestAngularBin return for behavior consistency.

Signed-off-by: Hunter Song <[email protected]>

* Revised test name

Signed-off-by: Hunter Song <[email protected]>

---------

Signed-off-by: Hunter Song <[email protected]>

Adding context to MPPI readme

Signed-off-by: Steve Macenski <[email protected]>

[behavior_tree] Add generate_nav2_tree_nodes_xml (ros-navigation#4073)

* Add generate_nav2_tree_nodes_xml

Signed-off-by: Davide Faconti <[email protected]>

* behavior_tree: removed list of plugins from yaml

Signed-off-by: Davide Faconti <[email protected]>

* check result of get_parameter(plugin_lib_names)

Signed-off-by: Davide Faconti <[email protected]>

* fix previous commit (uncrustify)

Signed-off-by: Davide Faconti <[email protected]>

* revert change

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>

Fix compilation with clang (ros-navigation#4131)

Signed-off-by: Ramon Wijnands <[email protected]>

code improvement based on feedback. Name changes and minor code improvement

Signed-off-by: stevedan <[email protected]>

Fix goal handle was not freed correctly (ros-navigation#4137)

* Fix goal handle was not freed correctly

* Update nav2_util/include/nav2_util/simple_action_server.hpp

Signed-off-by: Steve Macenski <[email protected]>

---------

Signed-off-by: Steve Macenski <[email protected]>
Co-authored-by: Ziohang <[email protected]>
Co-authored-by: Steve Macenski <[email protected]>

Adding Nvidia as Gold Sponsor! (ros-navigation#4144)

Prevent a possible segmentation fault (ros-navigation#4141) (ros-navigation#4147)

* Prevent a possible segmentation fault

Signed-off-by: Joni Pöllänen <[email protected]>

* Cleanup

Signed-off-by: Joni Pöllänen <[email protected]>

---------

Signed-off-by: Joni Pöllänen <[email protected]>

Updating stereolabs logo (ros-navigation#4158)

Update README.md

Signed-off-by: Steve Macenski <[email protected]>

behavior_tree: migration to BT.CPP 4.5.x (ros-navigation#4128)

* behavior_tree: migration to BT.CPP 4.5.x

Signed-off-by: Davide Faconti <[email protected]>

* fix formatting

Signed-off-by: Davide Faconti <[email protected]>

* fix lint warning

Signed-off-by: Davide Faconti <[email protected]>

* remove setStatus(BT::NodeStatus::IDLE)

Signed-off-by: Davide Faconti <[email protected]>

* handle SKIPPED state

Signed-off-by: Davide Faconti <[email protected]>

* fix SequenceStar

Signed-off-by: Davide Faconti <[email protected]>

* add tests

Signed-off-by: Davide Faconti <[email protected]>

* fix

Signed-off-by: Davide Faconti <[email protected]>

* fix unit tests

Signed-off-by: Davide Faconti <[email protected]>

* add emitWakeUpSignal()

Signed-off-by: Davide Faconti <[email protected]>

* fit test

Signed-off-by: Davide Faconti <[email protected]>

* fix

Signed-off-by: Davide Faconti <[email protected]>

* remove SequenceStar

Signed-off-by: Davide Faconti <[email protected]>

* remove SequenceStar

Signed-off-by: Davide Faconti <[email protected]>

* keep resetStatus() in action_node

Signed-off-by: Davide Faconti <[email protected]>

* add suggestions from peer reviewer

Signed-off-by: Davide Faconti <[email protected]>

* fix compilation

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>

bug fix (ros-navigation#4160)

Signed-off-by: Tianchu <[email protected]>

Stop planner if the goal is cancelled (ros-navigation#4148)

* Add support for stopping planners when the action is cancelled

Signed-off-by: Kemal Bektas <[email protected]>

* Support cancel in Smac planner

Signed-off-by: Kemal Bektas <[email protected]>

* Support cancel in Theta* planner

Signed-off-by: Kemal Bektas <[email protected]>

* Support cancel in Navfn planner

Signed-off-by: Kemal Bektas <[email protected]>

* Update nav2_system_tests to use cancel checker

Signed-off-by: Kemal Bektas <[email protected]>

* Add terminal_checking_interval parameter

Signed-off-by: Kemal Bektas <[email protected]>

* Handle timeout and cancel check on the same branch and default to 5000 iterations

Signed-off-by: Kemal Bektas <[email protected]>

* Add system tests for cancel

Signed-off-by: Kemal Bektas <[email protected]>

---------

Signed-off-by: Kemal Bektas <[email protected]>
Co-authored-by: Kemal Bektas <[email protected]>

Improvement on the wat the distance heuristic is calculated

Signed-off-by: stevedan <[email protected]>

Fix BT.CPP import (ros-navigation#4165)

Signed-off-by: Tony Najjar <[email protected]>

Update default recommendation from Obstacles to Cost critic in MPPI (ros-navigation#4170)

Signed-off-by: Steve Macenski <[email protected]>

nav2_controller: add loop rate log (ros-navigation#4171)

* update smac_planner README

Signed-off-by: ARK3r <[email protected]>

* added current controller loop rate logging

Signed-off-by: ARK3r <[email protected]>

* linting

Signed-off-by: ARK3r <[email protected]>

* uncrustify lint

Signed-off-by: ARK3r <[email protected]>

* Update nav2_controller/src/controller_server.cpp

Signed-off-by: Steve Macenski <[email protected]>

* Update nav2_controller/src/controller_server.cpp

Signed-off-by: Steve Macenski <[email protected]>

* Update nav2_controller/src/controller_server.cpp

Signed-off-by: Steve Macenski <[email protected]>

---------

Signed-off-by: ARK3r <[email protected]>
Signed-off-by: Steve Macenski <[email protected]>
Co-authored-by: Steve Macenski <[email protected]>

improvement based on feedback

Signed-off-by: stevedan <[email protected]>
enricosutera pushed a commit to enricosutera/navigation2 that referenced this pull request May 19, 2024
* check result of blackboard->get and use halTree

Signed-off-by: Davide Faconti <[email protected]>

* remove unused header

Signed-off-by: Davide Faconti <[email protected]>

* BT: add port inputs when missing and use getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* add description

Signed-off-by: Davide Faconti <[email protected]>

* change return value of getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* updated tree XML

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>
Signed-off-by: enricosutera <[email protected]>
Marc-Morcos pushed a commit to Marc-Morcos/navigation2 that referenced this pull request Jul 4, 2024
* check result of blackboard->get and use halTree

Signed-off-by: Davide Faconti <[email protected]>

* remove unused header

Signed-off-by: Davide Faconti <[email protected]>

* BT: add port inputs when missing and use getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* add description

Signed-off-by: Davide Faconti <[email protected]>

* change return value of getInputPortOrBlackboard

Signed-off-by: Davide Faconti <[email protected]>

* updated tree XML

Signed-off-by: Davide Faconti <[email protected]>

---------

Signed-off-by: Davide Faconti <[email protected]>
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