Skip to main content

Model Context Protocol server for M/M/1 queue simulation and analysis

Project description

MCP Server for M/M/1 Queue Simulation

A Model Context Protocol server that provides comprehensive resources, tools, and prompts for M/M/1 queuing system simulation and analysis.

Python License: MIT MCP

What is M/M/1?

M/M/1 is a fundamental queuing model in operations research:

  • First M: Markovian (Poisson) arrivals
  • Second M: Markovian (exponential) service times
  • 1: Single server

This MCP server enables LLMs like Claude to:

  • Access structured M/M/1 theory and formulas
  • Validate simulation parameters
  • Calculate theoretical performance metrics
  • Generate and execute SimPy simulations
  • Compare simulation results with theory

Features

📚 Resources (7)

  • mm1://schema - Complete M/M/1 system schema
  • mm1://parameters - Parameter definitions with constraints
  • mm1://metrics - Performance metrics catalog
  • mm1://formulas - Theoretical formulas
  • mm1://guidelines - Implementation best practices
  • mm1://examples - Pre-configured scenarios
  • mm1://literature - References and citations

🔧 Tools (5)

  • validate_config - Validate M/M/1 parameters and check stability
  • calculate_metrics - Compute theoretical performance metrics
  • run_simulation - Execute SimPy discrete event simulation
  • compare_results - Analyze simulation accuracy
  • recommend_parameters - Suggest optimal configuration

💬 Prompts (4)

  • generate_simulation_code - Create production-ready SimPy code
  • explain_mm1_theory - Educational content on M/M/1 theory
  • analyze_results - Interpret simulation outcomes
  • debug_simulation - Troubleshoot common issues

Installation

Option 1: Using uvx (Recommended)

uvx mcp-server-mm1

Option 2: Using pip

pip install mcp-server-mm1
mcp-server-mm1

Option 3: From Source

git clone https://github.com/yourusername/mcp-server-mm1.git
cd mcp-server-mm1
uv pip install -e .
mcp-server-mm1

Usage with Claude Desktop

Add to your claude_desktop_config.json:

macOS

Location: ~/Library/Application Support/Claude/claude_desktop_config.json

Windows

Location: %APPDATA%\Claude\claude_desktop_config.json

Configuration

{
  "mcpServers": {
    "mm1-simulation": {
      "command": "uvx",
      "args": ["mcp-server-mm1"]
    }
  }
}

Restart Claude Desktop and the server will be available!

Example Usage in Claude

1. Get M/M/1 Schema

User: Show me the M/M/1 queue schema

Claude uses: mm1://schema resource

2. Validate Configuration

User: Is λ=5, μ=8 a valid M/M/1 configuration?

Claude uses: validate_config tool
Result: ✓ Valid, ρ=0.625

3. Calculate Theoretical Metrics

User: Calculate theoretical metrics for λ=5, μ=8

Claude uses: calculate_metrics tool
Result:
- Utilization: 0.625
- Avg queue length: 1.0417
- Avg waiting time: 0.2083
- Avg system time: 0.3333

4. Run Simulation

User: Run a simulation with λ=5, μ=8 for 10,000 time units

Claude uses: run_simulation tool
Result: Simulation metrics + theoretical comparison + accuracy analysis

5. Generate Code

User: Generate SimPy code for λ=3, μ=10

Claude uses: generate_simulation_code prompt
Result: Complete, production-ready Python code

Development

Setup Development Environment

# Clone repository
git clone https://github.com/yourusername/mcp-server-mm1.git
cd mcp-server-mm1

# Install dependencies
uv pip install -e ".[dev]"

Run Tests

pytest

Code Quality

# Format code
black src/ tests/

# Lint
ruff check src/ tests/

# Type check
mypy src/

Local Testing

Use the MCP Inspector to test the server locally:

# Install MCP inspector (if not already installed)
npm install -g @modelcontextprotocol/inspector

# Run server with inspector
mcp dev src/mcp_server_mm1/server.py

This opens a web interface where you can:

  • Browse available resources
  • Test tool invocations
  • Try prompt templates
  • Inspect JSON-RPC communication

Architecture

src/mcp_server_mm1/
├── server.py          # FastMCP server with resources/tools/prompts
├── schemas/
│   └── mm1_schema.py  # M/M/1 system schema definition
├── simulations/
│   └── mm1_queue.py   # SimPy simulation implementation
└── utils/
    └── metrics.py     # Theoretical calculations

M/M/1 Theory Quick Reference

Key Formulas

Given arrival rate λ and service rate μ:

  • Utilization: ρ = λ/μ
  • Avg Queue Length: L_q = ρ²/(1-ρ)
  • Avg Time in Queue: W_q = ρ/(μ(1-ρ))
  • Avg Time in System: W = 1/(μ(1-ρ))

Stability Condition

System must satisfy ρ < 1 (λ < μ)

If ρ ≥ 1, the queue grows unbounded!

Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes with tests
  4. Submit a pull request

License

MIT License - see LICENSE file for details.

Related Work

This MCP server was developed as part of research on LLM-assisted simulation code generation for the Winter Simulation Conference (WSC) 2025.

References

Support


Made with ❤️ for the simulation and LLM communities

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

mcp_server_mm1-0.1.2.tar.gz (26.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_server_mm1-0.1.2-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

Details for the file mcp_server_mm1-0.1.2.tar.gz.

File metadata

  • Download URL: mcp_server_mm1-0.1.2.tar.gz
  • Upload date:
  • Size: 26.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.13

File hashes

Hashes for mcp_server_mm1-0.1.2.tar.gz
Algorithm Hash digest
SHA256 17c18411ac711ae383a1acee41c554ae595667ebf086e6098dbb89706dac245c
MD5 d1bb659e7b44e105ef6d8506be0f762d
BLAKE2b-256 8af8a94f6a3a7e8982204e3c644172fd8dd0eea67e37052a72ccd93b895ed523

See more details on using hashes here.

File details

Details for the file mcp_server_mm1-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: mcp_server_mm1-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 29.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.13

File hashes

Hashes for mcp_server_mm1-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1f5e74806da2e4b605e95af3979a2505bebf136a3087e9e4e38002623c9989ea
MD5 d666ebce67e9d2c3eb161ba14aaf8132
BLAKE2b-256 cf36e9f7d1c3b0859a3781e1ef774f787add94bbd614cb21eda450f53a3b2f40

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page