elektron-mcp

elektron-mcpは、Pythonを使用して自動化されたプロセスを簡素化するためのツールです。ユーザーは、複雑なワークフローを簡単に構築でき、効率的な作業を実現します。特に、データ処理やAPIとの連携に強みを持っています。

GitHubスター

82

ユーザー評価

未評価

お気に入り

0

閲覧数

19

フォーク

4

イシュー

3

README
Elektron MCP

A Model Context Protocol (MCP) server that allows Claude and other MCP-compatible LLMs to interact with and control Elektron synthesizers via MIDI.

If you have a Moog Sub37/Subsequent37, check out our dedicated MCP server for it at moog-sub37-mcp.
A web-based version of this MCP server can be found at senthgenie.com. (You can ask for API key for free on discord)
If you want help or would like to contribute to development, please join our Discord community.
Prompt examples
"Use Digitone MCP to design an evolving dark pad using the Wavetone machine on track 1."
"Use Digitone MPC to design a Dark thick pad using Wavetone machine on track 1."

Only Wavetone machine is supported for now, other machines will be added soon, stay tuned!

Features
  • Complete MIDI control interface for the Elektron Digitone synthesizer
  • Structured controllers for all Digitone sound engines:
    • Wavetone (waveshaping synthesis)
    • FM Tone (FM synthesis)
    • FM Drum (percussive FM synthesis)
    • Swarmer (unison/swarm synthesis)
  • Comprehensive parameter control for:
    • All filter types
      • MultiMode
      • Lowpass4
      • Equalizer
      • LegacyLpHp
      • CombMinus
      • CombPlus
      • BaseWidth
    • Amplitude and envelope settings
    • Effects processing (delay, reverb, chorus, bit reduction, etc.)
    • LFOs control
  • MCP server exposing all synth parameters as tools for LLMs
  • Type-safe parameter validation using Pydantic
  • Modular architecture for easy extension to other Elektron devices
Demo

Watch Claude control the Elektron Digitone synthesizer in real-time:

Claude controlling Elektron Digitone

Installation and Usage
Prerequisites
  • Python 3.10+
  • uv for package management
  • An Elektron Digitone connected via USB
  • Claude Desktop app (for full integration)
Installing Dependencies

uv is mandatory for this project so start by installing it:

For macOS:
brew install uv
For Windows:

Follow the instructions here

3. Installing with Claude Desktop

To use with Claude AI, add the MCP server configuration in Claude Desktop:

⚠️ Important: You don't need to clone the repository or install the packages, all you need is to add the MCP server configuration to your claude_desktop_config.json file the MPC server is already published on pypi.

Go to Claude > Settings > Developer > Edit Config > claude_desktop_config.json to include the following:

{
  "mcpServers": {
    "Digitone 2": {
      "command": "uvx",
      "args": ["elektron-mcp"]
    }
  }
}
Architecture
  • Base Controllers: Common functionality abstracted into base classes
  • Specialized Controllers: Dedicated controllers for each synth engine and module
  • MCP Tools: Direct interface between LLMs and the synth's parameters
  • MIDI Interface: Reliable communication with Digitone hardware
Implementation Details

This library uses:

  • FastMCP: For exposing synth controls to LLMs
  • Pydantic models: For data validation, serialization, and type safety
  • mido: For MIDI communication
Use Cases
  • Allow Claude and other LLMs to create and modify sounds on the Digitone
  • Programmatically control Digitone parameters for automated sound design
  • Bridge between AI-generated music and hardware synthesis
Future Extensions
  • Support for additional Elektron devices (Analog Four, Octatrack, etc.)
  • Pattern sequencing and automation
  • Sound preset management
  • Additional synthesis parameters