Skip to main content

BrainStreamingLayer real-time framework for online neuroscience research through LSL-compatible devices.

Project description

Brain Streaming Layer

BrainStreamingLayer provides a real-time brain signal streaming framework. BSL is a wrapper around the python interface to the Lab Streaming Layer (LSL). BSL goal is to simplify the design of a study using the Lab Streaming Layer which provides sub-millisecond time synchronization accuracy.

Any signal acquisition system supported by native LSL or OpenVibe is also supported by BSL. Since the data communication is based on TCP, signals can be transmitted wirelessly. For more information about LSL, please visit the LSL github.

BSL is based on NeuroDecode. The original version developped by Kyuhwa Lee was recognised at Microsoft Brain Signal Decoding competition with the First Prize Award (2016) after achieving high decoding accuracy. BSL is based on the refactor version by Arnaud Desvachez for the Fondation Campus Biotech Geneva (FCBG). The low-level functionnalities have been reworked and improved, while the decoding functionnalities have been dropped.

Installation

BSL supports python >= 3.6 and requires:

  • numpy
  • scipy
  • pylsl
  • mne
  • pyqt5
  • pyqtgraph

Optional dependencies for trigger via an Arduino to LPT converter:

  • pyserial

Optional dependencies for StreamViewer alternative backends:

  • vispy

BSL can be installed in normal mode with python setup.py install or in developement mode with python setup.py develop. Optional dependencies can be installed using the keywords:

  • trigger_arduino2lpt
  • vispy_backend
  • doc
  • test

Documentation

Documentation website.

BSL is centered around 4 main modules: stream_receiver, stream_recorder, stream_player and stream_viewer.

StreamReceiver

The stream receiver connects to one or more LSL streams and acquires data from those. Supported streams are:

  • EEG
  • Markers

Example:

from bsl import StreamReceiver

# Connects to all available streams
sr = StreamReceiver(bufsize=1, winsize=1, stream_name=None)
# Update each stream buffer with new data
sr.acquire()
# Retrieve buffer/window for the stream named 'StreamPlayer'
data, timestamps = sr.get_window(stream_name='StreamPlayer')

The data and its timestamps are returned as numpy array:

  • data.shape = (samples, channels)
  • timestamps.shape = (samples, )

The data can be returned as an MNE raw instance if return_raw is set to True.

StreamRecorder

The stream recorder connects to one or more LSL streams and periodically acquires data from those until stopped, and then saves the acquired data to disk in pickle .pcl and in FIF .fif format.

Example:

import time
from bsl import StreamRecorder

# Connects to all available streams
recorder = StreamRecorder(record_dir=None, fname=None, stream_name=None)
recorder.start(verbose=True)
time.sleep(10)
recorder.stop()

When the argument record_dir is set to None, the current folder obtained with pathlib.Path.cwd() is used. When the argument fname is set to None, the created files' stem use the start datetime.

CLI: The stream recorder can be called by command-line in a terminal by using either bsl stream_recorder or bsl_stream_recorder followed by the optional arguments -d, -f, -s respectively for record_dir, fname, and stream_name.

bsl_stream_recorder -d "D:/Data"
bsl_stream_recorder -d "D:/Data" -f test
bsl_stream_recorder -d "D:/Data" -f test -s openvibeSignals

StreamPlayer

The stream player loads a previously recorded .fif file and creates a LSL server streaming data from this file. The stream player can be used to test code with a fake LSL data stream.

Example:

import time
from bsl import StreamPlayer

sp = StreamPlayer(stream_name='StreamPlayer', fif_file=r'path to .fif')
sp.start()
time.sleep(10)
sp.stop()

CLI: The stream player can be called by command-line in a terminal by using either bsl stream_player or bsl_stream_player followed by positional arguments stream_name and fif_file and the optional arguments -c and -t respectively for chunk_size and trigger_file.

bsl_stream_player StreamPlayer "D:/Data/data-raw.fif"
bsl_stream_player StreamPlayer "D:/Data/data-raw.fif" -c 16
bsl_stream_player StreamPlayer "D:/Data/data-raw.fif" -c 16 -t "D:/triggerdef.ini"

StreamViewer

The stream viewer creates a 2-window GUI composed of a control GUI and a plotter GUI to display the data acquired from an LSL server in real-time.

CLI: The stream viewer can be called by command-line in a terminal by using either bsl stream_viewer or bsl_stream_viewer followed by the optional argument -s and -b respectively for the stream_name and backend. If no stream name is provided, a prompt will ask the user to select the desired non-marker stream to display. The supported backends are pyqt5 (default) and vispy (incomplete).

bsl_stream_viewer
bsl_stream_viewer -s StreamPlayer
bsl_stream_viewer -s StreamPlayer -b vispy

Triggers

Triggers includes functions to mark time event by sending a trigger which will be saved on the TRIGGER channel of the on-going recording. Triggers can be achieved either through hardware or through software.

Currently, the supported hardware triggers use an LPT port.

Example:

import time
from bsl import StreamRecorder
from bsl.triggers.software import TriggerSoftware
from bsl.triggers.lpt import TriggerArduino2LPT

# Software trigger
recorder = StreamRecorder()
recorder.start()
trigger = TriggerSoftware(recorder)
for k in range(1, 5):
    trigger.signal(k)
    time.sleep(1)
trigger.close()
recorder.stop()

# Hardware trigger through Arduino LPT converter
recorder = StreamRecorder()
recorder.start()
trigger = TriggerArduino2LPT()
for k in range(1, 5):
    trigger.signal(k)
    time.sleep(1)
trigger.close()
recorder.stop()

Note that closing the trigger before stopping the recording may not be required for all kind of triggers.

Copyright and license

The codes are released under GNU Lesser General Public License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bsl-0.2.1.tar.gz (241.0 kB view details)

Uploaded Source

Built Distribution

bsl-0.2.1-py3-none-any.whl (259.2 kB view details)

Uploaded Python 3

File details

Details for the file bsl-0.2.1.tar.gz.

File metadata

  • Download URL: bsl-0.2.1.tar.gz
  • Upload date:
  • Size: 241.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.10

File hashes

Hashes for bsl-0.2.1.tar.gz
Algorithm Hash digest
SHA256 0af6e9286d5180e1bcff46bba4ae34b5b5a65385e0e52a7fb1bf9fbab1c5b02c
MD5 4f6d4ab2b520f204285abb46c289a80c
BLAKE2b-256 b1c70456991bb2ca9d87e871d1589c1570ca2f6b22f25afd66753230cd61f273

See more details on using hashes here.

File details

Details for the file bsl-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: bsl-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 259.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.10

File hashes

Hashes for bsl-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7782f8e085e23586612237b9a599d6fe1352287555845a457030bafa02eb51a7
MD5 7b794de42621e5ebcba0ef6e29a460b1
BLAKE2b-256 f4eb87dc445b7ec6db6c18f99e14a69483d68cc977b6a3d0070ad178dd2e1326

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page