Skip to main content
Glama

Constrained Optimization MCP Server

Constrained Optimization MCP Server

A general-purpose Model Context Protocol (MCP) server for solving combinatorial optimization problems with logical and numerical constraints. This server provides a unified interface to multiple optimization solvers, enabling AI assistants to solve complex optimization problems across various domains.

🚀 Features

  • Unified Interface: Single MCP server for multiple optimization backends
  • AI-Ready: Designed for use with AI assistants through MCP protocol
  • Portfolio Focus: Specialized tools for portfolio optimization and risk management
  • Extensible: Modular design for easy addition of new solvers
  • High Performance: Optimized for large-scale problems
  • Robust: Comprehensive error handling and validation

🛠️ Supported Solvers

  • Z3 - SMT solver for constraint satisfaction problems
  • CVXPY - Convex optimization solver
  • HiGHS - Linear and mixed-integer programming solver
  • OR-Tools - Constraint programming solver

📦 Installation

# Install the package pip install constrained-opt-mcp # Or install from source git clone https://github.com/your-org/constrained-opt-mcp cd constrained-opt-mcp pip install -e .

📐 Mathematical Foundations

Optimization Theory

The Constrained Optimization MCP Server implements solutions for various classes of optimization problems:

Linear Programming (LP)

Loading...

Quadratic Programming (QP)

Loading...

Convex Optimization

Loading...

Where Loading... and Loading... are convex functions.

Constraint Satisfaction Problems (CSP)

Find Loading... such that Loading...

Portfolio Optimization (Markowitz)

Loading...

Where:

  • Loading...: portfolio weights
  • Loading...: expected returns
  • Loading...: covariance matrix
  • Loading...: risk aversion parameter

Solver Capabilities

Problem TypeSolverComplexityMathematical Form
Constraint SatisfactionZ3NP-CompleteLogical constraints
Convex OptimizationCVXPYPolynomialConvex functions
Linear ProgrammingHiGHSPolynomialLinear constraints
Constraint ProgrammingOR-ToolsNP-CompleteDiscrete domains

🚀 Quick Start

1. Run Examples

# Run individual examples python examples/nqueens.py python examples/knapsack.py python examples/portfolio_optimization.py python examples/job_shop_scheduling.py python examples/nurse_scheduling.py python examples/economic_production_planning.py # Run interactive notebook jupyter notebook examples/constrained_optimization_demo.ipynb

2. Start the MCP Server

constrained-opt-mcp

3. Connect from AI Assistant

Add the server to your MCP configuration:

{ "mcpServers": { "constrained-opt-mcp": { "command": "constrained-opt-mcp", "args": [] } } }

4. Use the Tools

The server provides the following tools:

  • solve_constraint_satisfaction - Solve logical constraint problems
  • solve_convex_optimization - Solve convex optimization problems
  • solve_linear_programming - Solve linear programming problems
  • solve_constraint_programming - Solve constraint programming problems
  • solve_portfolio_optimization - Solve portfolio optimization problems

📚 Examples

Constraint Satisfaction Problem

# Solve a simple arithmetic constraint problem variables = [ {"name": "x", "type": "integer"}, {"name": "y", "type": "integer"}, ] constraints = [ "x + y == 10", "x - y == 2", ] # Result: x=6, y=4

Portfolio Optimization

# Optimize portfolio allocation assets = ["Stocks", "Bonds", "Real Estate", "Commodities"] expected_returns = [0.10, 0.03, 0.07, 0.06] risk_factors = [0.15, 0.03, 0.12, 0.20] correlation_matrix = [ [1.0, 0.2, 0.6, 0.3], [0.2, 1.0, 0.1, 0.05], [0.6, 0.1, 1.0, 0.25], [0.3, 0.05, 0.25, 1.0], ] # Result: Optimal portfolio weights and performance metrics

Linear Programming

# Production planning problem sense = "maximize" objective_coeffs = [3.0, 2.0] # Profit per unit variables = [ {"name": "product_a", "lb": 0, "ub": None, "type": "cont"}, {"name": "product_b", "lb": 0, "ub": None, "type": "cont"}, ] constraint_matrix = [ [2, 1], # Labor: 2*A + 1*B <= 100 [1, 2], # Material: 1*A + 2*B <= 80 ] constraint_senses = ["<=", "<="] rhs_values = [100.0, 80.0] # Result: Optimal production quantities

