Add lidar animate test, fix mock iterable.

This commit is contained in:
Piv
2020-03-11 22:26:42 +10:30
parent c9a421867b
commit 40e3d283bf
2 changed files with 51 additions and 1 deletions

43
tracking/animate.py Executable file
View File

@@ -0,0 +1,43 @@
#!/usr/bin/env python3
'''Animates distances and measurment quality'''
from tracking.mock_lidar import MockLidar
import matplotlib.pyplot as plt
import numpy as np
import matplotlib.animation as animation
import tracking.lidar_loader as loader
PORT_NAME = '/dev/ttyUSB0'
DMAX = 4000
IMIN = 0
IMAX = 50
def update_line(num, iterator, line):
scan = next(iterator)
offsets = np.array([(np.radians(meas[1]), meas[2]) for meas in scan])
line.set_offsets(offsets)
intens = np.array([meas[0] for meas in scan])
line.set_array(intens)
return line,
def run():
lidar = MockLidar(loader.load_scans_bytes_file("tracking/out.pickle"))
fig = plt.figure()
ax = plt.subplot(111, projection='polar')
line = ax.scatter([0, 0], [0, 0], s=5, c=[IMIN, IMAX],
cmap=plt.cm.Greys_r, lw=0)
ax.set_rmax(DMAX)
ax.grid(True)
iterator = lidar.iter_scans()
ani = animation.FuncAnimation(fig, update_line,
fargs=(iterator, line), interval=50)
plt.show()
lidar.stop()
lidar.disconnect()
if __name__ == '__main__':
run()

View File

@@ -6,6 +6,7 @@ in the lidar_cache for testing (or anywhere else the rplidar may be used)
import tracking.lidar_loader as loader import tracking.lidar_loader as loader
class MockLidar: class MockLidar:
def __init__(self, scan_iter=None): def __init__(self, scan_iter=None):
@@ -27,10 +28,16 @@ class MockLidar:
self._iter = scan_iter self._iter = scan_iter
def iter_scans(self, min_len=100): def iter_scans(self, min_len=100):
return self._iter return iter(self._iter)
def get_health(self): def get_health(self):
return "Mock Lidar has scans" if self._iter is not None else "Mock lidar won't work properly!" return "Mock Lidar has scans" if self._iter is not None else "Mock lidar won't work properly!"
def get_info(self): def get_info(self):
return self.get_health() return self.get_health()
def stop(self):
pass
def disconnect(self):
pass