A modular framework for automated EEG data processing, built on MNE-Python
Project description
AutoClean EEG
A modular framework for automated EEG data processing, built on MNE-Python.
Features
- Framework for automated EEG preprocessing with "lego block" modularity
- Support for multiple EEG paradigms (ASSR, Chirp, MMN, Resting State)
- BIDS-compatible data organization and comprehensive quality control
- Extensible plugin system for file formats, montages, and event processing
- Research-focused workflow: single file testing → parameter tuning → batch processing
- Detailed output: logs, stage files, metadata, and quality control visualizations
Installation
pip install autoclean-eeg
For development installation:
git clone https://github.com/cincibrainlab/autoclean_pipeline.git
cd autoclean-eeg
uv tool install -e --upgrade ".[dev]"
Quick Start
AutoClean EEG offers two approaches for building custom EEG processing workflows:
Option 1: Python Task Files (Recommended for New Users)
Create simple Python files that combine configuration and processing logic:
# my_task.py
from typing import Any, Dict
from autoclean.core.task import Task
# Embedded configuration
config = {
'resample_step': {'enabled': True, 'value': 250},
'filtering': {'enabled': True, 'value': {'l_freq': 1, 'h_freq': 100}},
'ICA': {'enabled': True, 'value': {'method': 'picard'}},
'epoch_settings': {'enabled': True, 'value': {'tmin': -1, 'tmax': 1}}
}
class MyRestingTask(Task):
def __init__(self, config: Dict[str, Any]):
self.settings = globals()['config']
super().__init__(config)
def run(self) -> None:
self.import_raw()
self.run_basic_steps(export=True)
self.run_ica(export=True)
self.create_regular_epochs(export=True)
# Use your custom task
from autoclean import Pipeline
pipeline = Pipeline(output_dir="/path/to/output")
pipeline.add_task("my_task.py")
pipeline.process_file("/path/to/data.raw", task="MyRestingTask")
Option 2: Traditional YAML Configuration
For complex workflows or when you prefer separate config files:
from autoclean import Pipeline
# Initialize pipeline with YAML configuration
pipeline = Pipeline(
output_dir="/path/to/output"
)
# Process using built-in tasks
pipeline.process_file(
file_path="/path/to/test_data.raw",
task="rest_eyesopen"
)
Typical Research Workflow
- Test single file to validate task and tune parameters
- Review results in output directories and adjust as needed
- Process full dataset using batch processing
# Batch processing (works with both approaches)
pipeline.process_directory(
directory="/path/to/dataset",
task="MyRestingTask", # or built-in task name
pattern="*.raw"
)
Key Benefits of Python Task Files:
- Simpler: No separate YAML files to manage
- Self-contained: Configuration and logic in one file
- Flexible: Optional
export=Trueparameters control file outputs - Intuitive: Pandas-like API with sensible defaults
Documentation
Full documentation is available at https://cincibrainlab.github.io/autoclean_pipeline/
Contributing
We welcome contributions! Please see our Contributing Guide for details.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Citation
If you use this software in your research, please cite:
@software{autoclean_eeg,
author = {Gammoh, Gavin, Pedapati, Ernest, and Grace Westerkamp},
title = {AutoClean EEG: Automated EEG Processing Pipeline},
year = {2024},
publisher = {GitHub},
url = {[https://github.com/yourusername/autoclean-eeg](https://github.com/cincibrainlab/autoclean_pipeline/)}
}
Acknowledgments
- Cincinnati Children's Hospital Medical Center
- Built with MNE-Python
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 autoclean_eeg-2.0.1.tar.gz.
File metadata
- Download URL: autoclean_eeg-2.0.1.tar.gz
- Upload date:
- Size: 339.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b532a1b03b4e30412f81789dbc1b1751f5088f926fa4226728bcd9dc3fed2f0e
|
|
| MD5 |
484e567d09f53de3e06ad826a0892af0
|
|
| BLAKE2b-256 |
83077498c0fc247d28c3d3bf00b4b9226dc1087e77f4534a5611ada248523abd
|
File details
Details for the file autoclean_eeg-2.0.1-py3-none-any.whl.
File metadata
- Download URL: autoclean_eeg-2.0.1-py3-none-any.whl
- Upload date:
- Size: 5.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f678d542bec2e955981efe8df4461daa2114448688206c9847effdb6c2898726
|
|
| MD5 |
4b11eb6ad7e5f7e6f89efd1ef32fa8b3
|
|
| BLAKE2b-256 |
b579569e213183d786f5c56a6cdf04b4634eeaa2daeb29117c87bb452088d8ec
|