MoveIt Pro Behavior
Core Behaviors for MoveIt Pro
|
A base class for behaviors which need to send a goal to a ROS action client and wait for a result. If the behavior is halted before the action result is received, the action goal will be canceled. More...
#include <action_client_behavior_base.hpp>
Classes | |
class | ClientInterfaceBase |
Provides an interface to an action client that can handle a single goal at a time. More... | |
class | RclcppClientInterface |
Implements ClientInterfaceBase for the rclcpp action client. More... | |
Public Types | |
using | ClientGoalHandle = rclcpp_action::ClientGoalHandle< ActionT > |
Public Member Functions | |
ActionClientBehaviorBase (const std::string &name, const BT::NodeConfiguration &config, const std::shared_ptr< BehaviorContext > &shared_resources) | |
Constructs ActionClientBehaviorBase using the RclcppClientInterface. | |
ActionClientBehaviorBase (const std::string &name, const BT::NodeConfiguration &config, const std::shared_ptr< BehaviorContext > &shared_resources, std::unique_ptr< ClientInterfaceBase > client_interface) | |
Constructs ActionClientBehaviorBase using a user-provided implementation of ClientInterfaceBase. | |
virtual | ~ActionClientBehaviorBase ()=default |
Public Member Functions inherited from moveit_studio::behaviors::AsyncBehaviorBase | |
AsyncBehaviorBase (const std::string &name, const BT::NodeConfiguration &config, const std::shared_ptr< BehaviorContext > &shared_resources) | |
virtual | ~AsyncBehaviorBase ()=default |
BT::NodeStatus | onStart () override |
Required implementation of BT::StatefulActionNode::onStart(). | |
BT::NodeStatus | onRunning () override |
Required implementation of BT::StatefulActionNode::onRunning(). | |
void | onHalted () override |
Required implementation of BT::StatefulActionNode::onHalted(). | |
void | resetStatus () |
Resets the internal status of this node. | |
Public Member Functions inherited from moveit_studio::behaviors::SharedResourcesNode< BT::StatefulActionNode > | |
SharedResourcesNode (const std::string &name, const BT::NodeConfiguration &config, const std::shared_ptr< BehaviorContext > &shared_resources) | |
Constructor for SharedResourcesNode. Called by BT::BehaviorTreeFactory when creating a new behavior tree containing this node. | |
Protected Member Functions | |
virtual tl::expected< std::string, std::string > | getActionName ()=0 |
User-provided function to get the name of the action when initializing the action client. | |
virtual tl::expected< std::chrono::duration< double >, std::string > | getResultTimeout () |
Optional user-provided function to set the timeout used when waiting for the action result. | |
virtual tl::expected< typename ActionT::Goal, std::string > | createGoal ()=0 |
User-provided function to create the action goal before sending the action goal request. | |
virtual tl::expected< bool, std::string > | processResult (const std::shared_ptr< typename ActionT::Result >) |
Optional user-provided function to process the action result after the action has finished. | |
virtual void | processFeedback (const std::shared_ptr< const typename ActionT::Feedback >) |
Optional user-provided function to process feedback sent by the action server. | |
virtual std::string | getAbortedMessage (const std::shared_ptr< const typename ActionT::Result >) const |
Optional user-provided function to retrieve and surface an error message from an aborted action server result. | |
Protected Member Functions inherited from moveit_studio::behaviors::AsyncBehaviorBase | |
virtual std::shared_future< tl::expected< bool, std::string > > & | getFuture ()=0 |
Gets the shared future which is used to monitor the progress of the async process. | |
void | notifyCanHalt () |
Called when runAsync() finishes to notify onHalted() that the async process has finished. | |
Additional Inherited Members | |
Protected Attributes inherited from moveit_studio::behaviors::SharedResourcesNode< BT::StatefulActionNode > | |
std::shared_ptr< BehaviorContext > | shared_resources_ |
A base class for behaviors which need to send a goal to a ROS action client and wait for a result. If the behavior is halted before the action result is received, the action goal will be canceled.
Important: If a halt is requested before the action goal request is sent to the action server or before the action goal response has been received from the action server, the behavior will wait to halt until the action goal response has been received then request that the action goal be canceled, and will finally wait until the in-progress action goal has finished.
ActionT | ROS action message type used to specialize this class for a specific action |
using moveit_studio::behaviors::ActionClientBehaviorBase< ActionT >::ClientGoalHandle = rclcpp_action::ClientGoalHandle<ActionT> |
moveit_studio::behaviors::ActionClientBehaviorBase< ActionT >::ActionClientBehaviorBase | ( | const std::string & | name, |
const BT::NodeConfiguration & | config, | ||
const std::shared_ptr< BehaviorContext > & | shared_resources | ||
) |
Constructs ActionClientBehaviorBase using the RclcppClientInterface.
moveit_studio::behaviors::ActionClientBehaviorBase< ActionT >::ActionClientBehaviorBase | ( | const std::string & | name, |
const BT::NodeConfiguration & | config, | ||
const std::shared_ptr< BehaviorContext > & | shared_resources, | ||
std::unique_ptr< ClientInterfaceBase > | client_interface | ||
) |
Constructs ActionClientBehaviorBase using a user-provided implementation of ClientInterfaceBase.
|
virtualdefault |
|
protectedpure virtual |
User-provided function to create the action goal before sending the action goal request.
|
inlineprotectedvirtual |
Optional user-provided function to retrieve and surface an error message from an aborted action server result.
If no user-defined implementation is provided, then this method will simply return "Action goal was aborted."
result | Action result message to process. |
|
protectedpure virtual |
User-provided function to get the name of the action when initializing the action client.
Implemented in moveit_studio::behaviors::NavigateThroughPosesAction, moveit_studio::behaviors::NavigateToPoseAction, moveit_studio::behaviors::ShapeCompletionAction, and moveit_studio::behaviors::GetMasks2DAction.
|
inlineprotectedvirtual |
Optional user-provided function to set the timeout used when waiting for the action result.
If no user-defined implementation is provided, the default implementation returns a negative duration, which will cause the action client to wait for the result without timing out.
|
inlineprotectedvirtual |
Optional user-provided function to process feedback sent by the action server.
If no user-defined implementation is provided, then no additional processing will be performed on action feedback and this function will always return void.
feedback | Action feedback message to process. |
|
inlineprotectedvirtual |
Optional user-provided function to process the action result after the action has finished.
If no user-defined implementation is provided, then no additional processing will be performed on succeeding action results and this function will always return true.
result | Action result message to process. |