16 from geometry_msgs.msg
import PoseStamped
22 Basic navigation demo to follow a given path after smoothing
29 navigator = BasicNavigator()
32 initial_pose = PoseStamped()
33 initial_pose.header.frame_id =
'map'
34 initial_pose.header.stamp = navigator.get_clock().now().to_msg()
35 initial_pose.pose.position.x = 0.0
36 initial_pose.pose.position.y = 0.0
37 initial_pose.pose.orientation.z = 0.0
38 initial_pose.pose.orientation.w = 1.0
39 navigator.setInitialPose(initial_pose)
42 navigator.waitUntilNav2Active()
45 goal_pose = PoseStamped()
46 goal_pose.header.frame_id =
'map'
47 goal_pose.header.stamp = navigator.get_clock().now().to_msg()
48 goal_pose.pose.position.x = 7.0
49 goal_pose.pose.position.y = 0.5
50 goal_pose.pose.orientation.w = 1.0
53 path = navigator.getPath(initial_pose, goal_pose)
54 smoothed_path = navigator.smoothPath(path)
57 navigator.followPath(smoothed_path)
60 while not navigator.isTaskComplete():
69 feedback = navigator.getFeedback()
70 if feedback
and i % 5 == 0:
72 'Estimated distance remaining to goal position: '
73 +
'{0:.3f}'.format(feedback.distance_to_goal)
74 +
'\nCurrent speed of the robot: '
75 +
'{0:.3f}'.format(feedback.speed)
79 result = navigator.getResult()
80 if result == TaskResult.SUCCEEDED:
81 print(
'Goal succeeded!')
82 elif result == TaskResult.CANCELED:
83 print(
'Goal was canceled!')
84 elif result == TaskResult.FAILED:
87 print(
'Goal has an invalid return status!')
89 navigator.lifecycleShutdown()
94 if __name__ ==
'__main__':