MoveIt Pro Behavior
Core Behaviors for MoveIt Pro
moveit_studio::behaviors::ForEach Class Reference

A class for creating a behavior tree decorator node to iterate through a vector of items. More...

#include <for_each.hpp>

Inheritance diagram for moveit_studio::behaviors::ForEach:
Collaboration diagram for moveit_studio::behaviors::ForEach:

Public Member Functions

 ForEach (const std::string &name, const BT::NodeConfiguration &config)
 
 ~ForEach () override=default
 

Static Public Member Functions

static BT::PortsList providedPorts ()
 Required implementation of the static providedPorts function. More...
 
static BT::KeyValueVector metadata ()
 

Detailed Description

A class for creating a behavior tree decorator node to iterate through a vector of items.

  • Given an instance of std::vector<BT::Any> which is provided on an input data port and contains N items, set the value of an output data port to the item in the vector which is at index 0 and then tick the ForEach decorator's child node until the child returns SUCCESS or FAILURE.
  • If the child returns SUCCESS, set the value of the output data port to the item at index 1 and repeat ticking the child node.
  • If the child returns FAILURE, stop iterating through the vector or ticking the child and return FAILURE.
  • Repeat until we have iterated through all elements of the input vector, and finally return SUCCESS.

For each element set in the output, the index of the element in the input vector is also set in the index output data port. Therefore this Behavior outputs pairs [index, out] for each element in the input vector, containing the element index (starting at 0) and its value.

NOTE: The output values are only expected to be used by the child node or subtree of the ForEach node which sets it. While it is possible to access these ports from elsewhere in the behavior tree, this may result in unexpected behavior so it is not recommended.

Data Port Name Port Type Object Type
vector_in input std::vector<BT::Any>
index output int
out output BT::Any

Constructor & Destructor Documentation

◆ ForEach()

moveit_studio::behaviors::ForEach::ForEach ( const std::string &  name,
const BT::NodeConfiguration &  config 
)

◆ ~ForEach()

moveit_studio::behaviors::ForEach::~ForEach ( )
overridedefault

Member Function Documentation

◆ metadata()

BT::KeyValueVector moveit_studio::behaviors::ForEach::metadata ( )
static

◆ providedPorts()

BT::PortsList moveit_studio::behaviors::ForEach::providedPorts ( )
static

Required implementation of the static providedPorts function.

Returns
The list of input and output ports used by this behavior.

The documentation for this class was generated from the following files: