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

Allow access to action feedback in nav2_behavior_tree::BtActionNode::on_wait_for_result #2972

Merged
merged 4 commits into from
May 27, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 29 additions & 2 deletions nav2_behavior_tree/include/nav2_behavior_tree/bt_action_node.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@

#include <memory>
#include <string>
#include <mutex>

#include "behaviortree_cpp_v3/action_node.h"
#include "nav2_util/node_utils.hpp"
Expand Down Expand Up @@ -133,8 +134,9 @@ class BtActionNode : public BT::ActionNodeBase
/**
* @brief Function to perform some user-defined operation after a timeout
* waiting for a result that hasn't been received yet
* @param feedback shared_ptr to latest feedback message
*/
virtual void on_wait_for_result()
virtual void on_wait_for_result(std::shared_ptr<const typename ActionT::Feedback> /*feedback*/)
{
}

Expand Down Expand Up @@ -206,7 +208,13 @@ class BtActionNode : public BT::ActionNodeBase
// The following code corresponds to the "RUNNING" loop
if (rclcpp::ok() && !goal_result_available_) {
// user defined callback. May modify the value of "goal_updated_"
on_wait_for_result();
on_wait_for_result(feedback_);

// reset feedback to avoid stale information
{
std::lock_guard<std::mutex> lock_guard(feedback_mutex_);
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
feedback_.reset();
}

auto goal_status = goal_handle_->get_status();
if (goal_updated_ && (goal_status == action_msgs::msg::GoalStatus::STATUS_EXECUTING ||
Expand Down Expand Up @@ -290,6 +298,15 @@ class BtActionNode : public BT::ActionNodeBase
setStatus(BT::NodeStatus::IDLE);
}

/**
* @brief Getter function for latest feedback message from action server
* @return shared_ptr to latest feedback message
*/
std::shared_ptr<const typename ActionT::Feedback> getFeedback()
{
return feedback_;
}

protected:
/**
* @brief Function to check if current goal should be cancelled
Expand Down Expand Up @@ -340,6 +357,12 @@ class BtActionNode : public BT::ActionNodeBase
result_ = result;
}
};
send_goal_options.feedback_callback =
[this](typename rclcpp_action::ClientGoalHandle<ActionT>::SharedPtr,
const std::shared_ptr<const typename ActionT::Feedback> feedback) {
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
std::lock_guard<std::mutex> lock_guard(feedback_mutex_);
feedback_ = feedback;
};

future_goal_handle_ = std::make_shared<
std::shared_future<typename rclcpp_action::ClientGoalHandle<ActionT>::SharedPtr>>(
Expand Down Expand Up @@ -406,6 +429,10 @@ class BtActionNode : public BT::ActionNodeBase
typename rclcpp_action::ClientGoalHandle<ActionT>::SharedPtr goal_handle_;
typename rclcpp_action::ClientGoalHandle<ActionT>::WrappedResult result_;

// To handle feedback from action server
std::mutex feedback_mutex_;
std::shared_ptr<const typename ActionT::Feedback> feedback_;

// The node that will be used for any ROS operations
rclcpp::Node::SharedPtr node_;
rclcpp::CallbackGroup::SharedPtr callback_group_;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,9 @@ class FollowPathAction : public BtActionNode<nav2_msgs::action::FollowPath>
/**
* @brief Function to perform some user-defined operation after a timeout
* waiting for a result that hasn't been received yet
* @param feedback shared_ptr to latest feedback message
*/
void on_wait_for_result() override;
void on_wait_for_result(std::shared_ptr<const nav2_msgs::action::FollowPath::Feedback> feedback) override;

/**
* @brief Creates list of BT ports
Expand Down
2 changes: 1 addition & 1 deletion nav2_behavior_tree/plugins/action/follow_path_action.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ void FollowPathAction::on_tick()
getInput("goal_checker_id", goal_.goal_checker_id);
}

void FollowPathAction::on_wait_for_result()
void FollowPathAction::on_wait_for_result(std::shared_ptr<const nav2_msgs::action::FollowPath::Feedback> /*feedback*/)
{
// Grab the new path
nav_msgs::msg::Path new_path;
Expand Down