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.6.tar.gz (34.6 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.6-py3-none-any.whl (37.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: rosoku-0.0.6.tar.gz
  • Upload date:
  • Size: 34.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for rosoku-0.0.6.tar.gz
Algorithm Hash digest
SHA256 8d78b6b59b5bad53cdc8a8f85d10c5f5e53be7df3339a1540c5dd677ed5dfd0a
MD5 67b910b07e29237dfacca9d139342173
BLAKE2b-256 6a56563c88e111d75de48567148d493cbc170ba992207fd65aeda59534799db1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: rosoku-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 37.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for rosoku-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f77aab5cc3fa9d98f4127e69a908cf7cc7945058ea0dede1865e5a29dc8978e4
MD5 07f89ffd01cb3f4a7a4a146f06750f62
BLAKE2b-256 616f44adc17a38e2a034ed164654968b26be596a89a8d8f4211f030aeeb37e89

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