forked from robintibor/python-mindwave-mobile
-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathMindwavePacketPayloadParser.py
78 lines (64 loc) · 2.84 KB
/
MindwavePacketPayloadParser.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
from MindwaveDataPoints import RawDataPoint, PoorSignalLevelDataPoint,\
AttentionDataPoint, MeditationDataPoint, BlinkDataPoint, EEGPowersDataPoint
EXTENDED_CODE_BYTE = 0x55
class MindwavePacketPayloadParser:
def __init__(self, payloadBytes):
self._payloadBytes = payloadBytes
self._payloadIndex = 0
def parseDataPoints(self):
dataPoints = []
while (not self._atEndOfPayloadBytes()):
dataPoint = self._parseOneDataPoint()
dataPoints.append(dataPoint)
return dataPoints
def _atEndOfPayloadBytes(self):
return self._payloadIndex == len(self._payloadBytes)
def _parseOneDataPoint(self):
dataRowCode = self._extractDataRowCode();
dataRowValueBytes = self._extractDataRowValueBytes(dataRowCode)
return self._createDataPoint(dataRowCode, dataRowValueBytes)
def _extractDataRowCode(self):
return self._ignoreExtendedCodeBytesAndGetRowCode()
def _ignoreExtendedCodeBytesAndGetRowCode(self):
# EXTENDED_CODE_BYTES seem not to be used according to
# http://wearcam.org/ece516/mindset_communications_protocol.pdf
# (August 2012)
# so we ignore them
byte = self._getNextByte()
while (byte == EXTENDED_CODE_BYTE):
byte = self._getNextByte()
dataRowCode = byte
return dataRowCode
def _getNextByte(self):
nextByte = self._payloadBytes[self._payloadIndex]
self._payloadIndex += 1
return nextByte
def _getNextBytes(self, amountOfBytes):
nextBytes = self._payloadBytes[self._payloadIndex : self._payloadIndex + amountOfBytes]
self._payloadIndex += amountOfBytes
return nextBytes
def _extractDataRowValueBytes(self, dataRowCode):
lengthOfValueBytes = self._extractLengthOfValueBytes(dataRowCode)
dataRowValueBytes = self._getNextBytes(lengthOfValueBytes)
return dataRowValueBytes
def _extractLengthOfValueBytes(self, dataRowCode):
dataRowHasLengthByte = dataRowCode > 0x7f
if (dataRowHasLengthByte):
return self._getNextByte()
else:
return 1
def _createDataPoint(self, dataRowCode, dataRowValueBytes):
if (dataRowCode == 0x02):
return PoorSignalLevelDataPoint(dataRowValueBytes)
elif (dataRowCode == 0x04):
return AttentionDataPoint(dataRowValueBytes)
elif (dataRowCode == 0x05):
return MeditationDataPoint(dataRowValueBytes)
elif (dataRowCode == 0x16):
return BlinkDataPoint(dataRowValueBytes)
elif (dataRowCode == 0x80):
return RawDataPoint(dataRowValueBytes)
elif (dataRowCode == 0x83):
return EEGPowersDataPoint(dataRowValueBytes)
else:
assert False