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 = 3.45
36 initial_pose.pose.position.y = 2.15
37 initial_pose.pose.orientation.z = 1.0
38 initial_pose.pose.orientation.w = 0.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 = -3.0
49 goal_pose.pose.position.y = -2.0
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:
71 print(
'Estimated distance remaining to goal position: ' +
72 '{0:.3f}'.format(feedback.distance_to_goal) +
73 '\nCurrent speed of the robot: ' +
74 '{0:.3f}'.format(feedback.speed))
77 result = navigator.getResult()
78 if result == TaskResult.SUCCEEDED:
79 print(
'Goal succeeded!')
80 elif result == TaskResult.CANCELED:
81 print(
'Goal was canceled!')
82 elif result == TaskResult.FAILED:
85 print(
'Goal has an invalid return status!')
87 navigator.lifecycleShutdown()
92 if __name__ ==
'__main__':