-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathproximity.py
98 lines (80 loc) · 3.13 KB
/
proximity.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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# Three point turn pseudo code
#!/usr/bin/python
# -*- coding: utf-8 -*-
from ABE_ADCPi import ADCPi
from ABE_helpers import ABEHelpers
import sys
import logging
import time
logging.basicConfig(stream=sys.stdout, level=logging.INFO)
class Proximity:
def __init__(self, drive):
""" Standard Constructor """
logging.info("Proximity constructor")
# set up ADC
self.i2c_helper = ABEHelpers()
self.bus = self.i2c_helper.get_smbus()
self.adc = ADCPi(self.bus, 0x6a, 0x6b, 12)
# define fixed values
self.stopped = 0
self.full_forward = 0.4
self.slow_forward = 0.3
self.full_reverse = -0.5
self.slow_reverse = -0.25
self.left_steering = -0.25
self.right_steering = 0.25
self.straight = 0
self.distance_sensor = 1
# Voltage value we are aiming for (2 was close, 0.5 was further away)
self.distance_threshold = 50.0
self.distance_required = 17.0
# Drivetrain is passed in
self.drive = drive
self.killed = False
def stop(self):
"""Simple method to stop the challenge"""
self.killed = True
def run(self):
""" Main call to run the three point turn script """
# Drive forward for a set number of seconds keeping distance equal
logging.info("forward to turning point")
self.move_segment()
# Final set motors to neutral to stop
logging.info("Finished Event")
self.drive.set_neutral()
def get_distance(self):
distance = 0.0
if self.distance_sensor:
voltage = self.adc.read_voltage(self.distance_sensor)
distance = 27.0 / voltage
return distance
def move_segment(self):
logging.info("move_segment called with arguments: {0}".format(locals()))
# Throttle is static and does not change
throttle = self.full_forward
# Steering starts at zero (straight forward)
steering = self.straight
# Drive forward at half speed until we get reasonably close
distance = self.get_distance()
logging.info("distance: {0}".format(distance))
time.sleep(0.05)
while not self.killed and (distance > self.distance_threshold):
self.drive.mix_channels_and_assign(self.straight, self.full_forward)
distance = self.get_distance()
logging.info("F: distance: {0}".format(distance))
time.sleep(0.05)
self.drive.set_neutral()
time.sleep(0.05)
logging.info("Entering Half Speed")
# Drive forward at slow/min speed until we get very close
while not self.killed and (distance > self.distance_required):
self.drive.mix_channels_and_assign(self.straight, self.slow_forward)
distance = self.get_distance()
logging.info("S: distance: {0}".format(distance))
time.sleep(0.05)
# Ever so slight brake
self.drive.mix_channels_and_assign(self.straight, self.slow_reverse)
time.sleep(0.05)
self.drive.set_neutral()
time.sleep(0.05)
logging.info("Finished manoeuvre")