Skip to main content

A flexible callback-based toolkit for EEG/BCI experiments that lets you define data loading and preprocessing freely, while rosoku handles training, evaluation, and result logging for conventional and deep-learning models.

Project description

🕯️ Rosoku — A Flexible EEG/BCI Experiment Pipeline Toolkit

Rosoku is a research-oriented Python framework for running reproducible EEG/BCI experiments with both conventional machine-learning models and deep-learning models.

It bridges the gap between high-level EEG/BCI frameworks (such as MOABB and Braindecode) and low-level machine-learning libraries (such as scikit-learn and PyTorch), by providing structured yet flexible experiment pipelines without hiding critical details.

Rosoku emphasizes clarity, reproducibility, and experimental control over maximum automation or throughput.


🔥 Core Philosophy

Rosoku is designed around a simple idea:

You define what the data are and how they should be processed.
Rosoku defines how experiments are run, evaluated, and recorded.

Rather than enforcing a fixed dataset or model API, Rosoku relies on explicit, callback-driven interfaces that make each experimental choice visible and reproducible.

This makes Rosoku particularly suitable for:

  • method development
  • ablation studies
  • cross-subject / cross-session analysis
  • careful comparison of pipelines in research papers

🧠 What Rosoku Does (and What You Control)

Task Rosoku handles You define
Dataset orchestration train/valid/test grouping what an item means
Data loading unified pipeline how to load (MNE, NumPy, custom)
Preprocessing execution & split handling any signal processing you write
Training loop fitting, scheduling, checkpointing sklearn estimator / PyTorch model
Evaluation scoring, grouping, aggregation metrics, saliency, logging
Result export parquet / msgpack / pth downstream analysis or plotting

Rosoku does not:

  • impose a dataset format
  • hide training logic behind opaque abstractions
  • silently modify randomness or preprocessing behavior

🔧 Two Complementary Pipelines

API Purpose Typical models
conventional() classical ML classification MDM / TSClassifier / CSP / SVM / LDA
deeplearning() deep learning with PyTorch EEGNet / Braindecode / custom CNN/RNN

Both pipelines follow the same design:

  1. You define items describing which data belong to each split
  2. You provide callbacks to load and preprocess data
  3. Rosoku runs training, evaluation, and result aggregation

This shared structure makes it easy to compare classical and deep-learning approaches within the same experimental setup.


🧪 Reproducibility First

Rosoku is designed with reproducibility as a first-class concern:

  • deterministic training is supported via explicit seeding
  • data loading behavior is transparent
  • no implicit parallelism is used

For maximum reproducibility, Rosoku recommends running with

num_workers = 0

especially when publishing or debugging experiments.


🚀 Quick Start

Full runnable examples are available under examples/.

Recommended first files:

  • examples/example_within-subject-classification-riemannian.py
  • examples/example_within-subject-classification-deeplearning.py

These examples demonstrate:

  • item-based dataset definition
  • grouped test evaluation
  • conventional vs deep-learning pipelines
  • reproducible experiment execution

✨ Who Is Rosoku For?

Rosoku is not a black-box AutoML tool.

It is designed for researchers who:

  • want to understand and control every step of their pipeline
  • need transparent experiments for publications
  • work across multiple datasets, subjects, or sessions
  • value explicitness over convenience

If you prefer maximum automation, MOABB or Braindecode may be a better fit.
If you want a clear, inspectable bridge between theory and implementation, Rosoku is built for you.

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

rosoku-0.0.7.tar.gz (34.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

rosoku-0.0.7-py3-none-any.whl (37.1 kB view details)

Uploaded Python 3

File details

Details for the file rosoku-0.0.7.tar.gz.

File metadata

  • Download URL: rosoku-0.0.7.tar.gz
  • Upload date:
  • Size: 34.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for rosoku-0.0.7.tar.gz
Algorithm Hash digest
SHA256 bd3690eb5c0d9e59f67f1dae1398dbf243df05b139d4539f187166e9f0c90d5d
MD5 e22010b0452e9fdd8c4e6d5817de4790
BLAKE2b-256 57e52c1d37d79dd34dea076d470c6d9adb908825042eab66def44027bfc7a4c5

See more details on using hashes here.

File details

Details for the file rosoku-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: rosoku-0.0.7-py3-none-any.whl
  • Upload date:
  • Size: 37.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for rosoku-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 b69601fbbd76d28041a7a53ec288569097ff5346f74cbc8ade8496cdab0242c9
MD5 c195c5e30cb67402a219f5c0b3889c1e
BLAKE2b-256 c809103e0f2c601d2f56ba7e08d1a9745b7bbb2ce27ae40d7a6f44ed72732fc7

See more details on using hashes here.

Supported by

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