sonicpi-mcp
Uses OpenAI's API to convert natural language requests into Sonic Pi code for music generation.
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., "@sonicpi-mcpcreate a rock drum beat"
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.
Sonic Pi MCP Server
A local MCP server that controls Sonic Pi via OSC with AI-powered music generation.
How It Works
MCP Server receives natural language requests
AI Generator converts requests to Sonic Pi code (patterns or OpenAI)
OSC Client sends code to Sonic Pi via OSC
Sonic Pi executes the code and plays music
Related MCP server: SuperCollider MCP Server
Setup
1. Install Dependencies
python -m venv venv
source venv/bin/activate # Windows: venv\Scripts\activate
pip install -e .2. Configure Sonic Pi
Add this code to Sonic Pi and click "Run":
live_loop :mcp_listener do
use_real_time
code_message = sync "/osc*/mcp/code"
begin
eval(code_message[0])
rescue => e
puts "Error executing code: #{e.message}"
end
end3. Optional: Add OpenAI API Key
cp .env_example .env
# Edit .env and add: OPENAI_API_KEY=your-key-here4. Run Server
python -m sonicpi_mcpUsage
Via Cursor (Recommended)
Ensure server is running
Use commands like: "create a rock beat", "make techno music", "play jazz piano"
Via Command Line
# Create and play music
echo '{"tool": "create_and_play", "args": {"request": "create a rock drum beat"}}' | python3 -m sonicpi_mcp
# Run Sonic Pi code directly
echo '{"tool": "run_code", "args": {"source": "play 60, amp: 2"}}' | python3 -m sonicpi_mcp
# Set BPM
echo '{"tool": "set_bpm", "args": {"bpm": 120}}' | python3 -m sonicpi_mcp
# Stop all
echo '{"tool": "stop_all", "args": {}}' | python3 -m sonicpi_mcpAvailable Tools
create_and_play- Generate and play music from natural languagerun_code- Execute Sonic Pi code directlyset_bpm- Set tempostop_all- Stop all audiocue- Send cue messagesgenerate_music- Generate code without playinglist_patterns- Show available patternsget_pattern- Get specific patterntail_logs- View recent logsdiagnose- Check connection status
Troubleshooting
No sound? Ensure the Sonic Pi listener live_loop is running.
Port issues? Server auto-discovers Sonic Pi's port. Check with: echo '{"tool": "diagnose", "args": {}}' | python3 -m sonicpi_mcp
OSC not working? Check Sonic Pi's Network settings and enable "Allow incoming OSC messages".
This server cannot be installed
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/PranavPradhan/sonicpi-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server