Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

P300test md #8

Open
wants to merge 29 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
14a0229
calibration peer, setup for bci peer
mdovgialo Feb 29, 2016
be9e0a3
cleaning up
mdovgialo Apr 19, 2016
54db28b
added Working tester for p300 classifiers
mdovgialo Apr 19, 2016
7f2d613
Working synthetic on real data
mdovgialo Apr 21, 2016
ec2be63
Thread locks
mdovgialo Apr 21, 2016
3f3fcdd
Auditory (untested) and haptic blining
mdovgialo May 5, 2016
96c215a
Sound bugfixing
mdovgialo May 9, 2016
e25072c
review fixes
mdovgialo May 11, 2016
2a5b4a3
Highlighting by images - done
mdovgialo May 11, 2016
6427150
adding scenarious
mdovgialo May 11, 2016
c9b20d8
ADD: half blink capability (global target probability)
mdovgialo May 12, 2016
5f9a3aa
option to send halfblink events with id -1, p300 classifier should no…
mdovgialo May 17, 2016
615b657
helper functions will be more usable
mdovgialo May 21, 2016
3798108
blinking engine pygame sound backend, fixed some imports
mdovgialo May 24, 2016
8dfea1e
reducing pygame latency - configurable buffors
mdovgialo May 24, 2016
7c22170
fixed first field sound not playing
mdovgialo May 24, 2016
96a19e4
initial ugm field for 2 class bci
mdovgialo May 30, 2016
25f1f1c
2 class visual p300 scenarious (dummy amplifier) for bci and calibrat…
mdovgialo May 30, 2016
a9b644c
adding author names
mdovgialo May 30, 2016
1dbc4f4
scenarios for live BCI
mdovgialo May 31, 2016
07074de
tweaked live scenarios with Einstein
mdovgialo May 31, 2016
e831b24
fixing calibration length
mdovgialo Jun 2, 2016
2c7a0f3
haptic scenarios
mdovgialo Jun 7, 2016
32e61b4
8 class visual p300
mdovgialo Jun 7, 2016
34a337a
Merge branch 'p300testMD' of https://github.com/BrainTech/openbci int…
mdovgialo Jun 7, 2016
5bfdc3f
text correction for haptic stim
mdovgialo Jun 7, 2016
cd82a82
little fixes, more logging in analysis
mdovgialo Jun 8, 2016
056521d
Fix for not stopping decision by max dec
Mar 15, 2017
8f548f3
P300 visual bci now uses budzik cap setup
mdovgialo Mar 15, 2017
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
5 changes: 5 additions & 0 deletions obci/configs/multiplexer.rules
Original file line number Diff line number Diff line change
Expand Up @@ -1024,6 +1024,11 @@ type {
whom: ALL
report_delivery_error: false
}
to {
peer: "LOGIC_FEEDBACK"
whom: ALL
report_delivery_error: false
}
}

