MIDI MCP Server
A Model Context Protocol (MCP) server for AI-driven MIDI composition. Generate MIDI files from structured JSON data, with chord name support, an interactive piano-roll preview UI, and multiple deployment modes.

Looking for the Agent Skills approach? It composes better songs with less context: tubone24/midi-agent-skill
Features
- Two MCP tools:
create_midi(with interactive preview UI) andparse_chord - Rich pitch input: MIDI numbers, note name strings (
"C4"), pitch arrays, or chord names ("Cmaj7") - Chord library: 25+ chord qualities — major, minor, dim, aug, 7th, maj7, m7, sus2, sus4, power, and more
- Flexible durations: numeric beats, standard strings (
'4','8'), dotted ('d4'), triplet ('T8') - Music theory resources: 7 built-in reference documents accessible as MCP resources
- Three transport modes: stdio, HTTP, or Cloudflare Workers (remote)
- MCP App UI: Piano-roll visualization and audio playback rendered directly in the conversation
Deployment Options
Option A — Remote (Cloudflare Workers)
A pre-deployed remote server is available:
https://midi-mcp-server.tubone24.workers.dev/mcp
Add it to any MCP client that supports Streamable HTTP (e.g., Claude.ai):
{
"mcpServers": {
"midi": {
"type": "http",
"url": "https://midi-mcp-server.tubone24.workers.dev/mcp"
}
}
}
Option B — Local stdio (recommended for desktop clients)
Build and configure as a local stdio server:
npm install
npm run build
{
"mcpServers": {
"musicComposer": {
"command": "node",
"args": ["/path/to/midi-mcp-server/build/index.js"]
}
}
}
Option C — Local HTTP
Run as a local Streamable HTTP server:
node build/index.js --http
# or with a custom port:
node build/index.js --http --port=8080
The server exposes:
POST /mcp— MCP Streamable HTTP endpointGET /health— Health check ({"status":"ok","version":"0.2.0"})
Tools
create_midi
Generate a MIDI file from structured composition data. Returns base64-encoded MIDI and renders an interactive piano-roll preview with audio playback in supported MCP clients (MCP App).

