forked from legonigel/wii-drone-on
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbalanceboard.py
93 lines (78 loc) · 2.6 KB
/
balanceboard.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
83
84
85
86
87
88
89
90
91
92
93
#! /usr/bin/python
import cwiid
from time import sleep
class InputBalanceBoard(object):
def makeConnection(self):
print "Press sync on da board yo"
try:
wiiboard = cwiid.Wiimote()
except RuntimeError:
wiiboard = None
else:
wiiboard.led = 1
wiiboard.rpt_mode = cwiid.RPT_BALANCE | cwiid.RPT_BTN
wiiboard.request_status()
sleep(1)
print wiiboard.state['ext_type']
ballance_calibration = wiiboard.get_balance_cal()
self.named_cal = {'right_top':ballance_calibration[0],
'right_bottom':ballance_calibration[1],
'left_top':ballance_calibration[2],
'left_bottom':ballance_calibration[3]}
self.calibrations = ballance_calibration
print "you be connected"
self.wiiboard = wiiboard
return wiiboard
def determine(self):
command = ""
if not self.wiiboard:
return command
self.wiiboard.request_status()
readings = self.wiiboard.state['balance']
weight = (calcweight(readings, self.named_cal)/100.0)
x_bal, y_bal = get_balance(readings, self.named_cal)
if (not ( -1 <= x_bal <= 1 )) or (not ( -1 <= y_bal <= 1)):
return ""
command = "lr " + str(x_bal / 3.0) + " fb " + str(y_bal / 3.0)
return command
def get_balance(readings, calibrations):
right_top = gsc(readings, 'right_top', calibrations)
left_top = gsc(readings, 'left_top' , calibrations)
right_bottom = gsc(readings, 'right_bottom', calibrations)
left_bottom = gsc(readings, 'left_bottom' , calibrations)
try:
x_bal = (float(right_top + right_bottom)) / (float(left_top + left_bottom))
if x_bal > 1:
x_bal = ((float(left_top + left_bottom)) / (float(right_top + right_bottom)) * -1.0) + 1.0
else:
x_bal = x_bal - 1.0
y_bal = (float(left_bottom + right_bottom)) / (float(left_top + right_top))
if y_bal > 1:
y_bal = ((float(left_top + right_top)) / (float(left_bottom + right_bottom)) * -1.0) + 1.0
else:
y_bal = y_bal - 1.0
except:
x_bal = 0
y_bal = 0
return (x_bal, y_bal)
def gsc(readings, pos, calibrations):
reading = readings[pos]
calibration = calibrations[pos]
if reading < calibration[1]:
weight = 1700 * (reading - calibration[0]) / (calibration[1] - calibration[0])
else:
weight = 1700 * (reading - calibration[0]) / (calibration[2] - calibration[1]) + 1700
return weight
def calcweight(readings, calibrations):
weight = 0
for sensor in ('right_top','right_bottom','left_top','left_bottom'):
weight += gsc(readings, sensor, calibrations)
return weight
def main():
myBoard = InputBalanceBoard()
board = myBoard.makeConnection()
while True:
board.led = (board.state['led'] + 1) % 2
print myBoard.determine()
if __name__ == "__main__":
main()