19 from rclpy.duration
import Duration
22 Basic navigation demo to go to poses.
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)
47 navigator.waitUntilNav2Active()
59 goal_pose1 = PoseStamped()
60 goal_pose1.header.frame_id =
'map'
61 goal_pose1.header.stamp = navigator.get_clock().now().to_msg()
62 goal_pose1.pose.position.x = 10.15
63 goal_pose1.pose.position.y = -0.77
64 goal_pose1.pose.orientation.w = 1.0
65 goal_pose1.pose.orientation.z = 0.0
66 goal_poses.append(goal_pose1)
69 goal_pose2 = PoseStamped()
70 goal_pose2.header.frame_id =
'map'
71 goal_pose2.header.stamp = navigator.get_clock().now().to_msg()
72 goal_pose2.pose.position.x = 17.86
73 goal_pose2.pose.position.y = -0.77
74 goal_pose2.pose.orientation.w = 1.0
75 goal_pose2.pose.orientation.z = 0.0
76 goal_poses.append(goal_pose2)
77 goal_pose3 = PoseStamped()
78 goal_pose3.header.frame_id =
'map'
79 goal_pose3.header.stamp = navigator.get_clock().now().to_msg()
80 goal_pose3.pose.position.x = 21.58
81 goal_pose3.pose.position.y = -3.5
82 goal_pose3.pose.orientation.w = 1.0
83 goal_pose3.pose.orientation.z = 0.0
84 goal_poses.append(goal_pose3)
89 nav_through_poses_task = navigator.goThroughPoses(goal_poses)
92 while not navigator.isTaskComplete(task=nav_through_poses_task):
101 feedback = navigator.getFeedback(task=nav_through_poses_task)
102 if feedback
and i % 5 == 0:
104 'Estimated time of arrival: '
106 Duration.from_msg(feedback.estimated_time_remaining).nanoseconds
113 if Duration.from_msg(feedback.navigation_time) > Duration(seconds=600.0):
114 navigator.cancelTask()
117 if Duration.from_msg(feedback.navigation_time) > Duration(seconds=35.0):
118 goal_pose4 = PoseStamped()
119 goal_pose4.header.frame_id =
'map'
120 goal_pose4.header.stamp = navigator.get_clock().now().to_msg()
121 goal_pose4.pose.position.x = 0.0
122 goal_pose4.pose.position.y = 0.0
123 goal_pose4.pose.orientation.w = 1.0
124 goal_pose4.pose.orientation.z = 0.0
125 navigator.goThroughPoses([goal_pose4])
128 result = navigator.getResult()
129 if result == TaskResult.SUCCEEDED:
130 print(
'Goal succeeded!')
131 elif result == TaskResult.CANCELED:
132 print(
'Goal was canceled!')
133 elif result == TaskResult.FAILED:
134 (error_code, error_msg) = navigator.getTaskError()
135 print(
'Goal failed!{error_code}:{error_msg}')
137 print(
'Goal has an invalid return status!')
139 navigator.lifecycleShutdown()
144 if __name__ ==
'__main__':