A Model Context Protocol server for MNE-Python neurophysiology analysis (EEG / MEG / sEEG / ECoG / fNIRS)
Project description
MNE-MCP
English | 简体中文
A Model Context Protocol (MCP) server that gives AI assistants direct, conversational access to MNE-Python for analyzing human neurophysiology data — EEG, MEG, sEEG, ECoG, and fNIRS.
Describe your analysis in plain language — MNE-MCP loads your recording, runs the MNE pipeline (filtering, ICA, epoching, ERP/ERF averaging, time-frequency, source-level work via code), saves the figures, and explains the results.
Works in Claude Code and opencode (any MCP-capable client). Pairs with bundled Agent Skills —
mne-analyst,mne-mcp-guard, plus a skeptical analysis suite (mne-methodology-critic+ per-category skills) for reliable, archived workflows.
Why an MCP for MNE-Python?
MNE analysis is stateful and visual — unlike a one-shot statistics batch job:
- You load a
Rawrecording once, then filter → re-reference → fit ICA → epoch → average → time-frequency, each step mutating large in-memory objects. MNE-MCP keeps one persistent session so recordings never get re-loaded between steps. - Every decision is driven by looking (PSD, sensor maps, ICA components, ERPs). Every plotting tool saves a PNG the assistant can read and interpret.
- MNE is a huge pure-Python API. MNE-MCP gives you 38 structured tools spanning the common
pipeline and advanced analysis (source localization, connectivity, decoding), plus an
mne_run_codeescape hatch that reaches the entire MNE API in the same live session. - Defaults (line frequency, montage, filter band, rejection threshold, ICA settings, epoch window,
dirs, timeout) are user-configurable via an interactive
mne-mcp configurewizard.
Requirements
- Python 3.10+
- MNE-Python ≥ 1.6 (installed automatically as a dependency)
scikit-learnfor ICA (optional extra)- Claude Code (or any MCP client) with MCP support
Cross-platform: unlike a closed engine, MNE-Python is pure Python, so analysis tools work on Windows, macOS, and Linux.
Quick Install
git clone https://github.com/Exekiel179/MNE-MCP.git
cd MNE-MCP
# 1. Install (pulls in mne, numpy, scipy, matplotlib, scikit-learn for ICA)
pip install -e ".[ica]"
# 2. Register in your MCP client(s) — Claude Code, Codex, opencode — and install skills
mne-mcp setup
# 3. Restart your client
Or run the one-shot installer (creates the venv, installs, verifies, registers, installs skills):
pwsh -File scripts\install.ps1 # Windows
bash scripts/install.sh # macOS / Linux
See QUICK_START.md for a guided first session, or docs/INSTALL.md for the full guide.
One command does everything:
mne-mcp setupregisters themneserver in Claude Code, Codex, and opencode (whichever you use) and installs the companion skills. Narrow it with--clients claude,codex. Themne_*tools require one client restart afterwards (MCP servers load at startup).
Configuration
Auto-configure (recommended)
mne-mcp setup # Claude Code + Codex + opencode, plus skills
mne-mcp setup --clients claude,codex # only specific clients
mne-mcp configure-claude # Claude Code only (subset of setup)
setup registers the mne server in each client and installs the skills, writing a timestamped
backup of any file it touches:
| Client | Config file | Key |
|---|---|---|
| Claude Code | ~/.claude.json |
mcpServers.mne |
| OpenAI Codex CLI | ~/.codex/config.toml |
[mcp_servers.mne] |
| opencode | ~/.config/opencode/opencode.json |
mcp.mne |
Manual setup
Point command at the Python where you installed the package (or mne-mcp if it is on PATH).
Claude Code — ~/.claude.json:
{ "mcpServers": { "mne": { "type": "stdio", "command": "mne-mcp", "args": ["serve", "--transport", "stdio"] } } }
Codex CLI — ~/.codex/config.toml:
[mcp_servers.mne]
command = "mne-mcp"
args = ["serve", "--transport", "stdio"]
enabled = true
opencode — ~/.config/opencode/opencode.json:
{ "mcp": { "mne": { "type": "local", "command": ["mne-mcp", "serve", "--transport", "stdio"], "enabled": true } } }
Environment variables (optional .env)
MNE_MCP_TIMEOUT=300 # per-operation timeout (s); raise for ICA / TFR / large files
MNE_MCP_RESULTS_DIR=... # where figures + exported objects are saved
MNE_MCP_DATA_DIR=... # default directory mne_list_files scans
Configure analysis defaults (interactive wizard)
Set the defaults the structured tools fall back to — mains line frequency (50/60 Hz), default montage, filter band, EEG rejection threshold, ICA method/components, epoch window, directories, and timeout:
mne-mcp configure # interactive prompts (Enter keeps current value)
mne-mcp configure --show # print current defaults
mne-mcp configure --reset # back to built-in defaults
mne-mcp configure --set line_freq=60 default_montage=biosemi64 reject_eeg_uv=120 # non-interactive
Defaults are saved to ~/.mne-mcp/config.json (override path with MNE_MCP_CONFIG). Precedence at
runtime: environment variable > config file > built-in. View the active config in-session with the
mne_get_config tool. Restart the MCP server for changes to take effect.
Install the Skills
mne-mcp setup installs all bundled skills automatically. To do it by hand, copy every folder under
skills/ into your skills dir — the suite is mne-analyst, mne-mcp-guard, mne-methodology-critic,
plus the per-category analysis skills (mne-preprocess, mne-artifacts, mne-erp, mne-spectral,
mne-timefreq, mne-connectivity, mne-source, mne-decoding, mne-stats, mne-advanced) and the
write-up skill (mne-writeup):
set SKILLS_DIR=%USERPROFILE%\.claude\skills
for %S in (mne-analyst mne-mcp-guard mne-methodology-critic mne-preprocess mne-artifacts mne-erp mne-spectral mne-timefreq mne-connectivity mne-source mne-decoding mne-stats mne-advanced mne-writeup) do xcopy /E /I skills\%S "%SKILLS_DIR%\%S"
mne-mcp setupalso installs themne-methodology-criticsubagent to~/.claude/agents/(the skills' Phase 3 dispatches it in an isolated context). Copyagents\mne-methodology-critic.mdthere by hand if installing manually.
Restart your client after installation. (Skills are a Claude Code feature; Codex / opencode use the MCP server directly.)
Usage
Just describe what you want:
加载 sub-01_raw.fif,看一下功率谱
对 raw 做 1–40 Hz 带通、50 Hz 陷波,然后跑 ICA 去眼电
Epoch around the 'target' trigger, -0.2 to 0.8 s, average it, and show the ERP topomaps at 100/200/300 ms
The assistant will:
- Check capabilities (
mne_check_status) - Load your recording into the persistent session
- Run the pipeline step by step, showing figures as PNGs
- Interpret each result in plain language
- Archive figures + the equivalent MNE code to
mne_result/
Output
Every plotting tool saves a PNG to the results dir and returns its path:
> Figure: `C:\...\mne-mcp\results\psd_01.png`
With the mne-analyst skill installed, results and the exact MNE code that produced them are
archived to mne_result/ in your working directory (sequence-numbered), so the analysis is
fully reproducible.
Available Tools (38)
Status & Session (7)
mne_check_status · mne_session_info · mne_describe · mne_get_info ·
mne_reset_session · mne_run_code · mne_get_config
Data IO (2)
mne_list_files · mne_load_raw
Preprocessing (7)
mne_filter · mne_resample · mne_crop · mne_set_montage ·
mne_set_reference · mne_mark_bad_channels · mne_interpolate_bads
Visualization (3)
mne_plot_psd · mne_plot_raw · mne_plot_sensors
ICA (4)
mne_fit_ica · mne_plot_ica_components · mne_plot_ica_sources · mne_apply_ica
Events / Epochs / ERP (7)
mne_find_events · mne_events_from_annotations · mne_make_epochs ·
mne_plot_epochs_image · mne_average_evoked · mne_plot_evoked · mne_plot_topomap
Time-frequency (1)
mne_tfr_morlet
Advanced analysis (6)
mne_decode (MVPA) · mne_connectivity · mne_compute_noise_cov · mne_make_forward ·
mne_apply_inverse · mne_plot_source_estimate
Export (1)
mne_save
Anything still not covered — BIDS, custom statistics, beamformers, autoreject — is reachable through
mne_run_code in the same live session. See TOOLS_REFERENCE.md for full
parameter details. Advanced tools need the [full] extra (pip install -e ".[full]").
Development
# Compile check
python -m compileall src/mne_mcp
# Run tests
pytest
# CLI commands
mne-mcp status # Check environment
mne-mcp setup # Register in Claude Code / Codex / opencode + install skills
mne-mcp configure-claude # Claude Code only
License
MIT — see LICENSE
Documentation
- 项目介绍 / Introduction: docs/INTRODUCTION.md · .docx
- 安装说明 / Install guide: docs/INSTALL.md · .docx
- 使用介绍 / Usage guide: docs/USAGE.md · .docx
- Quick start: QUICK_START.md
- Tool reference: TOOLS_REFERENCE.md
Links
- MNE-Python: https://mne.tools/
- MCP Protocol: https://modelcontextprotocol.io
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
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 mne_mcp-0.2.0.tar.gz.
File metadata
- Download URL: mne_mcp-0.2.0.tar.gz
- Upload date:
- Size: 4.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
69b67d03e0d0b6de28beaa25d0852f71f3126c126288f9bd3b702b78754d6d81
|
|
| MD5 |
9e4f4bb9e2aa161b9c13d360b3aa1249
|
|
| BLAKE2b-256 |
23f35cfc5115d5bcaf0b0ace01846ea78f43d6a1b20191264fc9d6fd36744ff2
|
Provenance
The following attestation bundles were made for mne_mcp-0.2.0.tar.gz:
Publisher:
release.yml on Exekiel179/MNE-MCP
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mne_mcp-0.2.0.tar.gz -
Subject digest:
69b67d03e0d0b6de28beaa25d0852f71f3126c126288f9bd3b702b78754d6d81 - Sigstore transparency entry: 1729413373
- Sigstore integration time:
-
Permalink:
Exekiel179/MNE-MCP@adadab1eb1adb1502031985bca17dfbb2b6707fa -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/Exekiel179
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@adadab1eb1adb1502031985bca17dfbb2b6707fa -
Trigger Event:
push
-
Statement type:
File details
Details for the file mne_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: mne_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 41.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
717bdba33af8f95390da7b4d7f28e18b855b6b83f180b4a770056c1bd6d7c29f
|
|
| MD5 |
fd7e71c723cabdf6ff5553844807538e
|
|
| BLAKE2b-256 |
d09344c787ac4e80e00193eb25166987c86f7f5a0b045fadc472286a726bd361
|
Provenance
The following attestation bundles were made for mne_mcp-0.2.0-py3-none-any.whl:
Publisher:
release.yml on Exekiel179/MNE-MCP
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mne_mcp-0.2.0-py3-none-any.whl -
Subject digest:
717bdba33af8f95390da7b4d7f28e18b855b6b83f180b4a770056c1bd6d7c29f - Sigstore transparency entry: 1729413425
- Sigstore integration time:
-
Permalink:
Exekiel179/MNE-MCP@adadab1eb1adb1502031985bca17dfbb2b6707fa -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/Exekiel179
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@adadab1eb1adb1502031985bca17dfbb2b6707fa -
Trigger Event:
push
-
Statement type: