mirror of
https://github.com/undera/pylgbst.git
synced 2020-11-18 19:37:26 -08:00
* It's HUB ID * Rename file * Working with official doc * Some progress * AttachedIO msg * device action impl * some better device alert impl * restructuring * Some port commands handled * Some command feedback waiting * Some more request-reply things * Some more request-reply things * Reworked msg classes * Getting back to UTs * Getting back to UTs * Facing sync lock problems * Facing sync lock problems * Testing it * Covering more with tests * handle actions * Hub class is almost covered * done coverage for Hub * done coverage for MoveHub * Button is tested * remove debug server from examples * Current and voltage tested * color sensor basic test * cover tilt sensor * motor sensor tested * constant motor * motor is tested * hold_speed impl for motor * motor commands recorded * some cleanup * some cleanup * some cleanup * debug * debug * FIX a bug * acc/dec profiles figured out * UT motor ops * UT motor ops * Get rid of weird piggyback * fix UT * Fix encoding? * fix test mb * More robust * Checked demo works * cosmetics * cosmetics * Maybe better test * fetching and decoding some device caps * describing devs * describing devs works * Applying modes we've learned * Simple and extensible dev attach * Reworking peripherals based on modes * Applying modes we've learned * implemented getting sensor data * fixed port subscribe * Added led out cmds on vision sensor * Worked on color-distance sensor * Introduce some locking for consistency * Improved it all * Travis flags * improve * improve * improve docs
67 lines
1.5 KiB
Python
67 lines
1.5 KiB
Python
from pylgbst.peripherals import VisionSensor
|
|
from . import *
|
|
|
|
logging.basicConfig(level=logging.INFO)
|
|
|
|
robot = Vernie()
|
|
running = True
|
|
criterion = min
|
|
|
|
cur_luminosity = 0
|
|
|
|
|
|
def on_change_lum(lumn):
|
|
global cur_luminosity
|
|
cur_luminosity = lumn
|
|
|
|
|
|
lum_values = {}
|
|
|
|
|
|
def on_btn(pressed):
|
|
global running
|
|
if pressed:
|
|
running = False
|
|
|
|
|
|
def on_turn(angl):
|
|
lum_values[angl] = cur_luminosity
|
|
|
|
|
|
robot.button.subscribe(on_btn)
|
|
robot.vision_sensor.subscribe(on_change_lum, VisionSensor.DEBUG, granularity=1)
|
|
robot.motor_A.subscribe(on_turn, granularity=30)
|
|
|
|
# TODO: add bump detect to go back?
|
|
|
|
while running:
|
|
# turn around, measuring luminosity
|
|
lum_values = {}
|
|
robot.turn(RIGHT, degrees=360, speed=0.2)
|
|
|
|
# get max luminosity angle
|
|
amin = min(lum_values.keys())
|
|
lmax = max(lum_values.values())
|
|
almax = amin
|
|
for almax in lum_values:
|
|
if lum_values[almax] == lmax:
|
|
break
|
|
|
|
angle = int((almax - amin) / VERNIE_TO_MOTOR_DEGREES)
|
|
logging.info("Angle to brightest %.3f is %s", lmax, angle)
|
|
|
|
# turn towards light
|
|
if angle > 180:
|
|
robot.turn(LEFT, degrees=360 - angle)
|
|
else:
|
|
robot.turn(RIGHT, degrees=angle)
|
|
|
|
# Now let's move until luminosity changes
|
|
lum = cur_luminosity
|
|
while cur_luminosity >= lum:
|
|
logging.info("Luminosity is %.3f, moving towards it", cur_luminosity)
|
|
robot.move(FORWARD, 1)
|
|
|
|
robot.vision_sensor.unsubscribe(on_change_lum)
|
|
robot.button.unsubscribe(on_btn)
|