1
0
mirror of https://github.com/undera/pylgbst.git synced 2020-11-18 19:37:26 -08:00
Andrey Pokhilko 32eecac1a6
Make v1.0, based on official docs (#27)
* 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
2019-05-30 17:02:50 +03:00

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)