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.1.0
License BSD-3-Clause
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/pastoriomarco/manymove.git
VCS Type git
VCS Version humble
Last Updated 2025-04-04
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

Package to generate behaviortrees for manymove_planner using BehaviorTree.CPP

Additional Links

No additional links.

Maintainers

  • Marco Pastorio

Authors

  • Marco Pastorio

ManyMove C++ Trees

This manymove_cpp_trees package is part of the manymove project for ROS 2 Humble. It offers a BehaviorTree.CPP-based framework for composing motion sequences, object manipulation, and I/O signal handling, using the action servers and messages defined throughout manymove packages.

Use at your own risk; this repository is experimental and does not provide safety features.


Overview

Key Functionalities

  • BehaviorTree.CPP Integration
    Provides a set of custom BT nodes (planner, object manipulation, signals, etc.) that can be used to build modular robotic behaviors.

  • MoveIt 2 & Action Server Bridges
    Easily plan and execute motions, manage collision objects, attach/detach objects, and send/receive I/O signals by leveraging the action servers in manymove_planner and manymove_object_manager.

  • Reconfigurable at Runtime
    Much of the tree logic (target poses, velocities, attach operations, etc.) is dynamically drawn from the Blackboard, allowing for flexible updates without recompiling.

  • HMI Service Node
    A dedicated node that exposes services for controlling behavior execution (start, stop, reset) and publishes Blackboard status.


Architecture

  1. Behavior Tree Nodes
    • action_nodes_planner.hpp: Nodes for planning/executing manipulator motions (PlanningAction, ExecuteTrajectory, etc.).
    • action_nodes_objects.hpp: Nodes for adding/removing collision objects and checking or attaching them.
    • action_nodes_signals.hpp: Nodes for sending/reading digital I/O signals and checking robot state.
    • action_nodes_logic.hpp: Custom decorator/condition nodes for controlling execution flow (e.g., pausing, aborting, blackboard key checks).
  2. bt_client_node
    • A reference implementation (in bt_client.cpp) that programmatically constructs a complex Behavior Tree.
    • Demonstrates combining the above custom BT nodes (e.g., for scanning the environment, picking/dropping objects, checking signals, etc.).
    • Uses a MultiThreadedExecutor to spin the tree logic in parallel with the HMI service node.
  3. HMI Service Node
    • HMIServiceNode provides services to start/stop/reset execution.
    • Publishes execution status (e.g., stop_execution, reset, etc.) at a fixed interval.

Installation & Dependencies

Please refer to the main ManyMove README for overall setup instructions, build steps, and prerequisites.

Usage

Running the bt_client_node

The bt_client_node is an example node that programmatically creates a Behavior Tree:

ros2 run manymove_cpp_trees bt_client_node

Parameters (can be set via the command line or a launch file):

  • robot_model (default: “lite6”)
  • robot_prefix (default: “”)
  • tcp_frame (default: “”)
  • is_robot_real (default: false), determines if real I/O signals are used or mocked.

Defining Your Own Trees

  • Include the desired node headers (action_nodes_*) in your custom .cpp.
  • Register them with BehaviorTree.CPP (see tree_helper.hpp and action_nodes_planner.cpp for examples).
  • Construct an XML tree (or build it programmatically) referencing these node types.
  • Create a BT::Tree from the factory and tick it in a loop or an executor.

Example Features

  • Motion Planning & Execution
    PlanningAction and ExecuteTrajectory nodes for MoveIt 2-based motion.

  • Collision Object Management
    AddCollisionObjectAction, RemoveCollisionObjectAction, AttachDetachObjectAction, etc.

  • I/O Signals & Robot State
    SetOutputAction, GetInputAction, CheckRobotStateAction, and so on.


Notes & Disclaimer

  • Experimental: This package is under development; no warranty of stability.
  • No Safety Features: Robot safety must be handled externally.
  • Check Main README: For detailed disclaimers, licensing, and more information.

Contributing

Feedback and pull requests are welcome. If you discover any issues or have suggestions, please open an issue or PR in the main manymove repository.

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.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged manymove_cpp_trees 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.