-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathroboot_follower.py
80 lines (63 loc) · 3.28 KB
/
roboot_follower.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#################################################################################################################
# RoboMaster Project #
# #
# Amichai Kafka & Liav weiss & Omer Michael #
#################################################################################################################
# In this part of the project we will present the robot's ability to track and shoot a robot.
# First we want to control the chassis the and gimbal manual, after that we will Enable detection of robot.
# We will set the gimbal rotation speed to the maximum possible, for fast object.
# We will set the travel mode to free mode so we can automatically rotate the gimbal.
# To truck after the robot we will need to save his previous possitions and his current position.
# After that as long as we recognize the robot we will track his location and shoot at him non-stop,
# as soon as the robot comes out of the robot's mediator of vision the robot will stop and wait (to use as little battery of the robot as possible).
pid = rm_ctrl.PIDCtrl()
def start():
V_avg = 1
k = 0.65
pid = rm_ctrl.PIDCtrl()
# enable detection of S1 robots.
vision_ctrl.enable_detection(rm_define.vision_detection_car)
vision_ctrl.set_marker_detection_distance(2)
# gimbal_ctrl.rotate_with_degree(rm_define.gimbal_up, 20)
gun_ctrl.set_fire_count(1)
gimbal_ctrl.set_rotate_speed(540)
pid.set_ctrl_params(330, 0, 28)
chassis_ctrl.enable_stick_overlay()
gimbal_ctrl.enable_stick_overlay()
robot_ctrl.set_mode(rm_define.robot_mode_free)
x = 0.0
y = 0.0
while True:
# Get list of detected S1 robots.
robotList = RmList(vision_ctrl.get_car_detection_info())
if robotList[1] > 0:
# We found at least one robot.
robot_ctrl.set_mode(rm_define.robot_mode_chassis_follow)
# gimbal.rotate_with_speed(pid.get_output(),0)
chassis_ctrl.set_trans_speed(0.3)
chassis_ctrl.move(0)
# Keep track of the current and previous x and y possitions of the
# detected robot.
prevX = x
prevY = y
# Get coordinates to the center of the first
# detected S1 robot. This will be our target.
x = robotList[2]
y = robotList[3]
if abs(x - prevX) < 0.03 and abs(y - prevY) < 0.03:
continue
yawAngle = gimbal_ctrl.get_axis_angle(rm_define.gimbal_axis_yaw)
pitchAngle = gimbal_ctrl.get_axis_angle(rm_define.gimbal_axis_pitch)
# Compute yaw and pitch angle offsets how much we need to move
yaw = 96 * (x - 0.5)
pitch = 54 * (0.5 - y)
if abs(yaw) > 2 or abs(pitch) > 2:
# Point gimbal to target.
try:
gimbal_ctrl.angle_ctrl(yawAngle + yaw, pitchAngle + pitch)
except:
print(" ")
gun_ctrl.fire_once()
else:
# gimbal.rotate_with_speed(0,0)
chassis_ctrl.stop()