type {
Expand Down
92 changes: 92 additions & 0 deletions obci/control/gui/presets/budzik.ini
Original file line number Diff line number Diff line change
Expand Up @@ -20,3 +20,95 @@ info=Run eyetracker (sample2d) with eyetracker signal saver(sample2d)
launch_file=scenarios/budzik/prototypes/etr_ws_signal_saver_sample2d.ini
public_params=
category=Prototypes

[P300 offline calibration]
info=run p300 calibration on recorded signal
launch_file=scenarios/budzik/prototypes/p300calibrate_offline.ini
public_params=
category=Prototypes P300

[P300 online test maze]
info=run p300 on calibrated classifier
launch_file=scenarios/budzik/prototypes/p300_labyrinth_dummy.ini
public_params=
category=Prototypes P300

[P300 synthetic online calibration]
info=run p300 calibration on synthetic signal online
launch_file=scenarios/budzik/prototypes/p300calibrate_synthetic_online.ini
public_params=
category=Prototypes P300

[P300 online synthetic test generated data]
info=run interactive synthetic test
launch_file=scenarios/budzik/prototypes/p300_synthetic_test_online.ini
public_params=
category=Prototypes P300

[P300 online synthetic test using real data]
info=run interactive synthetic test target and nontarget epochs from real EEG signal
launch_file=scenarios/budzik/prototypes/p300_online_synthetic_real_data_test.ini
public_params=
category=Prototypes P300

[P300 online labirynth all modalities]
info=run interactive labirynth P300 on dummy amp with 3 modalities
launch_file=scenarios/budzik/prototypes/modal_p300/p300_labyrinth_dummy.ini
public_params=
category=Prototypes P300


[P300 online labirynth visual audio text highlight by image]
info=run interactive labirynth P300 on dummy amp with 2 modalities
launch_file=scenarios/budzik/prototypes/visual_audio_image_highlight.ini
public_params=
category=Prototypes P300

[P300 online labirynth visual audio images no text]
info=run interactive labirynth P300 on dummy amp with 2 modalities
launch_file=scenarios/budzik/prototypes/visual_audio_no_text_image_highlight.ini
public_params=
category=Prototypes P300

[P300 visual 2 classes bci dummy]
info=run interactive p300 2 class bci with faces as highlight
launch_file=scenarios/budzik/prototypes/P300_visual_2_class_budzik.ini
public_params=
category=Prototypes P300 visual bci

[P300 visual 2 classes bci calibration dummy]
info=run 2 class bci calibration with faces as highlight
launch_file=scenarios/budzik/prototypes/P300_visual_2_class_budzik_calibration.ini
public_params=
category=Prototypes P300 visual bci

[P300 visual 2 classes bci]
info=run interactive p300 2 class bci with faces as highlight
launch_file=scenarios/budzik/prototypes/P300_visual_2_class_budzik_amp.ini
public_params=
category=Prototypes P300 visual bci

[P300 visual 8 classes bci]
info=run interactive p300 8 class bci with faces as highlight
launch_file=scenarios/budzik/prototypes/p300_visual_8_classes.ini
public_params=
category=Prototypes P300 visual bci


[P300 visual 2 classes bci calibration]
info=run 2 class bci calibration with faces as highlight
launch_file=scenarios/budzik/prototypes/P300_visual_2_class_budzik_calibration_amp.ini
public_params=
category=Prototypes P300 visual bci

[P300 haptic 2 classes bci]
info=run interactive p300 2 class bci with haptic stim
launch_file=scenarios/budzik/prototypes/P300_haptic_2_class_budzik_amp.ini
public_params=
category=Prototypes P300 haptic bci

[P300 haptic 2 classes bci calibration]
info=run 2 class bci calibration with haptic stim
launch_file=scenarios/budzik/prototypes/P300_haptic_2_class_budzik_calibration_amp.ini
public_params=
category=Prototypes P300 haptic bci
19 changes: 19 additions & 0 deletions obci/devices/haptics/haptics_stim_test_logic_peer.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,25 @@ def generate_test_messages(self):
self.logger.info('RUNNING! S2')
time.sleep(4)

msg = variables_pb2.Variable()
msg.key = 'S'
msg.value = '3:0.5'
self.conn.send_message(message=msg.SerializeToString(),
type=types.HAPTIC_CONTROL_MESSAGE,
flush=True)
self.logger.info('RUNNING! S3')
time.sleep(4)


msg = variables_pb2.Variable()
msg.key = 'S'
msg.value = '4:0.5'
self.conn.send_message(message=msg.SerializeToString(),
type=types.HAPTIC_CONTROL_MESSAGE,
flush=True)
self.logger.info('RUNNING! S4')
time.sleep(4)

msg = variables_pb2.Variable()
msg.key = 'S'
msg.value = '1,2:1.5,2.5'
Expand Down
2 changes: 1 addition & 1 deletion obci/gui/ugm/blinking/ugm_blinking_count_manager.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# -*- coding: utf-8 -*-
# Author:
# Mateusz Kruszyński <mateusz.kruszynski@gmail.com>

# Marian Dovgialo <marian.dowgialo@gmail.com>
from obci.utils import sequence_provider
class DummyProvider(object):
def get_value(self):
Expand Down
163 changes: 162 additions & 1 deletion obci/gui/ugm/blinking/ugm_blinking_ugm_manager.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
# Mateusz Kruszyński <mateusz.kruszynski@gmail.com>

from obci.gui.ugm import ugm_config_manager
import os.path
class _SingleUgmManager(object):
def __init__(self, configs):
mgr = ugm_config_manager.UgmConfigManager(configs.get_param('ugm_config'))
Expand Down Expand Up @@ -111,9 +112,169 @@ def get_unblink_ugm(self, area_id):



class _SingleTextImageOddballUgmManager(object):
'''Ugm config manager for blinks - text with synchronous nontarget
blinks and additional target oddball - image.

BCI design maximising efficiency based on studies:
Jin, Jing, et al. "A P300 Brain–Computer Interface Based on a
Modification of the Mismatch Negativity Paradigm."
International journal of neural systems 25.03 (2015): 1550011.

Kaufmann, Tobias, et al. "Face stimuli effectively
prevent brain–computer interface inefficiency in patients with
neurodegenerative disease."
Clinical Neurophysiology 124.5 (2013): 893-900.

'''
def __init__(self, configs):
mgr = ugm_config_manager.UgmConfigManager(configs.get_param('ugm_config'))
start_id = int(configs.get_param('blink_ugm_id_start'))
count = int(configs.get_param('blink_ugm_id_count'))
dec_count = int(configs.get_param('blink_id_count'))
active_field_ids = [int(field) for field in configs.get_param('active_field_ids').split(';')]
target_image_path = configs.get_param('target_image_path')
image_fields_id_offset = int(configs.get_param('image_fields_id_offset'))

assert(start_id >= 0)
assert(count >= 0)
assert(count == dec_count)

self.blink_ugm = []
self.unblink_ugm = []
self.half_blink_ugm = []
self.half_unblink_ugm = []
#create blinks and unblinks for every field
for dec in active_field_ids:#range(count):
new_blink_cfgs = []
new_unblink_cfgs = []
cfg_target = mgr.get_config_for(start_id+dec+image_fields_id_offset)
new_blink_cfgs.append({'id':cfg_target['id'],
'image_path':target_image_path
})
new_unblink_cfgs.append({'id':cfg_target['id'],
'image_path':''
})
#highlight every nontarget field:

for ndec in active_field_ids:
cfg = mgr.get_config_for(start_id+ndec)
half_blink = {'id':cfg['id'],
configs.get_param('blink_ugm_key'):configs.get_param('blink_ugm_value')
}
new_blink_cfgs.append(half_blink)
self.half_blink_ugm.append(half_blink)
half_unblink = {'id':cfg['id'],
configs.get_param('blink_ugm_key'):cfg[configs.get_param('blink_ugm_key')]
}
new_unblink_cfgs.append(half_unblink)
self.half_unblink_ugm.append(half_unblink)
self.blink_ugm.append(new_blink_cfgs)
self.unblink_ugm.append(new_unblink_cfgs)
#creating half blink


def get_blink_ugm(self, area_id):
if area_id is not None:
return self.blink_ugm[area_id]
else:
return self.half_blink_ugm

def get_unblink_ugm(self, area_id):
if area_id is not None:
return self.unblink_ugm[area_id]
else:
return self.half_unblink_ugm


class _SingleImageOddballUgmManager(_SingleTextImageOddballUgmManager):
'''Ugm config manager for blinks - images with synchronous nontarget
blinks and additional target oddball - image - another image.

BCI design maximising efficiency based on studies:
Jin, Jing, et al. "A P300 Brain–Computer Interface Based on a
Modification of the Mismatch Negativity Paradigm."
International journal of neural systems 25.03 (2015): 1550011.

Kaufmann, Tobias, et al. "Face stimuli effectively
prevent brain–computer interface inefficiency in patients with
neurodegenerative disease."
Clinical Neurophysiology 124.5 (2013): 893-900.

'''
def __init__(self, configs):
mgr = ugm_config_manager.UgmConfigManager(configs.get_param('ugm_config'))
start_id = int(configs.get_param('blink_ugm_id_start'))
count = int(configs.get_param('blink_ugm_id_count'))
dec_count = int(configs.get_param('blink_id_count'))
active_field_ids = [int(field) for field in configs.get_param('active_field_ids').split(';')]
images_folder = configs.get_param('images_path')
images_extension = configs.get_param('images_extension')

assert(start_id >= 0)
assert(count >= 0)
assert(count == dec_count)

self.blink_ugm = []
self.unblink_ugm = []
self.half_unblink_ugm = []
self.half_blink_ugm = []
#create blinks and unblinks for every field
for dec in active_field_ids:
new_blink_cfgs = []
new_unblink_cfgs = []

cfg_target = mgr.get_config_for(start_id+dec)
targ_image = os.path.join(images_folder,
'{}t.{}'.format(dec, images_extension))
idle_image = os.path.join(images_folder,
'{}i.{}'.format(dec, images_extension))
new_blink_cfgs.append({'id':cfg_target['id'],
'image_path':targ_image
})
new_unblink_cfgs.append({'id':cfg_target['id'],
'image_path':idle_image
})
#highlight every nontarget field:

for ndec in active_field_ids:
#change only nontarget, here this is important
if ndec!=dec:

high_image = os.path.join(images_folder,
'{}n.{}'.format(ndec, images_extension))
idle_image = os.path.join(images_folder,
'{}i.{}'.format(ndec, images_extension))
cfg = mgr.get_config_for(start_id+ndec)
new_blink_cfgs.append({'id':cfg['id'],
'image_path':high_image
})
new_unblink_cfgs.append({'id':cfg['id'],
'image_path':idle_image
})

self.blink_ugm.append(new_blink_cfgs)
self.unblink_ugm.append(new_unblink_cfgs)
#creating half blinks:
for ndec in active_field_ids:
high_image = os.path.join(images_folder,
'{}n.{}'.format(ndec, images_extension))
idle_image = os.path.join(images_folder,
'{}i.{}'.format(ndec, images_extension))
cfg = mgr.get_config_for(start_id+ndec)
self.half_blink_ugm.append({'id':cfg['id'],
'image_path':high_image
})
self.half_unblink_ugm.append({'id':cfg['id'],
'image_path':idle_image
})


MGRS = {
'single':_SingleUgmManager,
'classic':_ClassicUgmManager
'classic':_ClassicUgmManager,
'singletextimageoddball':_SingleTextImageOddballUgmManager,
'singleimageoddball':_SingleImageOddballUgmManager,
}

class UgmBlinkingUgmManager(object):
Expand Down
Loading