16 from geometry_msgs.msg
import PoseStamped
19 from rclpy.duration
import Duration
23 Basic recoveries demo. In this demonstration, the robot navigates
24 to a dead-end where recoveries such as backup and spin are used
32 navigator = BasicNavigator()
35 initial_pose = PoseStamped()
36 initial_pose.header.frame_id =
'map'
37 initial_pose.header.stamp = navigator.get_clock().now().to_msg()
38 initial_pose.pose.position.x = 3.45
39 initial_pose.pose.position.y = 2.15
40 initial_pose.pose.orientation.z = 1.0
41 initial_pose.pose.orientation.w = 0.0
42 navigator.setInitialPose(initial_pose)
45 navigator.waitUntilNav2Active()
47 goal_pose = PoseStamped()
48 goal_pose.header.frame_id =
'map'
49 goal_pose.header.stamp = navigator.get_clock().now().to_msg()
50 goal_pose.pose.position.x = 6.13
51 goal_pose.pose.position.y = 1.90
52 goal_pose.pose.orientation.w = 1.0
54 navigator.goToPose(goal_pose)
57 while not navigator.isTaskComplete():
59 feedback = navigator.getFeedback()
60 if feedback
and i % 5 == 0:
62 f
'Estimated time of arrival to destination is: \
63 {Duration.from_msg(feedback.estimated_time_remaining).nanoseconds / 1e9}'
67 print(
'Robot hit a dead end, backing up...')
68 navigator.backup(backup_dist=0.5, backup_speed=0.1)
71 while not navigator.isTaskComplete():
73 feedback = navigator.getFeedback()
74 if feedback
and i % 5 == 0:
75 print(f
'Distance traveled: {feedback.distance_traveled}')
78 print(
'Spinning robot around...')
79 navigator.spin(spin_dist=3.14)
82 while not navigator.isTaskComplete():
84 feedback = navigator.getFeedback()
85 if feedback
and i % 5 == 0:
86 print(f
'Spin angle traveled: {feedback.angular_distance_traveled}')
88 result = navigator.getResult()
89 if result == TaskResult.SUCCEEDED:
90 print(
'Dead end confirmed! Returning to start...')
91 elif result == TaskResult.CANCELED:
92 print(
'Recovery was canceled. Returning to start...')
93 elif result == TaskResult.FAILED:
94 print(
'Recovering from dead end failed! Returning to start...')
96 initial_pose.header.stamp = navigator.get_clock().now().to_msg()
97 navigator.goToPose(initial_pose)
98 while not navigator.isTaskComplete():
104 if __name__ ==
'__main__':