Python backend for bci-essentials
Project description
bci-essentials-python
This repository contains python modules and scripts for the processing of EEG-based BCI. These modules are specifically designed to be equivalent whether run offline or online.
Related packages
The front end for this package can be found in bci-essentials-unity
Getting Started
- Wiki – More detailed installation instructions and tutorials.
- API documentation
Installation
BCI Essentials requires Python 3.9 or later. To install for Windows, MacOS or Linux:
pip install bci-essentials
On some systems, it may be necessary to install liblsl. Alternatively, use the Conda environment to set up dependencies that are not provided by pip:
conda env create -f ./environment.yml
conda activate bci
Offline processing
Offline processing can be done by running the corresponding offline test script (ie. mi_offline_test.py, p300_offline_test.py, etc.) Change the filename in the script to point to the data you want to process.
python examples/mi_offline_test.py
Online processing
Online processing requires an EEG stream and a marker stream. These can both be simulated using eeg_lsl_sim.py and marker_lsl_sim.py. Real EEG streams come from a headset connected over LSL. Real marker streams come from the application in the Unity frontend. Once these streams are running, simply begin the backend processing script ( ie. mi_unity_backend.py, p300_unity_bakend.py, etc.) It is recommended to save the EEG, marker, and response (created by the backend processing script) streams using Lab Recorder for later offline processing.
python examples/mi_unity_backend.py
Directory
bci_essentials
The main packge containing modules for BCI processing.
- bci_controller.py - module for reading online/offline data, windowing, processing, and classifying EEG signals
- classification.py - module containing relevant classifiers for bci_controller, classifiers can be extended to meet individual needs
- signal_processing.py- module containing functions for the processing of bci_controller
- visuals.py - module for visualizing EEG data
examples
Example scripts and data.
- data - directory containing example data for P300, MI, and SSVEP
- eeg_lsl_sim.py - creates a stream of mock EEG data from an xdf file
- marker_lsl_sim.py - creates a stream of mock marker data from an xdf file
- mi_offline_test.py - runs offline MI processing on previously collected EEG and marker streams
- mi_unity_backend.py - runs online MI processing on live EEG and marker streams
- p300_offline_test.py - runs offline P300 processing on previously collected EEG and marker streams
- p300_unity_backend.py - runs online P300 processing on live EEG and marker streams
- ssvep_offline_test.py - runs offline SSVEP processing on previously collected EEG and marker streams
- ssvep_unity_backend_tf.py - runs online SSVEP processing on live EEG and marker streams, does not require training
- ssvep_unity_backend.py - runs online SSVEP processing on live EEG and marker streams
- switch_offline_test.py - runs offline switch state processing on previously collected EEG and marker streams
- switch_unity_backend.py - runs online switch state processing on live EEG and marker streams
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file bci_essentials-0.2.1.tar.gz
.
File metadata
- Download URL: bci_essentials-0.2.1.tar.gz
- Upload date:
- Size: 53.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7ec68f15de66112b423f3780884bd2990078a840059d06f04f65a97f63c8a815 |
|
MD5 | a2478aa2707006f781fdbceb6973632b |
|
BLAKE2b-256 | fb93958de2447aeb044a655c4303c3fca219578f1a15a52d05a48e6b409c943d |
File details
Details for the file bci_essentials-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: bci_essentials-0.2.1-py3-none-any.whl
- Upload date:
- Size: 77.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b188178c7b948028cbe1da28797a54920ffd13e9af669ef4b8b02f41de510876 |
|
MD5 | acc604064275843c86a6cc3881eef74b |
|
BLAKE2b-256 | b7ba3c58bf573fd67bf9a2ca11d31ce5db16208ee67f6b7a50e231859b59e66c |