Python Noise-Tagging Brain-Computer Interface (PyntBCI)
Project description
PyntBCI
The Python Noise-Tagging Brain-Computer Interfacing (PyntBCI) library is a specialized Python toolbox developed for the noise-tagging brain-computer interfacing (BCI) project at the Donders Institute for Brain, Cognition, and Behaviour at Radboud University in Nijmegen, the Netherlands. PyntBCI offers a suite of signal processing tools and machine learning algorithms tailored for BCIs using evoked responses, such as those recorded by electroencephalography (EEG). It is particularly focused on supporting code-modulated responses like the code-modulated visual evoked potential (c-VEP).
For detailed documentation as wel as tutorials and examples, see:
For a constructive review of the c-VEP BCI field, see:
- Martínez-Cagigal, V., Thielen, J., Santamaría-Vázquez, E., Pérez-Velasco, S., Desain, P., & Hornero, R. (2021). Brain–computer interfaces based on code-modulated visual evoked potentials (c-VEP): a literature review. Journal of Neural Engineering. DOI: 10.1088/1741-2552/ac38cf
For an extensive literature overview, also see:
For an example of an online BCI with PyntBCI, see our Dareplane implementation:
- https://github.com/thijor/dp-cvep
- https://github.com/thijor/dp-cvep-speller
- https://github.com/thijor/dp-cvep-decoder
Installation
To install PyntBCI, use:
pip install pyntbci
Getting started
Various tutorials and example analysis pipelines are provided in the tutorials/ and examples/ folder, which operate on limited preprocessed data as provided with PyntBCI. Furthermore, please find various pipelines for several open-access datasets below in the pipelines/ folder.
Referencing
When using PyntBCI, please reference at least one of the following:
- Thielen, J., van den Broek, P., Farquhar, J., & Desain, P. (2015). Broad-Band visually evoked potentials: re(con)volution in brain-computer interfacing. PLOS ONE, 10(7), e0133797. DOI: 10.1371/journal.pone.0133797
- Thielen, J., Marsman, P., Farquhar, J., & Desain, P. (2021). From full calibration to zero training for a code-modulated visual evoked potentials for brain–computer interface. Journal of Neural Engineering, 18(5), 056007. DOI: 10.1088/1741-2552/abecef
Contact
- Jordy Thielen (jordy.thielen@donders.ru.nl)
Licensing
PyntBCI is licensed by the BSD 3-Clause License:
Copyright (c) 2021, Jordy Thielen All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Changelog
Version 1.8.3 (21-05-2025)
Added
- Added
approachinBayesStoppingofstopping
Changed
- Refactor
rCCAofclassifiers
Fixed
- Fixed
astypein all modules - Fixed
decoding_matrixinrCCAofclassifiersonly called if required - Fixed
encoding_strideinrCCAofclassifiersto allow list input likeencoding_length - Fixed docs
Version 1.8.2 (16-04-2025)
Added
Changed
- Changed
strideinencoding_matrixofutilitiesto allow list input likelength
Fixed
- Fixed
cca_channelsineCCAofclassifiers - Fixed
lags=[...]andensemble=Truecombination ineCCAofclassifiers
Version 1.8.1 (11-03-2025)
Added
- Added
labelstostimplotinplotting
Changed
- Changed
pinvinutilitiesto work with non-square matrices
Fixed
- Fixed array
encoding_lengthofrCCAinclassifiers - Fixed
smooth_widthofCriterionStoppinginstopping - Fixed
stop_time_ofCriterionStoppinginstopping - Fixed
gamma_xandgamma_yregularization ofCCAintransformers
Version 1.8.0 (08-11-2024)
Added
- Added
min_timeto stopping methods instopping - Added
max_timetoCriterionStoppinginstopping
Changed
Fixed
- Fixed fit exception in
DistributionStoppinginstopping
Version 1.7.0 (22-10-2024)
Added
- Added
tmintoencoding_matrixinutilities - Added
tmintorCCAinclassifiers
Changed
Fixed
Version 1.6.1 (10-10-2024)
Added
- Added
find_neighboursandfind_worst_neighbourtoutilities - Added
optimize_subset_clusteringtostimulus - Added
optimize_layout_incrementaltostimulus - Added
stimplottoplotting
Changed
- Changed order of tutorials and examples
Fixed
- Fixed
max_timein allstoppingclasses to deal with "partial" segments
Version 1.5.0 (30-09-2024)
Added
- Added
ValueStoppingtostopping - Added parameter
distributiontoDistributionStoppinginstopping
Changed
- Changed
envelope_rmstormsinenvelope - Changed
envelope_gammatonetogammatoneinenvelope - Changed
BetaStoppinginstoppingtoDistributionStopping
Fixed
- Fixed default
CCAintransformerstoinv, notpinv - Fixed
seedformake_m_sequenceandmake_gold_codesinstimulusto not be full zeros
Version 1.4.1 (19-07-2024)
Added
Changed
Fixed
- Fixed default
CCAintransformerstoinv, notpinv
Version 1.4.0 (15-07-2024)
Added
- Added
pinvtoutilities - Added
alpha_xtoCCAintranformers - Added
alpha_ytoCCAintranformers - Added
alpha_xtoeCCAinclassifiers - Added
alpha_ttoeCCAinclassifiers - Added
alpha_xtorCCAinclassifiers - Added
alpha_mtorCCAinclassifiers - Added
squeeze_componentstorCCA,eCCA,eTRCAin `classifiers'
Changed
- Changed
numpytyping ofnp.ndarraytoNDArray - Changed
cca_andtrca_attributes to belistalways ineCCA,rCCAandeTRCA - Changed
scipy.linalg.invtopyntbci.utilities.pinvinCCAoftransformers - Changed
decision_functionandpredictofclassifiersto return without additional dimension for components ifn_components=1andsqueeze_components=True, both of which are defaults
Fixed
Version 1.3.3 (01-07-2024)
Added
Changed
Fixed
- Fixed components bug in
decision_functionofeCCAinclassifiers
Version 1.3.2 (23-06-2024)
Added
- Added
cov_estimator_ttoeCCAinclassifiers
Changed
- Changed separate covariance estimators for data and templates in
eCCAofclassifiers
Fixed
Version 1.3.1 (23-06-2024)
Added
Changed
Fixed
- Fixed zero division
eventplotinplotting - Fixed event order duration event
event_matrixinutilities
Version 1.3.0 (18-06-2024)
Added
- Removed
gatingofrCCAinclassifiers - Removed
_scoremethods inclassifiers - Added
n_componentsineCCAinclassifiers - Added
n_componentsineTRCAinclassifiers
Changed
- Changed "bes" to "bds" in
BayesStoppinginstoppingin line with publication - Changed
lxandlytogamma_xandgamma_yiofeCCAinclassifiers - Changed
gatingtogates - Changed
TRCAintransformersto deal with one-class data only - Changed
_get_Ttoget_Tin allclassifiers
Fixed
Version 1.2.0 (18-04-2024)
Added
Changed
- Changed
lxofrCCAinclassifierstogamma_x, which ranges between 0-1, such that the parameter represents shrinkage regularization - Changed
lyofrCCAinclassifierstogamma_m, which ranges between 0-1, such that the parameter represents shrinkage regularization - Changed
lxofCCAintransformerstogamma_x, which ranges between 0-1, such that the parameter represents shrinkage regularization - Changed
lyofCCAintransformerstogamma_y, which ranges between 0-1, such that the parameter represents shrinkage regularization
Fixed
Version 1.1.0 (17-04-2024)
Added
- Added
envelopemodule containingenvelope_gammatoneandenvelope_rmsfunctions - Added
CriterionStoppingtostoppingfor some static stopping methods
Changed
- Changed default value of
encoding_lengthinrCCAofclassifiersof 0.3 to None, which is equivalent to 1 / fs
Fixed
- Fixed variable
fsof type np.ndarray instead of int in examples, tutorials, and pipelines - Fixed double call to
decoding_matrixinfitofrCCAinclassifiers
Version 1.0.1 (26-03-2024)
Added
- Added
set_stimulus_amplitudesforrCCAinclassifiers
Changed
Fixed
- Fixed dependency between
stimulusandamplitudesinrCCAofclassifiers
Version 1.0.0 (22-03-2024)
Added
- Added variable
decoding_lengthofrCCAinclassifiercontrolling the length of a learned spectral filter - Added variable
decoding_strideofrCCAinclassifiercontrolling the stride of a learned spectral filter - Added function
decoding_matrixinutilitiesto phase-shit the EEG data maintaining channel-prime ordering - Added variable
encoding_strideofrCCAinclassifiercontrolling the stride of a learned temporal response - Added module
gatingwith gating functions, for instance for multi-component or filterbank analysis - Added variable
gatingofrCCAinclassifierto deal with multiple CCA components - Added variable
gatingofEnsembleinclassifier, for example to deal with a filterbank
Changed
- Changed variable
codesofrCCAinclassifierstostimulus - Changed variable
transient_sizeofrCCAinclassifierstoencoding_length - Changed class
FilterBankinclassifierstoEnsemble - Changed function
structure_matrixinutilitiestoencoding_matrix
Fixed
- Fixed several documentation issues
Version 0.2.5 (29-02-2024)
Added
- Added function
eventplotinplottingto visualize an event matrix - Added variable
runningofcovarianceinutilitiesto do incremental running covariance updates - Added variable
runningofCCAintransformersto use a running covariance for CCA - Added variable
cov_estimator_xandcov_estimator_mofrCCAinclassifiersto change the covariance estimator - Added event definitions "on", "off" and "onoff" for
event_matrixinutilities
Changed
- Changed the CCA optimization to contain separate computations for Cxx, Cyy and Cxy
- Changed the CCA to allow separate BaseEstimators for Cxx and Cyy
Fixed
- Fixed zero-division in
itrinutilities
Version 0.2.4
Added
- Added CCA cumulative/incremental average and covariance
- Added
amplitudes(e.g. envelopes) instructure_matrixofutilities - Added
max_timeto classes instoppingto allow a maximum stopping time for stopping methods - Added brainamp64.loc to capfiles
- Added plt.show() in all examples
Changed
Fixed
Version 0.2.3
Added
Changed
- Changed example pipelines to include more examples and explanation
- Changed tutorial pipelines to include more examples and explanation
Fixed
- Fixed several documentation issues
Version 0.2.2
Added
- Added class
TRCAtotransformers - Added class
eTRCAtoclassifiers - Added parameter
ensembleto classes inclassifiersto allow a separate spatial filter per class
Changed
- Changed package name from PyNT to PyntBCI to avoid clash with existing pynt library
- Changed filter order in
filterbankofutilitiesto be optimized given input parameters
Fixed
- Fixed issue in
rCCAofclassifierscausing novel events in structure matrix when "cutting cycles" - Fixed
correlationto not contain mutable input variables
Version 0.2.1
Added
- Added
tests - Added tutorials
Changed
- Changed
rCCAto work with non-binary events instead of binary only
Fixed
Version 0.2.0
Added
- Added dynamic stopping: classes
MarginStopping,BetaStopping, andBayesStoppingin modulestopping - Added value inner for variable
score_metricin 'classifiers'
Changed
- Changed all data shapes from (channels, samples, trials) to (trials, channels, samples)
- Changed all codes shapes from (samples, classes) to (classes, samples)
- Changed all decision functions to similarity, not distance (e.g., Euclidean), to always maximize
Fixed
- Fixed zero-mean templates in
eCCAandrCCAofclassifiers
Version 0.1.0
Added
- Added
Filterbanktoclassifiers
Changed
- Changed classifiers all have
predictanddecision_functionmethods inclassifiers
Fixed
Version 0.0.2
Added
Changed
- Changed CCA method from sklearn to custom covariance method
Fixed
Version 0.0.1
Added
- Added
eCCAtemplate metrics: average, median, OCSVM - Added
eCCAspatial filter options: all channels or subset
Changed
Fixed
Version 0.0.0
Added
- Added
CCAintransformers - Added
rCCAinclassifiers - Added
eCCAinclassifier
Changed
Fixed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyntbci-1.8.3.tar.gz.
File metadata
- Download URL: pyntbci-1.8.3.tar.gz
- Upload date:
- Size: 45.2 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b217e6dfaf2dbcbf3f438f15832fa35b03f0209ae1d84159b2c7148a8680fb22
|
|
| MD5 |
2441453128620250a9b34445876afd2b
|
|
| BLAKE2b-256 |
cb2a4dc459fef4f44d20431e3d97129da64241a0bd02bcb486d7e9be9d822da8
|
File details
Details for the file pyntbci-1.8.3-py3-none-any.whl.
File metadata
- Download URL: pyntbci-1.8.3-py3-none-any.whl
- Upload date:
- Size: 45.2 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0ced4da61bb46e5aec8b18623d40c0244eebd791554afb21fa5187d7bc3a7889
|
|
| MD5 |
584670128779cb6cf00bf61edc18b744
|
|
| BLAKE2b-256 |
16d0a8b7259cb6b05372e04e2e7016941f3f2e2e09483d648ef9de330b1adace
|