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.1.tar.gz (26.5 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.1-py3-none-any.whl (29.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mcp_server_mm1-0.1.1.tar.gz
  • Upload date:
  • Size: 26.5 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.1.tar.gz
Algorithm Hash digest
SHA256 4185968771830a814729dc929bdfe45487ff88272b9e7b14b35e29ed3cce464d
MD5 0f093b44c49cd7f2a411391df6baf458
BLAKE2b-256 8904ef76bbe6733e7efb0fa651eb0ebdc76d8bf0bd3434860984b8f0b560392c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mcp_server_mm1-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 29.6 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 facebe61cda4b08c7e759a6f767049fb4f13f0cc725cee2e79af58ccf54e8066
MD5 718372952b5ca81c6f3a13c9962a5834
BLAKE2b-256 083b3925f658e29ccdd62bc7928b2ec0e73e98fbdfc978550c71ca96b57d5b46

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