Nav2 Navigation Stack - rolling  main
ROS 2 Navigation Stack
progress_checker_selector_node.cpp
1 // Copyright (c) 2024 Open Navigation LLC
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #include <string>
16 #include <memory>
17 
18 #include "std_msgs/msg/string.hpp"
19 
20 #include "nav2_behavior_tree/plugins/action/progress_checker_selector_node.hpp"
21 
22 #include "rclcpp/rclcpp.hpp"
23 
24 namespace nav2_behavior_tree
25 {
26 
27 using std::placeholders::_1;
28 
30  const std::string & name,
31  const BT::NodeConfiguration & conf)
32 : BT::SyncActionNode(name, conf)
33 {
34  initialize();
35 }
36 
37 void ProgressCheckerSelector::initialize()
38 {
39  createROSInterfaces();
40 }
41 
42 void ProgressCheckerSelector::createROSInterfaces()
43 {
44  std::string topic_new;
45  getInput("topic_name", topic_new);
46  if (topic_new != topic_name_ || !progress_checker_selector_sub_) {
47  topic_name_ = topic_new;
48  node_ = config().blackboard->get<nav2::LifecycleNode::SharedPtr>("node");
49  callback_group_ = node_->create_callback_group(
50  rclcpp::CallbackGroupType::MutuallyExclusive,
51  false);
52  callback_group_executor_.add_callback_group(callback_group_, node_->get_node_base_interface());
53 
54  progress_checker_selector_sub_ = node_->create_subscription<std_msgs::msg::String>(
55  topic_name_,
56  std::bind(&ProgressCheckerSelector::callbackProgressCheckerSelect, this, _1),
58  callback_group_);
59  }
60 }
61 
62 BT::NodeStatus ProgressCheckerSelector::tick()
63 {
64  if (!BT::isStatusActive(status())) {
65  initialize();
66  }
67 
68  callback_group_executor_.spin_some();
69 
70  // This behavior always use the last selected progress checker received from the topic input.
71  // When no input is specified it uses the default goaprogressl checker.
72  // If the default progress checker is not specified then we work in
73  // "required progress checker mode": In this mode, the behavior returns failure if the progress
74  // checker selection is not received from the topic input.
75  if (last_selected_progress_checker_.empty()) {
76  std::string default_progress_checker;
77  getInput("default_progress_checker", default_progress_checker);
78  if (default_progress_checker.empty()) {
79  return BT::NodeStatus::FAILURE;
80  } else {
81  last_selected_progress_checker_ = default_progress_checker;
82  }
83  }
84 
85  setOutput("selected_progress_checker", last_selected_progress_checker_);
86 
87  return BT::NodeStatus::SUCCESS;
88 }
89 
90 void
91 ProgressCheckerSelector::callbackProgressCheckerSelect(const std_msgs::msg::String::SharedPtr msg)
92 {
93  last_selected_progress_checker_ = msg->data;
94 }
95 
96 } // namespace nav2_behavior_tree
97 
98 #include "behaviortree_cpp/bt_factory.h"
99 BT_REGISTER_NODES(factory)
100 {
101  factory.registerNodeType<nav2_behavior_tree::ProgressCheckerSelector>("ProgressCheckerSelector");
102 }
A QoS profile for latched, reliable topics with a history of 10 messages.
The ProgressCheckerSelector behavior is used to switch the progress checker of the controller server....
ProgressCheckerSelector(const std::string &xml_tag_name, const BT::NodeConfiguration &conf)
A constructor for nav2_behavior_tree::ProgressCheckerSelector.