ableton-live-mcp-server

MCP.Pizza Chef: Simon-Kansara

The Ableton Live MCP Server is a specialized MCP server that bridges LLMs with Ableton Live using the Open Sound Control (OSC) protocol. It maps Ableton Live's OSC addresses into MCP tools, allowing real-time, structured communication and control of Ableton Live sessions. This server facilitates advanced AI-driven music production workflows by enabling LLMs to send commands and receive feedback from Ableton Live seamlessly.

Use This MCP server To

Control Ableton Live parameters using natural language commands Automate music production tasks via LLM-driven OSC messaging Integrate Ableton Live with AI-powered creative workflows Map Ableton Live controls to MCP tools for real-time interaction Enable LLMs to query and modify Ableton Live session states Create custom AI-based Ableton Live performance assistants

README

Ableton Live MCP Server

📌 Overview

The Ableton Live MCP Server is a server implementing the Model Context Protocol (MCP) to facilitate communication between LLMs and Ableton Live. It uses OSC (Open Sound Control) to send and receive messages to/from Ableton Live. It is based on AbletonOSC implementation and exhaustively maps available OSC adresses to tools accessible to MCP clients.

Control Ableton Live with LLMs

This project consists of two main components:

  • mcp_ableton_server.py: The MCP server handling the communication between clients and the OSC daemon.
  • osc_daemon.py: The OSC daemon responsible for relaying commands to Ableton Live and processing responses.

✨ Features

  • Provides an MCP-compatible API for controlling Ableton Live from MCP clients.
  • Uses python-osc for sending and receiving OSC messages.
  • Based on the OSC implementation from AbletonOSC.
  • Implements request-response handling for Ableton Live commands.

⚡ Installation

Requirements

  • Python 3.8+
  • python-osc (for OSC communication)
  • fastmcp (for MCP support)
  • uv (recommended Python package installer)
  • AbletonOSC as a control surface

Installation Steps

  1. Install uv (https://docs.astral.sh/uv/getting-started/installation):

    curl -LsSf https://astral.sh/uv/install.sh | sh
  2. Clone the repository:

    git clone https://github.com/your-username/mcp_ableton_server.git
    cd mcp_ableton_server
  3. Install the project and its dependencies:

    uv sync
  4. Install AbletonOSC Follow the instructions at AbletonOSC

🚀 Usage

Running the OSC Daemon

The OSC daemon will handle OSC communication between the MCP server and Ableton Live:

uv run osc_daemon.py

This will:

  • Listen for MCP client connections on port 65432.
  • Forward messages to Ableton Live via OSC on port 11000.
  • Receive OSC responses from Ableton on port 11001.

Example Usage

In Claude desktop, ask Claude:

  • Prepare a set to record a rock band
  • Set the input routing channel of all tracks that have "voice" in their name to Ext. In 2

⚙️ Configuration

By default, the server and daemon run on localhost (127.0.0.1) with the following ports:

  • MCP Server Socket: 65432
  • Ableton Live OSC Port (Send): 11000
  • Ableton Live OSC Port (Receive): 11001

To modify these, edit the AbletonOSCDaemon class in osc_daemon.py:

self.socket_host = '127.0.0.1'
self.socket_port = 65432
self.ableton_host = '127.0.0.1'
self.ableton_port = 11000
self.receive_port = 11001

Claude Desktop Configuration

To use this server with Claude Desktop, you need to configure it in your Claude Desktop settings. The configuration file location varies by operating system:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%/Claude/claude_desktop_config.json

Add the following configuration to your mcpServers section:

{
  "mcpServers": {
    "Ableton Live Controller": {
      "command": "/path/to/your/project/.venv/bin/python",
      "args": ["/path/to/your/project/mcp_ableton_server.py"]
    }
  }

This configuration ensures that:

  • The server runs with all dependencies properly managed
  • The project remains portable and reproducible

Contributing

Feel free to submit issues, feature requests, or pull requests to improve this project.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Acknowledgments

TODO

  • Explore resources and prompts primitives opportunities.
  • Build a standalone Ableton Live MCP client.

ableton-live-mcp-server FAQ

How does the Ableton Live MCP Server communicate with Ableton Live?
It uses the Open Sound Control (OSC) protocol to send and receive messages between the MCP server and Ableton Live.
What components make up the Ableton Live MCP Server?
It consists of the MCP server handling client communication and an OSC daemon that relays commands to Ableton Live and processes responses.
Can this server be used with different LLM providers?
Yes, it is provider-agnostic and works with models like OpenAI, Claude, and Gemini.
Is prior knowledge of OSC required to use this server?
No, the server abstracts OSC details by mapping them into MCP tools accessible to clients.
How does this server enhance music production workflows?
It enables AI models to control and automate Ableton Live functions, streamlining creative and performance tasks.
Does the server support real-time interaction with Ableton Live?
Yes, it supports real-time bidirectional communication for dynamic control and feedback.
What programming languages or environments are needed to run the server?
The server is implemented in Python and requires an environment capable of running Python scripts and managing OSC communication.
Can the server be extended or customized?
Yes, since it is based on open-source AbletonOSC, developers can extend or customize the OSC mappings and MCP tools.