TorchEEG is a library built on PyTorch for EEG signal analysis. TorchEEG aims to provide a plug-and-play EEG analysis tool, so that researchers can quickly reproduce EEG analysis work and start new EEG analysis research without paying attention to technical details unrelated to the research focus.
Project description
Documentation | TorchEEG Examples | Paper
TorchEEG is a library built on PyTorch for EEG signal analysis. TorchEEG aims to provide a plug-and-play EEG analysis tool, so that researchers can quickly reproduce EEG analysis work and start new EEG analysis research without paying attention to technical details unrelated to the research focus.
TorchEEG specifies a unified data input-output format (IO) and implement commonly used EEG databases, allowing users to quickly access benchmark datasets and define new custom datasets. The datasets that have been defined so far include emotion recognition and so on. According to papers published in the field of EEG analysis, TorchEEG provides data preprocessing methods commonly used for EEG signals, and provides plug-and-play API for both offline and online pre-proocessing. Offline processing allow users to process once and use any times, speeding up the training process. Online processing allows users to save time when creating new data processing methods. TorchEEG also provides deep learning models following published papers for EEG analysis, including convolutional neural networks, graph convolutional neural networks, and Transformers.
Installation
TorchEEG depends on PyTorch, please complete the installation of PyTorch according to the system, CUDA version and other information:
# Conda
# please refer to https://pytorch.org/get-started/locally/
# e.g. CPU version
conda install pytorch==1.11.0 torchvision torchaudio cpuonly -c pytorch
# e.g. GPU version
conda install pytorch==1.11.0 torchvision torchaudio cudatoolkit=11.3 -c pytorch
# Pip
# please refer to https://pytorch.org/get-started/previous-versions/
# e.g. CPU version
pip install torch==1.11.0+cpu torchvision==0.12.0+cpu torchaudio==0.11.0 --extra-index-url https://download.pytorch.org/whl/cpu
# e.g. GPU version
pip install torch==1.11.0+cu113 torchvision==0.12.0+cu113 torchaudio==0.11.0 --extra-index-url https://download.pytorch.org/whl/cu113
Anaconda
TorchEEG supports installing with conda! You can simply install TorchEEG using Anaconda, just run the following command:
conda install -c tczhangzhi -c conda-forge torcheeg
Pip
TorchEEG allows pip-based installation, please use the following command:
pip install torcheeg
Nightly
In case you want to experiment with the latest TorchEEG features which are not fully released yet, please run the following command to install from the main branch on github:
pip install git+https://github.com/tczhangzhi/torcheeg.git
Plugin
TorchEEG provides plugins related to graph algorithms for converting EEG in datasets into graph structures and analyzing them using graph neural networks. This part of the implementation relies on PyG.
If you do not use graph-related algorithms, you can skip this part of the installation.
# Conda
# please refer to https://pytorch-geometric.readthedocs.io/en/latest/notes/installation.html
conda install pyg -c pyg
# Pip
# please refer to https://pytorch-geometric.readthedocs.io/en/latest/notes/installation.html
# e.g. CPU version
pip install torch-scatter torch-sparse torch-cluster torch-spline-conv torch-geometric -f https://data.pyg.org/whl/torch-1.11.0+cpu.html
# e.g. GPU version
pip install torch-scatter torch-sparse torch-cluster torch-spline-conv torch-geometric -f https://data.pyg.org/whl/torch-1.11.0+cu113.html
More About TorchEEG
At a granular level, PyTorch is a library that consists of the following components:
Component |
Description |
---|---|
A set of unified input and output API is used to store the processing results of various EEG databases for more efficient and convenient use. |
|
The packaged benchmark dataset implementation provides a multi-process preprocessing interface. |
|
Extensive EEG preprocessing methods help users extract features, construct EEG signal representations, and connect to commonly used deep learning libraries. |
|
Extensive dataset partitioning methods for users to experiment with different settings. |
|
Extensive baseline method reproduction. |
Implemented Modules
We list currently supported datasets, transforms, data splitting, and deep learning models by category.
Datasets: All datasets rely on a set of efficient IO APIs, torcheeg.io, to store data preprocessing results on disk and read them quickly during training. Data preprocessing and storage support multiprocessing (speed up!).
AMIGOS dataset from Miranda-Correa et al.: AMIGOS: A dataset for affect, personality and mood research on individuals and groups.
DREAMER dataset from Katsigiannis et al.: DREAMER: A database for emotion recognition through EEG and ECG signals from wireless low-cost off-the-shelf devices.
SEED dataset from Zheng et al.: Investigating critical frequency bands and channels for EEG-based emotion recognition with deep neural networks.
DEAP dataset from Koelstra et al.: DEAP: A database for emotion analysis; using physiological signals.
MAHNOB dataset from Soleymani et al.: A multimodal database for affect recognition and implicit tagging.
Transforms: TorchEEG provides extensive data transformation tools to help users build EEG data representations suitable for a variety of task formulation and a variety of model structures.
Feature Engineering: BandDifferentialEntropy, BandPowerSpectralDensity, BandMeanAbsoluteDeviation, BandKurtosis, BandSkewness, Concatenate
General Operation: PickElectrode, MeanStdNormalize, MinMaxNormalize
For CNN: To2d, ToGrid, ToInterpolatedGrid
For GNN: ToG
For Augmentation: Resize, RandomNoise, RandomMask
For Label Construction: Select, Binary, BinariesToCategory
Data Splitting: In current research in the field of EEG analysis, there are various settings based on different considerations for data partitioning. Please choose a reasonable data division method according to the research focus:
Subject Dependent: KFoldPerSubjectGroupbyTrial, train_test_split_per_subject_groupby_trial
Subject Independent: LeaveOneSubjectOut
Conventional: KFold, train_test_split, KFoldGroupbyTrial, train_test_split_groupby_trial
Models: Coming soon after pushing to align with the official implementation or description. If the current version of CNNs, GNNs and Transformers is to be used, please refer to the implementation in torcheeg.models.
Quickstart
In this quick tour, we highlight the ease of starting an EEG analysis research with only a few lines.
The torcheeg.datasets module contains dataset classes for many real-world EEG datasets. In this tutorial, we use the DEAP dataset. We first go to the official website to apply for data download permission according to the introduction of DEAP dataset, and download the dataset. Next, we need to specify the download location of the dataset in the root_path parameter. For the DEAP dataset, we specify the path to the data_preprocessed_python folder, e.g. ./tmp_in/data_preprocessed_python.
from torcheeg.datasets import DEAPDataset
from torcheeg import transforms
from torcheeg.datasets.constants import \
DEAP_CHANNEL_LOCATION_DICT
dataset = DEAPDataset(
io_path=f'./tmp_out/examples_pipeline/deap',
root_path='./tmp_in/data_preprocessed_python',
offline_transform=transforms.Compose([
transforms.BandDifferentialEntropy(apply_to_baseline=True),
transforms.ToGrid(DEAP_CHANNEL_LOCATION_DICT, apply_to_baseline=True)
]),
online_transform=transforms.Compose(
[transforms.BaselineRemoval(),
transforms.ToTensor()]),
label_transform=transforms.Compose([
transforms.Select('valence'),
transforms.Binary(5.0),
]),
num_worker=8)
The DEAPDataset API further contains three parameters: online_transform, offline_transform, and label_transform, which are used to modify samples and labels, respectively.
Here, offline_transform will only be called once when the dataset is initialized to preprocess all samples in the dataset, and the processed dataset will be stored in io_path to avoid time-consuming repeated transformations in subsequent use. If offline preprocessing is a computationally intensive operation, we also recommend setting multi-CPU parallelism for offline_transform, e.g., set num_worker to 4.
online_transform is used to transform samples on the fly. Please use online_transform if you don’t want to wait for the preprocessing of the entire dataset (suitable for scenarios where new transform algorithms are designed) or expect data transformation with randomness each time a sample is indexed.
Next, we need to divide the dataset into a training set and a test set. In the field of EEG analysis, commonly used data partitioning methods include k-fold cross-validation and leave-one-out cross-validation. In this tutorial, we use k-fold cross-validation on the entire dataset (KFold) as an example of dataset splitting.
from torcheeg.model_selection import KFoldGroupbyTrial
k_fold = KFoldGroupbyTrial(n_splits=10,
split_path='./tmp_out/examples_pipeline/split',
shuffle=True,
random_state=42)
We loop through each cross-validation set, and for each one, we initialize the CCNN model and define its hyperparameters. For instance, each EEG sample contains 4-channel features from 4 sub-bands, and the grid size is 9x9. We then train the model for 50 epochs using the ClassifierTrainer.
from torch.utils.data import DataLoader
from torcheeg.models import CCNN
from torcheeg.trainers import ClassifierTrainer
import pytorch_lightning as pl
for i, (train_dataset, val_dataset) in enumerate(k_fold.split(dataset)):
train_loader = DataLoader(train_dataset, batch_size=64, shuffle=True)
val_loader = DataLoader(val_dataset, batch_size=64, shuffle=False)
model = CCNN(num_classes=2, in_channels=4, grid_size=(9, 9))
trainer = ClassifierTrainer(model=model,
num_classes=2,
lr=1e-4,
weight_decay=1e-4,
accelerator="gpu")
trainer.fit(train_loader,
val_loader,
max_epochs=50,
default_root_dir=f'./tmp_out/examples_pipeline/model/{i}',
callbacks=[pl.callbacks.ModelCheckpoint(save_last=True)],
enable_progress_bar=True,
enable_model_summary=True,
limit_val_batches=0.0)
score = trainer.test(val_loader,
enable_progress_bar=True,
enable_model_summary=True)[0]
print(f'Fold {i} test accuracy: {score["test_accuracy"]:.4f}')
For more specific usage of each module, please refer to the documentation.
Releases and Contributing
TorchEEG is currently in beta; Please let us know if you encounter a bug by filing an issue. We also appreciate all contributions.
If you would like to contribute new datasets, deep learning methods, and extensions to the core, please first open an issue and then send a PR. If you are planning to contribute back bug fixes, please do so without any further discussion.
License
TorchEEG has a MIT license, as found in the LICENSE file.
Citation
If you find this project useful for your research, please cite:
@article{zhang2024torcheeg,
title = {{TorchEEGEMO}: A deep learning toolbox towards {EEG}-based emotion recognition},
journal = {Expert Systems with Applications},
pages = {123550},
year = {2024},
issn = {0957-4174},
author = {Zhi Zhang and Sheng-hua Zhong and Yan Liu}
}
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
File details
Details for the file torcheeg-1.1.2.tar.gz
.
File metadata
- Download URL: torcheeg-1.1.2.tar.gz
- Upload date:
- Size: 214.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a6f13e12d7aa38e11247ee9ba70f320ea36571fd92f3fe9ed5bd24e23a5757ff |
|
MD5 | 9788dadc6bd0e9745cc1d3092050aeb1 |
|
BLAKE2b-256 | f4d545047b7501d635076492c9eb619605d9b43ae68ab719c6db71c8e042b10a |