-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscanner.py
43 lines (35 loc) · 1012 Bytes
/
scanner.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
#!/usr/bin/env python
import math
import time
import nxt.locator
from nxt.sensor import *
from nxt.motor import *
ARM_LENGTH = 8.0 # cm
DEG_PER_REAL_DEG = 20 # 500 deg == 25 deg
DEG_PER_CM = 500.0 # 5000 deg == 10 cm
def move(cm):
speed = -20
if (cm < 0): speed *= -1
deg = abs(cm) * DEG_PER_CM
driving_motor.turn(speed, deg)
def rotate(deg):
speed = 10
if (deg < 0): speed *= -1
deg *= DEG_PER_REAL_DEG
rotating_motor.turn(speed, abs(deg))
def get_x():
return math.sin(math.radians(__get_deg())) * ARM_LENGTH
def get_y():
rot = -driving_motor.get_tacho().rotation_count
dist = rot / DEG_PER_CM
dist += math.cos(math.radians(__get_deg())) * ARM_LENGTH
return dist
def __get_deg():
return rotating_motor.get_tacho().rotation_count / DEG_PER_REAL_DEG
def get_light():
return light_sensor.get_sample() / 1000.
brick = nxt.locator.find_one_brick()
light_sensor = Light(brick, PORT_1)
light_sensor.set_illuminated(True)
driving_motor = Motor(brick, PORT_A)
rotating_motor = Motor(brick, PORT_B)