Model analysis tools for explaining ill-conditioning and analyzing solutions.
Project description
Gurobi Model Analyzer
Gurobi Model Analyzer is an open-source python package that provides detailed analysis of model solutions and model characteristics. It consists of a results_analyzer module that calculates explanations of ill-conditioned basis matrices and a solcheck module that analysizes a given solution.
Documentation
The latest user manual is available on readthedocs.
Contact us
For questions related to using Gurobi Model Analyzer, please use Gurobi's Forum.
For reporting bugs, issues, and feature requests please open an issue.
If you encounter issues with Gurobi or gurobipy please contact Gurobi Support.
Installation
Dependencies
- Python >= 3.9
numpy
>= 1.21.5 (although earlier versions compatible with python 3.7 will probably work).- questionary for the (optional) interactive version
Pip installation
The easiest way to install gurobi-modelanalyzer is using pip in a virtual environment:
(.venv) pip install gurobi-modelanalyzer
This will also install the numpy and gurobipy dependencies. One of the advanced functions makes use of matplotlib; if you haven't already installed that and plan to use this function (matrix_bitmap), you can either install the matplotlib package directly, or install it with the gurobi-modelanalyzer package via "pip install gurobi-modelanalyzer matplotlib".
Please note that gurobipy is commercial software and requires a license. When installed via pip or conda, gurobipy ships with a free license for testing and can only solve models of limited size.
Example usage
Using the explainer functions
import gurobipy as gp
import gurobi_modelanalyzer as gma
model = gp.read("myillconditionedmodel.mps")
model.optimize()
gma.kappa_explain(model)
# row-based explanation (default)
gma.kappa_explain(model, expltype="ROWS")
# column-based explanation
gma.kappa_explain(model, expltype="COLS")
# angle-based explanation (only looks for pairs of rows or columns
# that cause ill-conditioning.
gma.angle_explain(model)
Use help(gma.kappa_explain)
or help(gma.angle_explain)
for information
on more advanced usage.
Using the solution checker
Testing a suboptimal solution
import gurobipy as gp
import gurobi_modelanalyzer as gma
m = gp.read("examples/data/afiro.mps")
sol = {m.getVarByName("X01"): 78, m.getVarByName("X22"): 495}
sc = gma.SolCheck(m)
sc.test_sol(sol)
print(f"Solution Status: {sc.Status}")
sc.optimize()
for v in sol.keys():
print(f"{v.VarName}: Fixed value: {sol[v]}, Computed value: {v.X}")
Testing an infeasible solution
m = gp.read("examples/data/misc07.mps")
sol = {m.getVarByName("COL260"): 2400.5}
sc = gma.sol_check(m)
sc.test_sol(sol)
print(f"Solution Status: {sc.Status}")
sc.inf_repair()
for c in m.getConstrs():
if abs(c._Violation) > 0.0001:
print(f"{c.ConstrName}: RHS: {c.RHS}, Violation: {c._Violation}")
Getting a Gurobi License
Alternatively to the bundled limited license, there are licenses that can handle models of all sizes.
As a student or staff member of an academic institution, you qualify for a free, full-product license. For more information, see:
For a commercial evaluation, you can request an evaluation license.
Other useful resources to get started:
Development
We value any level of experience in using Gurobi Model Analyzer and would like to encourage you to contribute directly to this project. Please see the Contributing Guide for more information.
Submitting a Pull Request
Before opening a Pull Request, have a look at the full Contributing page to make sure your code complies with our guidelines.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file gurobi_modelanalyzer-2.1.0.tar.gz
.
File metadata
- Download URL: gurobi_modelanalyzer-2.1.0.tar.gz
- Upload date:
- Size: 2.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6cbf564be36120a2ad5d9a4c658a143a90513ae4b20cebb52b9ab5e079fce8fc |
|
MD5 | e4fd2e937b84849f1403cb0ca903d940 |
|
BLAKE2b-256 | 6f315c3ff559008969f8884d51d0a7f748221454597af8bec5ad9876a94fbe61 |
File details
Details for the file gurobi_modelanalyzer-2.1.0-py3-none-any.whl
.
File metadata
- Download URL: gurobi_modelanalyzer-2.1.0-py3-none-any.whl
- Upload date:
- Size: 44.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cc6754a545953a727dd6897eafcb6a48c678fd3d87f4f1661cb777e556b876d4 |
|
MD5 | cc25d98795174c6c9224abebcbc9af87 |
|
BLAKE2b-256 | 84f53489ecd4ae4bdfc3b16a9d2d4122a4ba792cfe8fa145a46e146d4b3231de |