Portfolio Examples

  • Portfolio Optimization - Advanced portfolio optimization strategies including Markowitz, Black-Litterman, and ESG-constrained optimization
  • Risk Management - Risk management strategies including VaR optimization, stress testing, and hedging
Enhanced Portfolio Optimization Features

Equity Portfolio Optimization:

  • Sector diversification constraints (max 25% per sector)
  • Market cap constraints (large, mid, small cap allocations)
  • ESG (Environmental, Social, Governance) constraints
  • Liquidity requirements and individual position limits
  • Risk-return optimization with advanced metrics

Multi-Asset Portfolio Optimization:

  • Asset class constraints (equity, fixed income, alternatives, cash)
  • Regional exposure limits (developed vs emerging markets)
  • Alternative investment constraints (commodities, real estate, private equity)
  • Dynamic rebalancing and risk budgeting
  • Multi-period optimization with transaction costs

Advanced Risk Metrics:

  • Value at Risk (VaR) and Conditional VaR (CVaR)
  • Maximum Drawdown and Tail Risk
  • Factor exposure analysis and risk attribution
  • Stress testing and scenario analysis
  • Correlation and concentration risk management

Comprehensive Examples

🎯 Combinatorial Optimization
🏭 Scheduling & Operations
📊 Quantitative Economics & Finance
🧮 Interactive Learning

🧪 Testing

Run the comprehensive test suite:

# Run all tests pytest # Run specific test categories pytest tests/test_z3_solver.py pytest tests/test_cvxpy_solver.py pytest tests/test_highs_solver.py pytest tests/test_ortools_solver.py pytest tests/test_mcp_server.py # Run with coverage pytest --cov=constrained_opt_mcp

📖 Documentation

🏗️ Architecture

Core Components

  1. Core Models (constrained_opt_mcp/core/) - Base classes and problem types
  2. Solver Models (constrained_opt_mcp/models/) - Problem-specific model definitions
  3. Solvers (constrained_opt_mcp/solvers/) - Solver implementations
  4. MCP Server (constrained_opt_mcp/server/) - MCP server implementation
  5. Examples (constrained_opt_mcp/examples/) - Usage examples and demos

Supported Problem Types

Problem TypeSolverUse Cases
Constraint SatisfactionZ3Logic puzzles, verification, planning
Convex OptimizationCVXPYPortfolio optimization, machine learning
Linear ProgrammingHiGHSProduction planning, resource allocation
Constraint ProgrammingOR-ToolsScheduling, assignment, routing
Portfolio OptimizationMultipleRisk management, portfolio construction

🤝 Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests for new functionality
  5. Run the test suite
  6. Submit a pull request

📄 License

This project is licensed under the Apache License 2.0. See the LICENSE file for details.

🆘 Support

For questions, issues, or contributions, please:

  1. Check the documentation
  2. Search existing issues
  3. Create a new issue
  4. Join our discussions

📈 Changelog

Version 1.0.0

  • Initial release
  • Support for Z3, CVXPY, HiGHS, and OR-Tools
  • Portfolio optimization examples
  • Comprehensive test suite
  • MCP server implementation
-
security - not tested
A
license - permissive license
-
quality - not tested

hybrid server

The server is able to function both locally and remotely, depending on the configuration or use case.

Enables solving complex combinatorial optimization problems with logical and numerical constraints through multiple solvers (Z3, CVXPY, HiGHS, OR-Tools). Specializes in portfolio optimization, scheduling, resource allocation, and constraint satisfaction problems.

  1. 🚀 Features
    1. 🛠️ Supported Solvers
      1. 📦 Installation
        1. 📐 Mathematical Foundations
          1. Optimization Theory
          2. Solver Capabilities
        2. 🚀 Quick Start
          1. 1. Run Examples
          2. 2. Start the MCP Server
          3. 3. Connect from AI Assistant
          4. 4. Use the Tools
        3. 📚 Examples
          1. Constraint Satisfaction Problem
          2. Portfolio Optimization
          3. Linear Programming
          4. Portfolio Examples
          5. Comprehensive Examples
        4. 🧪 Testing
          1. 📖 Documentation
            1. 🏗️ Architecture
              1. Core Components
              2. Supported Problem Types
            2. 🤝 Contributing
              1. 📄 License
                1. 🆘 Support
                  1. 📈 Changelog
                    1. Version 1.0.0

                  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/Sharmarajnish/MCP-Constrained-Optimization'

                  If you have feedback or need assistance with the MCP directory API, please join our Discord server