Ableton Live integration through the Model Context Protocol
Project description
AbletonMCP - Ableton Live Model Context Protocol Integration
AbletonMCP connects Ableton Live to Claude AI through the Model Context Protocol (MCP), allowing Claude to directly interact with and control Ableton Live. This integration enables prompt-assisted music production, track creation, and Live session manipulation.
Join the Community
Give feedback, get inspired, and build on top of the MCP: Discord
Features
- Two-way communication: Connect Claude AI to Ableton Live through a socket-based server
- Track manipulation: Create, modify, and manipulate MIDI and audio tracks
- Instrument and effect selection: Claude can access and load the right instruments, effects and sounds from Ableton's library
- Clip creation: Create and edit MIDI clips with notes
- Session control: Start and stop playback, fire clips, and control transport
Components
The system consists of two main components:
- Ableton Remote Script (
AbletonMCP/__init__.py): A MIDI Remote Script for Ableton Live that creates a socket server to receive and execute commands - MCP Server (
server.py): A Python server that implements the Model Context Protocol and connects to the Ableton Remote Script
Installation
Prerequisites
- Ableton Live 10 or newer
- Python 3.8 or newer
- uv package manager
If you're on Mac, please install uv as:
brew install uv
Otherwise, install from [uv's official website][https://docs.astral.sh/uv/getting-started/installation/]
⚠️ Do not proceed before installing UV
Claude for Desktop Integration
- Go to Claude > Settings > Developer > Edit Config > claude_desktop_config.json to include the following:
{
"mcpServers": {
"ableton": {
"command": "uvx",
"args": [
"ableton-mcp"
]
}
}
}
Cursor Integration
Run ableton-mcp without installing it permanently through uvx. Go to Cursor Settings > MCP and paste this as a command:
uvx ableton-mcp
⚠️ Only run one instance of the MCP server (either on Cursor or Claude Desktop), not both
Installing the Ableton Remote Script
-
Download the
AbletonMCPfolder from this repo -
Copy the folder to Ableton's MIDI Remote Scripts directory:
For macOS:
- Method 1: Right-click on Ableton Live app → Show Package Contents → Navigate to:
Contents/App-Resources/MIDI Remote Scripts/ - Method 2: Use the direct path (replace XX with your version number):
/Applications/Ableton Live XX.app/Contents/App-Resources/MIDI Remote Scripts/ - For Suite version:
/Applications/Ableton Live XX Suite.app/Contents/App-Resources/MIDI Remote Scripts/ - For older versions:
/Applications/Ableton Live XX.app/Contents/Resources/MIDI Remote Scripts/
For Windows:
- Primary location:
C:\ProgramData\Ableton\Live XX\Resources\MIDI Remote Scripts\ - Alternative location:
C:\Program Files\Ableton\Live XX\Resources\MIDI Remote Scripts\ - For portable installations:
Look in your Ableton installation folder for
Resources\MIDI Remote Scripts\
Note: Replace XX with your Ableton version number (e.g., 10, 11, 12)
- Method 1: Right-click on Ableton Live app → Show Package Contents → Navigate to:
-
Launch Ableton Live
-
Go to Preferences → Link/MIDI
-
In the Control Surface dropdown, select "AbletonMCP"
-
Set Input and Output to "None"
Usage
Starting the Connection
- Ensure the Ableton Remote Script is loaded in Ableton Live
- Make sure the MCP server is configured in Claude Desktop or Cursor
- The connection should be established automatically when you interact with Claude
Using with Claude
Once the config file has been set on Claude, and the remote script is running in Ableton, you will see a hammer icon with tools for the Ableton MCP.
Capabilities
- Get session and track information
- Create and modify MIDI and audio tracks
- Create, edit, and trigger clips
- Control playback
- Load instruments and effects from Ableton's browser
- Add notes to MIDI clips
- Change tempo and other session parameters
Example Commands
Here are some examples of what you can ask Claude to do:
- "Create an 80s synthwave track"
- "Create a Metro Boomin style hip-hop beat"
- "Create a new MIDI track with a synth bass instrument"
- "Add reverb to my drums"
- "Create a 4-bar MIDI clip with a simple melody"
- "Get information about the current Ableton session"
- "Load a 808 drum rack into the selected track"
- "Add a jazz chord progression to the clip in track 1"
- "Set the tempo to 120 BPM"
- "Play the clip in track 2"
Troubleshooting
- Connection issues: Make sure the Ableton Remote Script is loaded, and the MCP server is configured on Claude
- Timeout errors: Try simplifying your requests or breaking them into smaller steps
- Have you tried turning it off and on again?: If you're still having connection errors, try restarting both Claude and Ableton Live
Technical Details
Communication Protocol
The system uses a simple JSON-based protocol over TCP sockets:
- Commands are sent as JSON objects with a
typeand optionalparams - Responses are JSON objects with a
statusandresultormessage
Limitations & Security Considerations
- Creating complex musical arrangements might need to be broken down into smaller steps
- The tool is designed to work with Ableton's default devices and browser items
- Always save your work before extensive experimentation
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Disclaimer
This is a third-party integration and not made by Ableton.
Project details
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 ableton_mcp-1.0.1.tar.gz.
File metadata
- Download URL: ableton_mcp-1.0.1.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fbc6d6c096c6355f9103acf7cfb9e3f7f969392f59e3f4d5705cdd0b7058df95
|
|
| MD5 |
8818c29bfbf1d8b199f8a99b2c2faeb5
|
|
| BLAKE2b-256 |
42c792cc8a6a126cc2d6d446de0166d4538788b2aba74586f0679e5a5a306e7f
|
File details
Details for the file ableton_mcp-1.0.1-py3-none-any.whl.
File metadata
- Download URL: ableton_mcp-1.0.1-py3-none-any.whl
- Upload date:
- Size: 9.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a9a3219660f3311c17792e90f5c22cc996e120cf9bdf92de2d224a1ae66e1df5
|
|
| MD5 |
9d16fb5585dc181a85f044bb4c7dbd54
|
|
| BLAKE2b-256 |
2290239f3197a564d6a74a8268d0b773702529cca5f53ce65bd9e3ec883c8986
|