-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathimuSensor.py
116 lines (88 loc) · 3.3 KB
/
imuSensor.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
import time
import json
import datetime
import math
import board
import adafruit_bno055
import socketio
import obdUtils
SENSOR_TYPE = 'IMU'
ERROR = 'ERR'
INFO = 'INFO'
RETRY_INTERVAL = 1 #Delay in seconds when retrying to connect to node server
POLL_INTERVAL = .0333333 #~30hz
GRAVITY = 9.80665
i2c = board.I2C()
sensor = adafruit_bno055.BNO055_I2C(i2c)
last_val = 0xFFFF
sio = None
numTries = 1
def temperature():
global last_val # pylint: disable=global-statement
result = sensor.temperature
if abs(result - last_val) == 128:
result = sensor.temperature
if abs(result - last_val) == 128:
return 0b00111111 & result
last_val = result
return result
def emitImuData():
global i2c
global sensor
while True:
try:
xA, yA, zA = sensor.acceleration
xL, yL, zL = sensor.linear_acceleration
heading, roll, pitch = sensor.euler
temp = temperature()
xQ, yQ, zQ, wQ = sensor.quaternion
sys, gyro, accel, mag = sensor.calibration_status
data = {
"accelX": xA,
"accelY": yA,
"accelZ": zA,
"linAccelX": xL,
"linAccelY": yL,
"linAccelZ": zL,
"gForce": math.sqrt((xL * xL) + (yL * yL) + (zL * zL)) / GRAVITY,
"heading": heading,
"roll": roll,
"pitch": pitch,
"temp": temp,
"quatX": xQ, #quatX and quatY seem to be reversed? x and y values will be swapped in javascript
"quatY": yQ,
"quatZ": zQ,
"quatW": wQ,
"calSys": sys,
"calGyro": gyro,
"calAccel": accel,
"calMag": mag,
}
sio.emit('imuData', json.dumps(data))
except Exception as ex:
errorLog = obdUtils.createLogMessage(ERROR, SENSOR_TYPE, type(ex).__name__, ex.args)
print(errorLog)
sio.emit('log', json.dumps(errorLog)) #will only work if exception is unrelated to node server connection
i2c = board.I2C() #try to reconnect to BNO055 sensor
sensor = adafruit_bno055.BNO055_I2C(i2c)
continue
time.sleep(POLL_INTERVAL)
while True: #loop until a connection is made with the server instead of immediately exiting
try:
sio = socketio.Client()
sio.connect('http://localhost:3000')
emitImuData() #temp workaround. Originally not needed. Seems to be issue with nodejs socketio version not sending connect packet to trigger connect() event
break;
except Exception as ex:
numTries += 1
print("IMU app unable to connect to node server, retrying attempt {0}".format(numTries))
errorLog = obdUtils.createLogMessage(ERROR, SENSOR_TYPE, type(ex).__name__, ex.args)
print(errorLog)
time.sleep(RETRY_INTERVAL)
continue
@sio.event
def connect():
connectedLog = obdUtils.createLogMessage(INFO, SENSOR_TYPE, 'Connection', 'Established')
print(connectedLog)
sio.emit('log', json.dumps(connectedLog))
emitImuData()