music21-mcp-server

brightlikethelight/music21-mcp-server

3.3

If you are the rightful owner of music21-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

The Music21 MCP Server is a production-ready server that leverages the Model Context Protocol to provide advanced music analysis and generation capabilities using the music21 library.

Tools
5
Resources
0
Prompts
0

Music21 Analysis - Multi-Interface Music Server

Python 3.10+ License: MIT Ruff MCP

Professional music analysis with 4 different interfaces - MCP server, HTTP API, CLI tools, and Python library. Built on the powerful music21 library with protocol-independent architecture for maximum reliability.

๐ŸŽฏ Why Multiple Interfaces?

Based on 2025 research showing MCP has 40-50% production success rate, this project provides multiple pathways to the same powerful music21 analysis functionality:

  • ๐Ÿ“ก MCP Server - For Claude Desktop integration (when it works)
  • ๐ŸŒ HTTP API - For web applications (reliable backup)
  • ๐Ÿ’ป CLI Tools - For automation (always works)
  • ๐Ÿ Python Library - For direct programming access

๐ŸŽต Core Music Analysis Features

Analysis Tools (13 Available)

  • Import & Export: MusicXML, MIDI, ABC, Lilypond, music21 corpus
  • Key Analysis: Multiple algorithms (Krumhansl, Aarden, Bellman-Budge)
  • Harmony Analysis: Roman numerals, chord progressions, cadence detection
  • Voice Leading: Parallel motion detection, voice crossing analysis
  • Pattern Recognition: Melodic, rhythmic, and harmonic patterns

Advanced Capabilities

  • Harmonization: Bach chorale and jazz style harmonization
  • Counterpoint: Species counterpoint generation (1-5)
  • Style Imitation: Learn and generate music in composer styles
  • Score Manipulation: Transposition, time stretching, orchestration

๐Ÿš€ Quick Start

Installation

Install from PyPI (Recommended)
# Install the package
pip install music21-mcp-server

# Start the server
music21-mcp-server --mode mcp   # For Claude Desktop
music21-mcp-server --mode http  # REST API at localhost:8000
music21-mcp-server --mode cli   # Interactive CLI
Install from Source
# Clone repository
git clone https://github.com/brightlikethelight/music21-mcp-server.git
cd music21-mcp-server

# Install with UV (recommended)
curl -LsSf https://astral.sh/uv/install.sh | sh
uv sync

# Or with pip
pip install -r requirements.txt

# Configure music21 corpus
python -m music21.configure

Usage - Pick Your Interface

๐ŸŽฏ Show All Available Interfaces
python -m music21_mcp.launcher
๐Ÿ“ก MCP Server (for Claude Desktop)
# Start MCP server
python -m music21_mcp.launcher mcp

# Configure Claude Desktop with:
# ~/.config/claude-desktop/config.json
{
  "mcpServers": {
    "music21-analysis": {
      "command": "python",
      "args": ["-m", "music21_mcp.server_minimal"],
      "env": {
        "PYTHONPATH": "/path/to/music21-mcp-server/src"
      }
    }
  }
}
๐ŸŒ HTTP API Server (for web apps)
# Start HTTP API server
python -m music21_mcp.launcher http
# Opens: http://localhost:8000
# API docs: http://localhost:8000/docs

# Example usage:
curl -X POST "http://localhost:8000/scores/import" \
  -H "Content-Type: application/json" \
  -d '{"score_id": "chorale", "source": "bach/bwv66.6", "source_type": "corpus"}'

curl -X POST "http://localhost:8000/analysis/key" \
  -H "Content-Type: application/json" \
  -d '{"score_id": "chorale"}'
๐Ÿ’ป CLI Tools (for automation)
# Show CLI status
python -m music21_mcp.launcher cli status

# Import and analyze a Bach chorale
python -m music21_mcp.launcher cli import chorale bach/bwv66.6 corpus
python -m music21_mcp.launcher cli key-analysis chorale
python -m music21_mcp.launcher cli harmony chorale roman

# List all tools
python -m music21_mcp.launcher cli tools
๐Ÿ Python Library (for programming)
from music21_mcp.adapters import create_sync_analyzer

# Create analyzer
analyzer = create_sync_analyzer()

# Import and analyze
analyzer.import_score("chorale", "bach/bwv66.6", "corpus")
key_result = analyzer.analyze_key("chorale")
harmony_result = analyzer.analyze_harmony("chorale", "roman")

print(f"Key: {key_result}")
print(f"Harmony: {harmony_result}")

# Quick comprehensive analysis
analysis = analyzer.quick_analysis("chorale")

๐Ÿงช Testing & Development

Run Tests

