AI-powered music notation. Describe what you want in plain English -- get a publication-ready score in MuseScore.
"Create a big band chart -- 32-bar AABA form, key of Bb, slow blues at 66 BPM, with rhythm changes and rehearsal marks at each section."
Claude writes a complete music21 script, executes it, and hands you a MusicXML file ready to open in MuseScore, Dorico, Sibelius, or any notation app.
With the MuseScore plugin running, you can go further:
"Read the melody in bars 9-16 and arrange it as a trombone soli following the chord progression."
Claude reads the live score, applies musical intelligence, and writes the arrangement back -- all through natural language.
pip install mcp-scoreOr with uv:
uv tool install mcp-scoreThen set up the components you need:
# Install the score generation skill (for Claude Code)
mcp-score install-skill
# Install the MuseScore plugin (for live score manipulation)
mcp-score install-plugin
# Or install both at once
mcp-score installmcp-score has three components that work together:
A Python MCP server with 18 tools for live score manipulation across MuseScore, Dorico, and Sibelius: connect/disconnect, read passages, add chords, set barlines, transpose, and more. Runs via mcp-score serve (or just mcp-score).
A Claude Code skill that teaches Claude to write music21 Python scripts for score generation. Installed to ~/.claude/skills/score-generate/. This handles the "create a score from scratch" use case -- no MCP round-trips needed.
A QML plugin that runs a WebSocket server inside MuseScore 4, enabling the MCP server to read from and write to the active score in real time. Supports 19 commands including navigation, note input, chord symbols, rehearsal marks, barlines, key/time signatures, tempo, transposition, and undo.
Add the MCP server to your project or global settings:
claude mcp add mcp-score -- mcp-score serveThe score generation skill is installed separately with mcp-score install-skill and activates automatically when you ask Claude to create a score.
Add to your claude_desktop_config.json:
{
"mcpServers": {
"mcp-score": {
"command": "mcp-score",
"args": ["serve"]
}
}
}After mcp-score install-plugin:
- Open MuseScore 4
- Go to Plugins > Plugin Manager
- Enable MCP Score Bridge
- The plugin starts a WebSocket server on port 8765
See MuseScore plugin docs for details.
mcp-score serve Run the MCP server (default)
mcp-score run <script> Run a Python script with music21 available
mcp-score install Install skill and MuseScore plugin
mcp-score install-skill Install the score-generate skill to ~/.claude/skills/
mcp-score install-plugin Install the QML plugin to MuseScore's Plugins directory
mcp-score help Show help
| Document | Description |
|---|---|
| Getting started | Set up mcp-score and generate your first score |
| Architecture | System design and key decisions |
| Tool reference | Complete list of MCP tools |
| MuseScore plugin | Plugin installation and WebSocket protocol |
See CONTRIBUTING.md for development setup, code style, and PR process.
Thomas Skovlund Hansen — thomas@skovlund.dev