No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

Package Summary

Tags No category tags.
Version 0.0.0
License TODO: License declaration
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/robojackets/urc-software.git
VCS Type git
VCS Version master
Last Updated 2025-04-01
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

TODO: Package description

Additional Links

No additional links.

Maintainers

  • keseterg

Authors

No additional authors.

URC Behavior Tree

This package provides the central orchestrator for running the behavior tree.

Launching

You should run the urc_bt_orchestrator node, which is registered as a plugin in this package. For an example, check out bt.launch.py under the urc_bringup package.

There are several parameters for the urc_bt_orchestrator node:

  • node_lib_dirs: array of strings, specifying the path to dynamic library files needed for bt nodes. Will be loaded on runtime.
  • tree_file_dir: string, to the path of the .xml file for the behavior tree. If not specified, the tree will not be loaded and started on launching.
  • start_bridge: bool, whether to initialize some of the convenient variables in the root Blackboard of the current behavior tree.

Starting, Stopping, Hot Swapping

To start or stop bt_orchestrator, call ~/start_bt or ~/stop_bt. Note that the orchestrator is still alive regardless of whether it is started or not; starting and stopping states determines whether the tree is going to tick the nodes.

bt_orchestrator enables hot-swapping by using service at runtime. After editing the tree, you do not need to restart everything. Instead, you have two options:

  • Calling ~/update_tree with service type UpdateBehaviorTree under urc_msgs. You can choose to update the tree using the path to an existing .xml BT tree file, or you can directly pass the content of the tree in the string.
  • Calling ~/reload with service type Trigger under std_srvs. In this case, you have to preload the tree with a tree_dir. The orchestrator will by-default load that file.

Editing the Tree

You can specify path to your tree during launch. For an example, check out strategies folder under urc_bringup package, which contains .btproj containing definitions for all the nodes that is going to be used inside URC.

Note that to provide a bridge between ros and bt, upon launch, urc_bt_orchestrator writes several values to the root Blackboard of the current behavior tree by default. They are:

  • ros_nh: shared ptr, node handle to a ros node.
  • ros_log: shared ptr, a ros logger.

This functionality can be disabled by changing the settings.

Creating Custom Nodes

Program and Compile the New Node

There are generally two types of nodes: raw BTCPP nodes and BTCPP.ROS2 nodes.

urc_bt use dynamic libraries to enable hot load / unload of nodes at runtime, and thus this is the recommended way to extend the node library under urc_bt_nodes.

Note that two types of nodes have to be registered differently: raw BTCPP nodes can be registered in multiples in one plugin, while for BTCPP.ROS2 nodes, you have to create one plugin for one node, and manually register them inside the cmake file. Generally, you can follow the template created by existing nodes.

Register the Node in Groot2

After creating your nodes, you have to manually register them inside Groot2. Note that having your nodes’ dynamic library loaded does not mean Groot2 will automatically get the definition of the nodes: Groot2 is only an editor and does not know the actual node implementation.

You can register a new node by clicking the “plus” icon inside Groot2 and get all the input and output ports registered correctly.

For more info on the nodes available, check Nodes Library from the official BT.CPP website.

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged urc_bt at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.