-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrun-this-to-test-without-ros.py
82 lines (64 loc) · 3.29 KB
/
run-this-to-test-without-ros.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
class Visualizer(object):
EXTEND_THRESHOLD = 0.8
def __init__(self, pixels_per_meter = 200):
import cv2
self.cv2 = cv2
from numpy import zeros
self.zeros = zeros
self._dot_scale = 0.004
self.pixels_per_meter = pixels_per_meter
self.counter = 0
self.position_graph = zeros((800, 800, 3), dtype = 'uint8')
def position(self, x, y, z, every = 100):
if self.counter%every is 0:
x, y = self._meters_to_pixels(x, y)
self._extend_canvas(x, y)
blue = 255 + 150*z# color represents depth
self.cv2.circle(self.position_graph, (x, y), self.dot_scale, (blue, 255, 0), -1)
self.cv2.imshow('position', self.position_graph)
self.cv2.waitKey(1)
self.counter += 1
def _meters_to_pixels(self, x, y):
y_range, x_range = self.position_graph.shape[:2]
y_center, x_center = [y_range//2, x_range//2]
return (int(x*self.pixels_per_meter + x_center), int(y_center - y*self.pixels_per_meter))
def _extend_canvas(self, x, y):
y_range, x_range = self.position_graph.shape[:2]
if x > x_range*Visualizer.EXTEND_THRESHOLD or y > y_range*Visualizer.EXTEND_THRESHOLD:
new_graph = self.cv2.resize(self.position_graph, (int(x_range*Visualizer.EXTEND_THRESHOLD), int(y_range*Visualizer.EXTEND_THRESHOLD)))
self.position_graph = self.zeros((self.position_graph.shape[0], self.position_graph.shape[1], 3), dtype = 'uint8')
border = [(big_dim - small_dim)//2 for (big_dim, small_dim) in zip(self.position_graph.shape, new_graph.shape)]
self.position_graph[border[0]:border[0] + new_graph.shape[0], border[1]:border[1] + new_graph.shape[1]] = new_graph
self.pixels_per_meter *= Visualizer.EXTEND_THRESHOLD
self._dot_scale *= Visualizer.EXTEND_THRESHOLD
@property
def dot_scale(self):
return int(self._dot_scale*self.position_graph.shape[0])
def main(simulating = False):
if simulating:
from main_module.gyro.simulation import Simulated as Gyro
from main_module.odometer.simulation import Simulated as Odometer
from main_module.propulsion.simulation import Simulated as Propulsion
from main_module.planning.s2018 import coach
gyro = Gyro(30.0)
odometer = Odometer(30.0)
propulsion = Propulsion(gyro, 30.0)
choice = eval(input('Which strategy should we run? (Enter 0, 1, or 2): '))
strategy = coach.list_of_strategies()[choice]
strategy = coach.initialize(strategy, gyro, odometer)
visualizer = Visualizer()
while True:
try:
strategy.run(propulsion, [])
gyro.complete_loop_update(propulsion)
odometer.complete_loop_update(gyro, propulsion)
# print(odometer.position.xyz)
visualizer.position(odometer.position.x, odometer.position.y, odometer.position.z)
except KeyboardInterrupt:
break
else:
from main_module.gyro.ros_gyro import ROS_Gyro as Gyro
from main_module.odometer.ros_odometer import ROS_Odometer as Odometer
from main_module.propulsion.robot2018 import Robot2018 as Propulsion
if __name__ == '__main__':
main(simulating = True)