-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdrive.py
More file actions
75 lines (56 loc) · 2.21 KB
/
drive.py
File metadata and controls
75 lines (56 loc) · 2.21 KB
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
import time
from math import copysign
from time import sleep
from createserial.commands import create_dd
from common.gyro_movements import straight_drive
from sensors import on_black_left, on_black_right, gyroscope
def msleep(milliseconds):
sleep(milliseconds/1000)
def drive(left_speed, right_speed, duration):
create_dd(-5 * right_speed, -5 * left_speed)
msleep(duration)
create_dd(0, 0)
def stop_motors(stop_time=None):
create_dd(0, 0)
if stop_time is not None:
msleep(stop_time)
def untimed_drive(left_speed, right_speed):
create_dd(-5 * right_speed, -5 * left_speed)
def square_up_black(left_speed, right_speed, threshold=1500):
untimed_drive(left_speed, right_speed)
while left_speed != 0 or right_speed != 0:
if on_black_left(threshold):
left_speed = 0
untimed_drive(left_speed, right_speed)
if on_black_right(threshold):
right_speed = 0
untimed_drive(left_speed, right_speed)
untimed_drive(0, 0)
def square_up_white(left_speed, right_speed, threshold=1500):
untimed_drive(left_speed, right_speed)
while left_speed != 0 or right_speed != 0:
if not on_black_left(threshold):
left_speed = 0
untimed_drive(left_speed, right_speed)
if not on_black_right(threshold):
right_speed = 0
untimed_drive(left_speed, right_speed)
untimed_drive(0, 0)
def gyro_turn(left_speed, right_speed, angle):
old_time = time.time()
untimed_drive(left_speed, right_speed)
current_turned_distance = 0
while abs(current_turned_distance) < abs(angle):
current_turned_distance += gyroscope() * (time.time() - old_time) / 8
old_time = time.time()
msleep(10)
untimed_drive(0, 0)
def gyro_turn_with_slow_down(left_speed, right_speed, angle):
fast_angle = 0.50 * angle
slow_angle = angle - fast_angle
gyro_turn(left_speed, right_speed, fast_angle)
gyro_turn(int(copysign(10, left_speed)), int(copysign(10, right_speed)), slow_angle)
def straight_drive_black(speed, stop_when_finished=True):
def see_white():
return not (on_black_left() or on_black_right())
straight_drive(speed, see_white, stop_when_finished)