Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
93 changes: 93 additions & 0 deletions Examples/example_epoc_x_macos.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
# -*- coding: utf8 -*-

#
# CyKIT 2020.06.05
# ________________________
# example_epoc_x_macos.py
#
# Written by zer0-pole
#
"""
usage: python Examples/example_epoc_x_macos.py

tested on macOS 12.5
Python 3.9.5
pip install pycryptodome hidapi
"""

import os
import signal

import hid
from Crypto.Cipher import AES


class EEG(object):

def __init__(self):
self.hid = hid.device()
self.delimiter = ", "
self.cipher = None

devicesUsed = 0

for device in hid.enumerate():
if device['manufacturer_string'] == 'Emotiv':
devicesUsed += 1
try :
self.hid.open(device['vendor_id'], device['product_id'], device['serial_number'])
except Exception as e:
if str(e) != "already open":
self.hid.close()
os._exit(0)
self.serial_number = device['serial_number']

if devicesUsed == 0:
os._exit(0)

serial = self.serial_number

print("serial: ", serial)

sn = bytearray()
for i in range(0,len(serial)):
sn += bytearray([ord(serial[i])])

k = [sn[-1],sn[-2],sn[-4],sn[-4],sn[-2],sn[-1],sn[-2],sn[-4],sn[-1],sn[-4],sn[-3],sn[-2],sn[-1],sn[-2],sn[-2],sn[-3]]

self.cipher = AES.new(bytearray(k), AES.MODE_ECB)

def convertEPOC_PLUS(self, value_1, value_2):
edk_value = "%.8f" % (((int(value_1) * .128205128205129) + 4201.02564096001) + ((int(value_2) -128) * 32.82051289))
return edk_value

def get_data(self, data):

data = [el ^ 0x55 for el in data]
data = self.cipher.decrypt(bytearray(data))

try:
packet_data = ""
for i in range(2,16,2):
packet_data = packet_data + str(self.convertEPOC_PLUS(str(data[i]), str(data[i+1]))) + self.delimiter

for i in range(18,len(data),2):
packet_data = packet_data + str(self.convertEPOC_PLUS(str(data[i]), str(data[i+1]))) + self.delimiter

packet_data = packet_data[:-len(self.delimiter)]
return str(packet_data)

except Exception as exception2:
print(str(exception2))

cyHeadset = EEG()


def handler(signum, frame):
exit(0)

signal.signal(signal.SIGINT, handler)

while 1:
data = cyHeadset.hid.read(32)
print(cyHeadset.get_data(data))
99 changes: 99 additions & 0 deletions Examples/example_epoc_x_win.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
# -*- coding: utf8 -*-
#
# CyKIT 2020.06.05
# ________________________
# example_epoc_x_win.py
#
# Written by zer0-pole
#
"""

usage: python.exe .\example_epoc_x_win.py

( May need to adjust the key below, based on whether
device is in 14-bit mode or 16-bit mode. )

"""

import os
import sys
print(str(sys.path))
sys.path.insert(0, '..//py3//cyUSB//')
sys.path.insert(0, '..//py3')

import cyPyWinUSB as hid
import queue
from cyCrypto.Cipher import AES


tasks = queue.Queue()

class EEG(object):

def __init__(self):
self.hid = None
self.delimiter = ", "
self.cipher = None

devicesUsed = 0

for device in hid.find_all_hid_devices():
if device.product_name == 'EEG Signals':
devicesUsed += 1
self.hid = device
self.hid.open()
self.serial_number = device.serial_number
device.set_raw_data_handler(self.dataHandler)
if devicesUsed == 0:
os._exit(0)

serial = self.serial_number
print("serial: ", serial)

sn = bytearray()
for i in range(0,len(serial)):
sn += bytearray([ord(serial[i])])

k = [sn[-1],sn[-2],sn[-4],sn[-4],sn[-2],sn[-1],sn[-2],sn[-4],sn[-1],sn[-4],sn[-3],sn[-2],sn[-1],sn[-2],sn[-2],sn[-3]]

self.cipher = AES.new(bytearray(k), AES.MODE_ECB)

def dataHandler(self, data):

data2 = [0] * (len(data) - 1)
for X in range(1, len(data)):
data2[X - 1] = (data[X] ^ 0x55) # XOR each byte by 0x55 (85)


ans = self.cipher.decrypt(bytearray(data2))

tasks.put(ans)

def convertEPOC_PLUS(self, value_1, value_2):
edk_value = "%.8f" % (((int(value_1) * .128205128205129) + 4201.02564096001) + ((int(value_2) -128) * 32.82051289))
return edk_value

def get_data(self):

data = tasks.get()

try:
packet_data = ""
for i in range(2,16,2):
packet_data = packet_data + str(self.convertEPOC_PLUS(str(data[i]), str(data[i+1]))) + self.delimiter

for i in range(18,len(data),2):
packet_data = packet_data + str(self.convertEPOC_PLUS(str(data[i]), str(data[i+1]))) + self.delimiter

packet_data = packet_data[:-len(self.delimiter)]
return str(packet_data)

except Exception as exception2:
print(str(exception2))

cyHeadset = EEG()

while 1:
while tasks.empty():
pass
print(cyHeadset.get_data())