able-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., "@able-mcpWhat's the tempo and track count of my latest project?"
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.
ABLE-MCP
Right-click MIDI and audio tools for Ableton Live 12, plus an MCP server for .als analysis and live bridge orchestration.
Two artifacts in one repo:
AbleMCP.ablx — a native Ableton Live 12 extension. Drag it in, right-click clips, get fast deterministic transformations and vocal-to-complement generation. No API key, no cloud dependency.
able-mcp(Python) — an MCP server for parsing and analyzing.alsproject files offline. Plug into Claude Desktop / VS Code / Cursor and ask questions about your sets.
The extension (shipping in v0.2)
Built on @ableton-extensions/sdk 1.0.0-beta.0. Runs inside Live's own process — not Max for Live. Tested on Live 12.4.5b3.
Install
Download
dist/AbleMCP.ablxOpen Live → Settings → Library → Extensions
Drag the
.ablxfile inRestart Live
What you get
Right-click any MIDI clip (session or arrangement) → ABLE-MCP menu:
Action | What it does |
ABLE-MCP: Variation | 30% chance per note: bump ±octave; 15% chance: drop the note. |
ABLE-MCP: Octave double | Add a quieter octave-up layer. |
ABLE-MCP: Humanize | Jitter timing ±0.05 beats and velocity ±10. |
ABLE-MCP: Reverse | Mirror notes around the clip's midpoint in time. |
ABLE-MCP: Invert (mirror) | Mirror pitch around the median note. |
ABLE-MCP: Transpose +1 / ABLE-MCP: Transpose -1 | Semitone up / down. |
ABLE-MCP: Legato | Extend each pitch's note to the next one's start. |
ABLE-MCP: Staccato | Cut every note to 25% of its length. |
ABLE-MCP: Thin (every other) | Drop every other note in time order. |
ABLE-MCP: Double-time | Compress timing 2× and play the pattern twice. |
ABLE-MCP: Half-time | Stretch to 2×; first half plays at half speed. |
ABLE-MCP: Strum chords | Stagger simultaneous notes by 1/64 each (instant strum). |
ABLE-MCP: Accent downbeats | Boost on-beat notes, duck off-beat. |
ABLE-MCP: Top voice only | Keep the highest note of each chord. |
ABLE-MCP: Bass voice (drop 8va) | Keep the lowest note of each chord, drop an octave. |
ABLE-MCP: Shift… | Modal: shift notes by N beats and/or N semitones, with optional wrap-around. Quick-bump preset buttons for common values. |
Every action also works on time-range selections in arrangement view — right-click a selection across one or more MIDI tracks and pick ABLE-MCP (range): …. Only notes inside the range are transformed.
Right-click any audio clip in arrangement view:
Action | What it does |
ABLE-MCP: Chop into beats (1/4 bar) / 1/2 / 1 / 2 / 4 / 8 bars | Splits a long audio clip into adjacent cropped chunks without rewriting source audio. |
ABLE-MCP: Snap first hit to bar | Detects first onset in WAV and repositions crop/start so the first hit lands on a downbeat. |
ABLE-MCP: Create complementary MIDI from vocal... | Renders the clip range, extracts guide melody from audio, generates a complementary line, and writes a new arrangement MIDI clip (modal controls: similarity, density, register, call/response, seed, target track). |
Every action is a single Cmd-Z undo.
Why it's fast
Core MIDI/audio actions are pure deterministic functions running in-process. Typical transform actions are near-instant and fully undoable. No LLM call is required for the shipping extension feature set.
Building from source
cd extension
npm install
npm run build # tsc + esbuild → dist/extension.cjs
npm run package # → ../dist/AbleMCP.ablxRelated MCP server: remix-mcp
The MCP server
Python 3.11, stdio transport. Parses Live's gzipped .als files and exposes structure as MCP tools. Useful when you want an LLM to read a project without opening Live.
Install
Option A — local clone:
uv syncOption B — run directly from GitHub (no PyPI required):
uvx --from git+https://github.com/bassDaddyDevices/ABLE-MCP@v0.2.0 able-mcpRun
Local clone:
uv run able-mcpGitHub source (one-shot):
uvx --from git+https://github.com/bassDaddyDevices/ABLE-MCP@v0.2.0 able-mcpHook into a client
Claude Desktop (local clone) — ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"able-mcp": {
"command": "uv",
"args": ["--directory", "/absolute/path/to/ABLE-MCP", "run", "able-mcp"]
}
}
}Claude Desktop (GitHub source, no PyPI):
{
"mcpServers": {
"able-mcp": {
"command": "uvx",
"args": [
"--from",
"git+https://github.com/bassDaddyDevices/ABLE-MCP@v0.2.0",
"able-mcp"
]
}
}
}VS Code (Copilot Chat, local clone) — your user or workspace mcp.json:
{
"servers": {
"able-mcp": {
"command": "uv",
"args": ["--directory", "/absolute/path/to/ABLE-MCP", "run", "able-mcp"]
}
}
}VS Code (Copilot Chat, GitHub source, no PyPI):
{
"servers": {
"able-mcp": {
"command": "uvx",
"args": [
"--from",
"git+https://github.com/bassDaddyDevices/ABLE-MCP@v0.2.0",
"able-mcp"
]
}
}
}Tools
Tool | What it does |
| Tempo, time sig, track/clip/note counts, master-bus state. |
| Per-track kind, name, mute/solo, device & clip counts. |
| Clip metadata across one or all tracks. |
| Note-level MIDI dump. |
| Heuristic suggestions for things that look incomplete. |
| Extract monophonic guide melody from vocal WAV. |
| Generate complementary (not duplicated) MIDI line. |
| One-shot extraction + complement generation pipeline. |
| Replace notes in arrangement MIDI clip by index. |
| Render audio range in Live, generate complement, create/write arrangement MIDI clip in one call. |
Roadmap
v0.2.x — tighten vocal-to-complement quality (better vibrato handling, stronger anti-unison controls, warped-clip timing support).
v0.3 — richer bridge orchestration tools (multi-clip workflows and arrangement/session interoperability).
v0.4 — expand deterministic composition primitives (scale quantize, swing, density, stutter, chord-tone targeting).
Develop
uv run pytest # Python tests
uv run ruff check . # Python lintPython tests use synthetic .als fixtures (gzipped XML) generated in tests/fixtures/init.py. When a real Live 12 file becomes available, drop it under tests/fixtures/real/ and add parity tests — the parser is best-effort against an undocumented schema.
Supply-chain hygiene
uv.lockis committed; review every diff.All Python deps pinned with
==.The extension has exactly one runtime dep (
@ableton-extensions/sdk), pinned in extension/package.json.
License
MIT (extension and Python server).
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/bassDaddyDevices/ABLE-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server