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:
- You define items describing which data belong to each split
- You provide callbacks to load and preprocess data
- 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 = 0especially when publishing or debugging experiments.
🚀 Quick Start
Full runnable examples are available under examples/.
Recommended first files:
examples/example_within-subject-classification-riemannian.pyexamples/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
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 rosoku-0.0.5.tar.gz.
File metadata
- Download URL: rosoku-0.0.5.tar.gz
- Upload date:
- Size: 34.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e9f6210c0a4df4a3de69bfd6e076b9f0d3fe900a66e2cb1d1ce0083c554bba29
|
|
| MD5 |
a6c35bb17774eb1ad500b5be49a2e0a2
|
|
| BLAKE2b-256 |
c26eb598a93fc264d6d3e6ba921e5193c4c46f1a88619901f56f577ca2f4f1af
|
File details
Details for the file rosoku-0.0.5-py3-none-any.whl.
File metadata
- Download URL: rosoku-0.0.5-py3-none-any.whl
- Upload date:
- Size: 37.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb3b3fb5ff485daab8167d2d3eb8c947a6e2c988c2441c607242a777867569c3
|
|
| MD5 |
acf8b14ffa38288cfcfcd42d372680e1
|
|
| BLAKE2b-256 |
9958cd9586695cc1414749e59c757d10b786782ff7412dd047ad4795669ce664
|