Input
| Field | Type | Required | Description |
|---|---|---|---|
title | string | ✓ | Title of the composition |
composition | object | ✓ | Composition data (see schema below) |
Output (structured content)
| Field | Type | Description |
|---|---|---|
midiBase64 | string | Base64-encoded MIDI file data |
title | string | Composition title |
bpm | number | Tempo used |
trackCount | number | Number of tracks generated |
parse_chord
Parse a chord name and return its component MIDI pitches and note names. Useful for understanding voicings before composing.
Input
| Field | Type | Required | Description |
|---|---|---|---|
chord | string | ✓ | Chord name, e.g. "Cmaj7", "F#m7", "G7sus4" |
octave | number | — | Root octave (default: 4) |
Output example
{
"chord": "Cmaj7",
"octave": 4,
"midiNumbers": [60, 64, 67, 71],
"noteNames": ["C4", "E4", "G4", "B4"]
}
Composition Schema
{
"bpm": 120, // tempo (also accepted: "tempo")
"timeSignature": { "numerator": 4, "denominator": 4 }, // optional, default 4/4
"tracks": [
{
"name": "Piano", // optional
"instrument": 0, // GM program number 0–127 (optional)
"notes": [
{
"pitch": 60, // MIDI number, note name "C4", or array [60, 64, 67]
"chord": "Cmaj7", // OR use chord name (overrides pitch)
"beat": 1, // beat position (1-based); OR use startTime
"startTime": 0, // tick offset (alias: "time")
"duration": "4", // see Duration Reference below
"velocity": 100, // 0–127 (optional, default 100)
"channel": 0 // MIDI channel 0–15 (optional)
}
]
}
]
}
Pitch Input Formats
| Format | Example | Description |
|---|---|---|
| MIDI number | 60 | Standard MIDI note number (0–127) |
| Note name | "C4" | Letter + optional accidental + octave |
| Pitch array | [60, 64, 67] | Multiple pitches played simultaneously |
| Chord field | chord: "Cmaj7" | Chord name expanded automatically |
Supported accidentals: # (sharp), b (flat). Examples: "F#5", "Bb3".
Duration Reference
| Value | Description |
|---|---|
'1' | Whole note |
'2' | Half note |
'4' | Quarter note |
'8' | Eighth note |
'16' | Sixteenth note |
'32' | Thirty-second note |
'd1' 'd2' 'd4' 'd8' 'd16' | Dotted variants |
'dd4' | Double-dotted quarter |
'T4' 'T8' … | Triplet variants |
4 (number) | Beat-based: 1=quarter, 2=half, 4=whole, 0.5=eighth |
Supported Chord Qualities
| Quality | Example | Description |
|---|---|---|
(none) / maj | C, Cmaj | Major |
m / min | Dm | Minor |
dim | Bdim | Diminished |
aug | Eaug | Augmented |
7 | G7 | Dominant 7th |
maj7 / M7 | Cmaj7 | Major 7th |
m7 / min7 | Am7 | Minor 7th |
dim7 | Bdim7 | Diminished 7th |
m7b5 | Bm7b5 | Half-diminished |
aug7 | Eaug7 | Augmented 7th |
6 / m6 | C6, Am6 | 6th |
9 / maj9 / m9 | G9 | 9th variants |
add9 | Cadd9 | Add 9th |
11 / 13 | C11 | Extended |
sus2 / sus4 | Gsus4 | Suspended |
7sus4 / 7sus2 | G7sus4 | 7th suspended |
power / 5 | G5 | Power chord |
MCP Resources
The server exposes 7 music theory reference documents as MCP resources:
| URI | Description |
|---|---|
music-theory://harmony | Intervals, chord types, diatonic chords, cadences, voice leading |
music-theory://chord-progressions | Common progressions by mood/genre, substitutions, modulation |
music-theory://counterpoint | Species counterpoint rules, consonance/dissonance, motion types |
music-theory://modes-scales | Diatonic modes, minor scale variants, pentatonic/blues, genre guide |
music-theory://orchestration | Instrument ranges, GM program numbers, texture types |
music-theory://rhythm-patterns | Time signatures, MIDI duration reference, genre grooves |
music-theory://voice-leading | Forbidden parallels, voicing strategies, non-chord tones |
MCP clients that support resource reading can pass these to the AI as context, enabling theory-aware composition.
Example Composition
const composition = {
bpm: 120,
timeSignature: { numerator: 4, denominator: 4 },
tracks: [
{
name: "Piano",
instrument: 0,
notes: [
{ chord: "Cmaj7", beat: 1, duration: "2", velocity: 90 },
{ chord: "Am7", beat: 3, duration: "2", velocity: 90 },
{ chord: "Fmaj7", beat: 5, duration: "2", velocity: 90 },
{ chord: "G7", beat: 7, duration: "2", velocity: 90 }
]
},
{
name: "Melody",
instrument: 0,
notes: [
{ pitch: "E4", beat: 1, duration: "4", velocity: 100 },
{ pitch: "G4", beat: 2, duration: "4", velocity: 100 },
{ pitch: "A4", beat: 3, duration: "2", velocity: 110 }
]
}
]
};
Demo
The prompt below generates an 8-bar melodic minor choral piece:
Create an 8-bar choral piece in a slightly minor, melodic scale.
https://github.com/user-attachments/assets/e20ebef0-fdbf-4e72-910d-41b94183f9d9
Build & Development
npm install
# Full build (UI + server)
npm run build
# Build steps individually
npm run build:ui # Vite — builds the MCP App preview HTML
npm run build:server # tsc — compiles TypeScript server
# Deploy to Cloudflare Workers
npm run deploy
# Run tests
npm test
npm run test:coverage
Dependencies
| Package | Purpose |
|---|---|
@modelcontextprotocol/sdk | MCP server implementation (stdio & HTTP transports) |
@modelcontextprotocol/ext-apps | MCP Apps extension — interactive UI in conversation |
midi-writer-js | MIDI file generation |
@tonejs/midi | MIDI parsing (preview UI) |
soundfont-player | Audio playback in preview UI |
zod | Input schema validation |
