15 #ifndef PLANNING__PLANNER_TESTER_HPP_
16 #define PLANNING__PLANNER_TESTER_HPP_
18 #include <gtest/gtest.h>
24 #include "nav2_ros_common/lifecycle_node.hpp"
25 #include "nav2_msgs/action/compute_path_to_pose.hpp"
26 #include "nav_msgs/msg/occupancy_grid.hpp"
27 #include "nav2_msgs/msg/costmap.hpp"
28 #include "nav2_msgs/srv/get_costmap.hpp"
29 #include "nav2_msgs/srv/is_path_valid.hpp"
30 #include "nav2_util/costmap.hpp"
31 #include "nav2_ros_common/node_thread.hpp"
32 #include "geometry_msgs/msg/pose_stamped.hpp"
33 #include "geometry_msgs/msg/transform_stamped.hpp"
34 #include "nav2_planner/planner_server.hpp"
35 #include "tf2_ros/transform_broadcaster.hpp"
37 namespace nav2_system_tests
53 std::cout <<
"" << std::endl;
55 std::cout << costmap_ros_->getCostmap()->getCharMap()[i] <<
" ";
57 std::cout <<
"" << std::endl;
62 std::unique_lock<nav2_costmap_2d::Costmap2D::mutex_t> lock(
63 *(costmap_ros_->getCostmap()->getMutex()));
65 nav2_msgs::msg::CostmapMetaData prop;
66 nav2_msgs::msg::Costmap cm = costmap->
get_costmap(prop);
68 costmap_ros_->getCostmap()->resizeMap(
69 prop.size_x, prop.size_y,
70 prop.resolution, prop.origin.position.x, prop.origin.position.x);
72 volatile unsigned char * costmap_ptr = costmap_ros_->getCostmap()->getCharMap();
74 costmap_ptr =
new unsigned char[prop.size_x * prop.size_y];
75 std::copy(cm.data.begin(), cm.data.end(), costmap_ptr);
79 const geometry_msgs::msg::PoseStamped & goal,
80 nav_msgs::msg::Path & path)
82 geometry_msgs::msg::PoseStamped start;
83 if (!nav2_util::getCurrentPose(start, *tf_,
"map",
"base_link", 0.1)) {
87 auto dummy_cancel_checker = []() {
return false;};
88 path = planners_[
"GridBased"]->createPlan(start, goal, dummy_cancel_checker);
92 if (!path.poses.size()) {
101 void onCleanup(
const rclcpp_lifecycle::State & state)
106 void onActivate(
const rclcpp_lifecycle::State & state)
111 void onDeactivate(
const rclcpp_lifecycle::State & state)
116 void onConfigure(
const rclcpp_lifecycle::State & state)
122 enum class TaskStatus : int8_t
132 using ComputePathToPoseCommand = geometry_msgs::msg::PoseStamped;
133 using ComputePathToPoseResult = nav_msgs::msg::Path;
143 void loadDefaultMap();
146 void loadSimpleCostmap(
const nav2_util::TestCostmap & testCostmapType);
151 bool defaultPlannerTest(
152 ComputePathToPoseResult & path,
153 const double deviation_tolerance = 1.0);
157 bool defaultPlannerRandomTests(
158 const unsigned int number_tests,
159 const float acceptable_fail_ratio);
162 nav_msgs::msg::Path & path,
unsigned int max_cost,
163 bool consider_unknown_as_obstacle);
168 TaskStatus createPlan(
169 const ComputePathToPoseCommand & goal,
170 ComputePathToPoseResult & path
176 bool using_fake_costmap_;
179 bool trinary_costmap_;
180 bool track_unknown_space_;
181 int lethal_threshold_;
182 int unknown_cost_value_;
183 nav2_util::TestCostmap testCostmapType_;
186 std::shared_ptr<nav_msgs::msg::OccupancyGrid> map_;
189 std::unique_ptr<nav2_util::Costmap> costmap_;
192 std::shared_ptr<NavFnPlannerTester> planner_tester_;
195 nav2::ServiceClient<nav2_msgs::srv::IsPathValid>::SharedPtr path_valid_client_;
198 std::unique_ptr<nav2::NodeThread> spin_thread_;
201 std::unique_ptr<geometry_msgs::msg::TransformStamped> base_transform_;
202 std::shared_ptr<tf2_ros::TransformBroadcaster> tf_broadcaster_;
203 rclcpp::TimerBase::SharedPtr transform_timer_;
204 void publishRobotTransform();
205 void startRobotTransform();
206 void updateRobotPosition(
const geometry_msgs::msg::Point & position);
209 nav2::Publisher<nav_msgs::msg::OccupancyGrid>::SharedPtr map_pub_;
210 rclcpp::TimerBase::SharedPtr map_timer_;
211 rclcpp::WallRate map_publish_rate_;
218 const geometry_msgs::msg::Point & robot_position,
219 const ComputePathToPoseCommand & goal,
220 ComputePathToPoseResult & path);
222 bool isCollisionFree(
const ComputePathToPoseResult & path);
224 bool isWithinTolerance(
225 const geometry_msgs::msg::Point & robot_position,
226 const ComputePathToPoseCommand & goal,
227 const ComputePathToPoseResult & path)
const;
229 bool isWithinTolerance(
230 const geometry_msgs::msg::Point & robot_position,
231 const ComputePathToPoseCommand & goal,
232 const ComputePathToPoseResult & path,
233 const double deviationTolerance,
234 const ComputePathToPoseResult & reference_path)
const;
236 void printPath(
const ComputePathToPoseResult & path)
const;
A lifecycle node wrapper to enable common Nav2 needs such as manipulating parameters.
unsigned int getSizeInCellsX() const
Accessor for the x size of the costmap in cells.
unsigned int getSizeInCellsY() const
Accessor for the y size of the costmap in cells.
An action server implements the behavior tree's ComputePathToPose interface and hosts various plugins...
nav2::CallbackReturn on_configure(const rclcpp_lifecycle::State &state) override
Configure member variables and initializes planner.
nav2::CallbackReturn on_deactivate(const rclcpp_lifecycle::State &state) override
Deactivate member variables.
PlannerServer(const rclcpp::NodeOptions &options=rclcpp::NodeOptions())
A constructor for nav2_planner::PlannerServer.
nav2::CallbackReturn on_cleanup(const rclcpp_lifecycle::State &state) override
Reset member variables.
nav2::CallbackReturn on_activate(const rclcpp_lifecycle::State &state) override
Activate member variables.
Class for a single layered costmap initialized from an occupancy grid representing the map.
nav2_msgs::msg::Costmap get_costmap(const nav2_msgs::msg::CostmapMetaData &specifications)
Get a costmap message from this object.