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.
- 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
Z3
- SMT solver for constraint satisfaction problemsCVXPY
- Convex optimization solverHiGHS
- Linear and mixed-integer programming solverOR-Tools
- Constraint programming solver
# 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 .
The Constrained Optimization MCP Server implements solutions for various classes of optimization problems:
Where
Find
Where:
-
$w$ : portfolio weights -
$\mu$ : expected returns -
$\Sigma$ : covariance matrix -
$\lambda$ : risk aversion parameter
Problem Type | Solver | Complexity | Mathematical Form |
---|---|---|---|
Constraint Satisfaction | Z3 | NP-Complete | Logical constraints |
Convex Optimization | CVXPY | Polynomial | Convex functions |
Linear Programming | HiGHS | Polynomial | Linear constraints |
Constraint Programming | OR-Tools | NP-Complete | Discrete domains |
# 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
constrained-opt-mcp
Add the server to your MCP configuration:
{
"mcpServers": {
"constrained-opt-mcp": {
"command": "constrained-opt-mcp",
"args": []
}
}
}
The server provides the following tools:
solve_constraint_satisfaction
- Solve logical constraint problemssolve_convex_optimization
- Solve convex optimization problemssolve_linear_programming
- Solve linear programming problemssolve_constraint_programming
- Solve constraint programming problemssolve_portfolio_optimization
- Solve portfolio optimization problems
# 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
# 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
# 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 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
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
- N-Queens Problem - Classic constraint satisfaction with chessboard visualization
- Knapsack Problem - 0/1 and multiple knapsack variants with performance analysis
- Job Shop Scheduling - Multi-machine production scheduling with Gantt charts
- Nurse Scheduling - Complex workforce scheduling with fairness constraints
- Portfolio Optimization - Advanced strategies including Markowitz, Black-Litterman, Risk Parity, and ESG-constrained optimization
- Economic Production Planning - Multi-period supply chain optimization with inventory management
- Comprehensive Demo Notebook - Interactive Jupyter notebook with all solver types and visualizations
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
- API Reference - Complete API documentation
- Examples - Comprehensive examples and demos
- Jupyter Notebook - Interactive demo notebook
- PDF Documentation - Comprehensive PDF guide with theory, examples, and implementation details
- Journal-Style PDF - Academic paper format with literature review, mathematics, and research contributions
- Core Models (
constrained_opt_mcp/core/
) - Base classes and problem types - Solver Models (
constrained_opt_mcp/models/
) - Problem-specific model definitions - Solvers (
constrained_opt_mcp/solvers/
) - Solver implementations - MCP Server (
constrained_opt_mcp/server/
) - MCP server implementation - Examples (
constrained_opt_mcp/examples/
) - Usage examples and demos
Problem Type | Solver | Use Cases |
---|---|---|
Constraint Satisfaction | Z3 | Logic puzzles, verification, planning |
Convex Optimization | CVXPY | Portfolio optimization, machine learning |
Linear Programming | HiGHS | Production planning, resource allocation |
Constraint Programming | OR-Tools | Scheduling, assignment, routing |
Portfolio Optimization | Multiple | Risk management, portfolio construction |
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Run the test suite
- Submit a pull request
This project is licensed under the Apache License 2.0. See the LICENSE file for details.
For questions, issues, or contributions, please:
- Check the documentation
- Search existing issues
- Create a new issue
- Join our discussions
- Initial release
- Support for Z3, CVXPY, HiGHS, and OR-Tools
- Portfolio optimization examples
- Comprehensive test suite
- MCP server implementation