Nav2 Navigation Stack - rolling  main
ROS 2 Navigation Stack
conversions.cpp
1 /*
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2017, Locus Robotics
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above
14  * copyright notice, this list of conditions and the following
15  * disclaimer in the documentation and/or other materials provided
16  * with the distribution.
17  * * Neither the name of the copyright holder nor the names of its
18  * contributors may be used to endorse or promote products derived
19  * from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  */
34 
35 #include "nav_2d_utils/conversions.hpp"
36 
37 #include <vector>
38 #include <string>
39 
40 #include "geometry_msgs/msg/pose.hpp"
41 #include "geometry_msgs/msg/pose_stamped.hpp"
42 #include "geometry_msgs/msg/twist.hpp"
43 #include "nav_msgs/msg/path.hpp"
44 #include "nav_2d_msgs/msg/twist2_d.hpp"
45 #include "tf2_geometry_msgs/tf2_geometry_msgs.hpp"
46 #pragma GCC diagnostic push
47 #pragma GCC diagnostic ignored "-Wpedantic"
48 #include "tf2/utils.hpp"
49 #pragma GCC diagnostic pop
50 
51 #include "nav2_util/geometry_utils.hpp"
52 
53 namespace nav_2d_utils
54 {
55 using nav2_util::geometry_utils::orientationAroundZAxis;
56 
57 geometry_msgs::msg::Twist twist2Dto3D(const nav_2d_msgs::msg::Twist2D & cmd_vel_2d)
58 {
59  geometry_msgs::msg::Twist cmd_vel;
60  cmd_vel.linear.x = cmd_vel_2d.x;
61  cmd_vel.linear.y = cmd_vel_2d.y;
62  cmd_vel.angular.z = cmd_vel_2d.theta;
63  return cmd_vel;
64 }
65 
66 nav_2d_msgs::msg::Twist2D twist3Dto2D(const geometry_msgs::msg::Twist & cmd_vel)
67 {
68  nav_2d_msgs::msg::Twist2D cmd_vel_2d;
69  cmd_vel_2d.x = cmd_vel.linear.x;
70  cmd_vel_2d.y = cmd_vel.linear.y;
71  cmd_vel_2d.theta = cmd_vel.angular.z;
72  return cmd_vel_2d;
73 }
74 
75 nav_msgs::msg::Path posesToPath(
76  const std::vector<geometry_msgs::msg::Pose> & poses,
77  const std::string & frame, const rclcpp::Time & stamp)
78 {
79  nav_msgs::msg::Path path;
80  path.poses.resize(poses.size());
81  path.header.frame_id = frame;
82  path.header.stamp = stamp;
83  for (unsigned int i = 0; i < poses.size(); i++) {
84  path.poses[i].header.frame_id = frame;
85  path.poses[i].header.stamp = stamp;
86  path.poses[i].pose = poses[i];
87  }
88  return path;
89 }
90 
91 } // namespace nav_2d_utils