psychopy-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@psychopy-mcpRun a Stroop experiment and analyze the data"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
PsychoPy MCP
让 Claude Code / Codex 直接操作并接管 PsychoPy 的 MCP 服务器 —— 用自然语言设计、运行、读取心理学实验,且自动遵循前人文献的范式参数。
Claude/Codex 用自己的文件工具读写实验脚本(.py);本服务器提供这些工具做不到的 PsychoPy 专属能力:内省、静态校验、运行实验、编译 Builder 文件、驱动常驻交互窗口,以及一套文献校准的经典范式库。
快速上手见 QUICK_START.md,工具清单见 TOOLS_REFERENCE.md。
演示 Demo
一句话「用 Stroop 范式跑个实验再分析」即可走完:生成(文献校准)→ 运行(真实开窗)→ 自动分析出图。
刺激呈现(不一致试次:蓝色墨水的"RED") | 自动分析(Stroop 效应 = 131 ms) |
|
|
Related MCP server: arXiv Research Assistant MCP Server
架构
Claude Code / Codex
│ (MCP / stdio JSON-RPC)
▼
psychopy_mcp/server.py ──FastMCP──┐
│ │ subprocess (psychopy venv)
│ paradigms/ (引擎+14范式) ├── run_experiment → 运行 *.py 实验
│ frontend/ (GUI 启动器) ├── scaffold_paradigm → 生成文献校准实验
│ runner/ (常驻窗口) └── validate / compile / live
▼
.venv (Python 3.10 + PsychoPy 2026.1.3)psychopy_mcp/server.py —— MCP 服务器(FastMCP),暴露全部 19 个工具。
psychopy_mcp/paradigms/ —— 文献校准范式库:共享
engine.py(phase 引擎)+ 每范式一个模块(SPEC+build_trials)+custom.py(自定义范式)。psychopy_mcp/frontend/launcher.py —— Tkinter 桌面启动器:选范式 / 设参数 / 生成并运行 / 新建自定义范式。
psychopy_mcp/runner/live_session.py —— 常驻子进程,持有 PsychoPy
Window,按行收发 JSON,实现"实时接管"。workspace/ —— 脚手架/运行/数据的默认工作目录(相对路径解析到这里)。
工具一览
分组 | 工具 | 作用 |
内省 |
| 报告解释器/版本/安装路径,先调它确认环境连通 |
内省 |
| 列出可用的 visual 刺激类与 Builder 组件 |
内省 |
| 返回任意 PsychoPy 符号的签名+文档(如 |
范式 |
| 列出内置的「文献校准」经典范式 |
范式 |
| 返回某范式的完整规范(设计/固定的字号位置/时序/引用) |
范式 |
| 按文献规范生成可运行实验脚本(各条件字号/位置一致,杜绝 NL 自由发挥导致的偏差) |
范式 |
| 定义并保存自定义范式(之后像内置范式一样用) |
范式 |
| 打开桌面启动器(选范式/运行/新建自定义范式) |
创作 |
| 从模板生成 coder/builder 起始文件 |
创作 |
| 静态检查:语法 + import 解析(不运行、不开窗) |
执行 |
| 以子进程运行实验,捕获 stdout/stderr + 新增数据文件 |
执行 |
| 列出/读取 csv/tsv/log/psydat/xlsx 数据 |
分析 |
| 算范式的标准效应(Stroop效应/搜索斜率/SSRT/d′/ANT网络分等)+ 出图 |
联动 |
| 导出 SPSS 可直接导入的整洁/聚合 CSV(配合 SPSS-MCP 一站式统计) |
网页 |
| 把范式导出成 Builder |
Builder |
| 把 |
Builder |
| 把 |
实时接管 |
| 打开常驻窗口 |
实时接管 |
| 发命令:present_text/image/shape、flip、wait_keys、screenshot、exec、info |
实时接管 |
| 查询/关闭常驻窗口 |
安装
一键(Windows):
install.bat创建 .venv、安装 PsychoPy + 本包、并自动注册到 Claude Code。
手动:
python -m venv .venv
.venv\Scripts\python -m pip install -e .
.venv\Scripts\python -m psychopy_mcp.cli configure-claude项目自带 .mcp.json(用 python -m psychopy_mcp.server 启动),在本目录打开 Claude Code 即自动加载。Codex 用同样的 command/args 即可。CLI 还提供 psychopy-mcp serve|gui|list|configure-claude。
典型工作流
批处理实验(最常用)
env_info() # 1. 确认环境
scaffold_experiment("stroop") # 2. 生成 workspace/stroop.py
…用文件工具编辑 stroop.py…
validate_script("stroop.py") # 3. 静态校验
run_experiment("stroop.py") # 4. 运行(开窗)并收数据
list_data() / read_data("data/xxx.csv") # 5. 看结果实时接管窗口(边做边看)
live_start(size=[1024,768])
live_cmd("present_text", {"text":"Hello", "wait_keys":["space"]})
live_cmd("present_shape", {"shape":"circle", "size":0.3, "fillColor":"red"})
live_cmd("screenshot", {"filename":"shot.png"})
live_stop()Builder 文件
read_psyexp("templates/experiment.psyexp") # 看结构
compile_psyexp("templates/experiment.psyexp") # 编译成 .py 再 run_experiment文献校准(关键设计)
自然语言搭建实验最大的隐患:模型每次会自己瞎编字号、刺激位置、时序、配色,导致和已发表范式不可比。paradigms/ 把经典范式的规范参数固化下来(含引用),所有条件共享同一套字号与居中位置——拥挤/不一致这类错误从根上不可能出现。
list_paradigms() # 看 14 个校准范式
get_paradigm("stroop") # 看完整规范 + 引用(Stroop 1935; MacLeod 1991)
scaffold_paradigm("stroop", "exp1") # 生成 144 试次平衡版(con=incon=neutral=48)
scaffold_paradigm("nback", "wm1", {"n": 3}) # 可传参数覆盖默认所有范式都跑在共享的 phase 引擎(paradigms/engine.py)上:每个范式 = 一串 trial,每个 trial = 一串 phase(注视/线索/刺激/反应)。字号、位置、配色统一来自该范式的 SPEC,结构上保证各条件一致。
key | 范式 | 关键引用 | 默认试次 |
| Colour–Word Stroop | Stroop 1935; MacLeod 1991 | 144 |
| Eriksen Flanker | Eriksen & Eriksen 1974 | 240 |
| Simon | Simon & Rudell 1967 | 160 |
| Go/No-Go | Wessel 2018 | 100 |
| Posner 空间线索 | Posner 1980 | 40 |
| 停止信号(SSRT, 自适应阶梯) | Logan & Cowan 1984; Verbruggen 2019 | 128 |
| 注意网络测验 ANT | Fan et al. 2002 | 48–96 |
| N-back 工作记忆 | Kirchner 1958; Owen 2005 | 30 |
| Sternberg 记忆扫描 | Sternberg 1966 | 40 |
| 视觉搜索(特征/合取) | Treisman & Gelade 1980 | 60 |
| 线索化任务切换 | Meiran 1996; Monsell 2003 | 64 |
| 词汇判断 | Meyer & Schvaneveldt 1971 | 144 |
| 心理旋转(2D 字符变体) | Shepard & Metzler 1971 | 80 |
| 点探测(注意偏向) | MacLeod, Mathews & Tata 1986 | 48 |
词汇判断/点探测内置的是小词表,正式研究请替换为 SUBTLEX/ELP 等规范词库;心理旋转默认用 2D 字符变体,需要原版 3D 立方体图请放入图片素材并把刺激改为
kind="image"。
线上实验(Pavlovia / PsychoJS)
只有 Builder .psyexp 能自动转成 JavaScript 在浏览器跑(纯 Coder 脚本不行)。export_web 帮你把范式导出成 .psyexp + .js + 条件文件:
export_web("stroop") # → workspace/web_stroop/{*.psyexp, *.js, *_conditions.csv}把该文件夹上传到 Pavlovia(或在 PsychoPy Builder 里 Sync)即可招募线上被试。
目前支持「单文字刺激 + 按键」类范式(Stroop / Flanker / 词汇判断 / 文字类自定义);含图形/多阶段的范式(Posner/ANT/Simon 等)暂为桌面端。
与 SPSS-MCP 联动(设计→运行→统计 一条龙)
本服务器负责采数据,SPSS-MCP 负责做统计,靠 CSV 衔接。在同一个 Claude 会话里同时配置两个 MCP:
run_experiment("stroop_exp.py") # 1. 采数据
export_for_spss("data/xxx.csv", aggregate=True) # 2. 导出 SPSS 可读 CSV
→ 让 SPSS-MCP 导入该 CSV,对 rt_ms 按 condition 跑重复测量 ANOVA # 3. 出统计说明 / 限制
不是 headless:PsychoPy 基于 GUI,Windows 上运行实验会真实开窗。在带屏幕(或虚拟显示)的机器上跑。
venv 隔离:服务器与实验都用
.venv\Scripts\python.exe(Python 3.10 + PsychoPy 2026.1.3),不污染系统环境。live_cmd exec是逃生舱:可在窗口进程内执行任意 PsychoPy 代码(作用域含win, visual, core, event),灵活但需自负其责。一次只允许一个 live 会话;再开需先
live_stop。
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/hackerunner/psychopy-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server