# Reality-based test suite (95% core, 5% adapter)
python tests/run_reality_tests.py

# Core music21 tests (must pass)
python -m pytest tests/core/ -v

# MCP adapter tests (may fail - that's expected)
python -m pytest tests/adapters/ -v

Development Setup

# Install development dependencies
uv sync --dev

# Set up pre-commit hooks
pre-commit install

# Run linting
ruff check src/
ruff format src/

# Type checking
mypy src/

๐Ÿ—๏ธ Architecture

Protocol-Independent Design

Core Value Layer:
โ”œโ”€โ”€ services.py              # Music21 analysis service (protocol-independent)
โ””โ”€โ”€ tools/                   # 13 music analysis tools

Protocol Adapter Layer:
โ”œโ”€โ”€ adapters/mcp_adapter.py   # MCP protocol isolation
โ”œโ”€โ”€ adapters/http_adapter.py  # HTTP/REST API
โ”œโ”€โ”€ adapters/cli_adapter.py   # Command-line interface  
โ””โ”€โ”€ adapters/python_adapter.py # Direct Python access

Unified Entry Point:
โ””โ”€โ”€ launcher.py              # Single entry point for all interfaces

Design Philosophy

  • Core Value First: Music21 analysis isolated from protocol concerns
  • Protocol Apocalypse Survival: Works even when MCP fails (30-40% of time)
  • Multiple Escape Hatches: Always have a working interface
  • Reality-Based: Built for today's MCP ecosystem, not enterprise dreams

๐Ÿ“Š Interface Reliability

InterfaceSuccess RateBest For
MCP40-50%AI assistant integration
HTTP95%+Web applications
CLI99%+Automation & scripting
Python99%+Direct programming

๐Ÿ“š Documentation

  • - Complete interface guide with examples
  • - Architecture simplification rationale
  • - Working code examples
  • API Docs: http://localhost:8000/docs (when HTTP server running)

๐Ÿ”ง Configuration

Environment Variables

# Optional configuration
export MUSIC21_MCP_LOG_LEVEL=INFO
export MUSIC21_MCP_CACHE_SIZE=100
export MUSIC21_MCP_TIMEOUT=30

Music21 Setup

# Configure corpus path (one-time setup)
python -m music21.configure

๐Ÿ› ๏ธ Available Analysis Tools

  1. import_score - Import from corpus, files, URLs
  2. list_scores - List all imported scores
  3. get_score_info - Detailed score information
  4. export_score - Export to MIDI, MusicXML, etc.
  5. delete_score - Remove scores from storage
  6. analyze_key - Key signature analysis
  7. analyze_chords - Chord progression analysis
  8. analyze_harmony - Roman numeral/functional harmony
  9. analyze_voice_leading - Voice leading quality analysis
  10. recognize_patterns - Melodic/rhythmic patterns
  11. harmonize_melody - Automatic harmonization
  12. generate_counterpoint - Counterpoint generation
  13. imitate_style - Style imitation and generation

๐Ÿš€ Quick Examples

Analyze a Bach Chorale

# CLI approach
python -m music21_mcp.launcher cli import chorale bach/bwv66.6 corpus
python -m music21_mcp.launcher cli key-analysis chorale

# Python approach  
analyzer = create_sync_analyzer()
analyzer.import_score("chorale", "bach/bwv66.6", "corpus")
print(analyzer.analyze_key("chorale"))

Start Services

# For Claude Desktop
python -m music21_mcp.launcher mcp

# For web development
python -m music21_mcp.launcher http

# For command-line work
python -m music21_mcp.launcher cli status

๐Ÿ”„ Migration from v1.0

The previous enterprise version has been simplified for reliability:

  • โœ… Kept: All music21 analysis functionality
  • โœ… Added: HTTP API, CLI, Python library interfaces
  • โŒ Removed: Docker, K8s, complex auth, monitoring (too unstable for MCP ecosystem)
  • ๐Ÿ”„ Changed: Focus on core value delivery through multiple interfaces

๐Ÿค Contributing

  1. Fork the repository
  2. Create feature branch: git checkout -b feature/amazing-feature
  3. Run tests: python tests/run_reality_tests.py
  4. Commit changes: git commit -m 'Add amazing feature'
  5. Push branch: git push origin feature/amazing-feature
  6. Submit pull request

๐Ÿ“„ License

MIT License - see file for details.

๐Ÿ™ Acknowledgments

  • Built on the excellent music21 library
  • Uses FastMCP for MCP protocol support
  • Inspired by the need for reliable music analysis tools

Choose the interface that works for you. All provide the same powerful music21 analysis capabilities! ๐ŸŽต