Skip to main content

PyTorch-based End-to-End Predict-then-Optimize Tool

Project description

PyEPO: A PyTorch-based End-to-End Predict-then-Optimize Tool

PyEPO (PyTorch-based End-to-End Predict-then-Optimize Tool) is a Python-based, open-source software that supports modeling and solving predict-then-optimize problems with linear objective functions. The core capability of PyEPO is to build optimization models with GurobiPy, COPT, Pyomo, Google OR-Tools, MPAX, or any other solvers and algorithms, then embed the optimization model into an artificial neural network for the end-to-end training. For this purpose, PyEPO implements various methods as PyTorch autograd modules.

Features

  • Implement SPO+, PG, DPO (additive and multiplicative perturbations), PFYL (additive and multiplicative perturbations), I-MLE, AI-MLE, L2-regularized RFWO/RFYL, DBB, NID, CaVE, NCE, and LTR
  • Support Gurobi, COPT, Pyomo, Google OR-Tools, and MPAX API
  • Symbolic modeling with pyepo.dsl: define an LP, MIP, or QP once, then compile it to any backend
  • JAX frontend (pyepo.func.jax): train any loss in JAX/Flax with jax.grad
  • Support parallel computing for optimization solvers
  • Support solution caching to speed up training
  • Support kNN robust loss to improve decision quality

CaVE for Binary Linear Programs

For end-to-end learning on binary linear programs (TSP, CVRP, knapsack, ...), PyEPO ships CaVE. CaVE replaces the per-step ILP solve with a cone-alignment projection onto the binding-constraint normals at the true optimum, backed by an interior-point QP solver (Clarabel). Because the cone projection is far cheaper than the per-instance ILP solve, CaVE trains an order of magnitude faster than SPO+ at TSP scale.

GPU-Accelerated Solving with MPAX

PyEPO integrates MPAX, a JAX-based mathematical programming solver using the PDHG algorithm for GPU-accelerated optimization. Key advantages: (1) GPU-native solving — the first-order PDHG method runs efficiently on GPU; (2) batch solving — an entire mini-batch can be solved simultaneously via vectorization; (3) no GPU-CPU data transfer overhead — both the neural network and the solver stay on GPU, eliminating the data transfer bottleneck.

Documentation

The official docs can be found at https://khalil-research.github.io/PyEPO.

Publication

PyEPO: A PyTorch-based End-to-End Predict-then-Optimize Library for Linear and Integer Programming (Mathematical Programming Computation)

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

pyepo-2.2.3.tar.gz (162.5 kB view details)

Uploaded Source

Built Distribution

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

pyepo-2.2.3-py3-none-any.whl (160.5 kB view details)

Uploaded Python 3

File details

Details for the file pyepo-2.2.3.tar.gz.

File metadata

  • Download URL: pyepo-2.2.3.tar.gz
  • Upload date:
  • Size: 162.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pyepo-2.2.3.tar.gz
Algorithm Hash digest
SHA256 b7b9f6f75811cad172e02fc5f5591dca05edca93090a7da5768926219816f894
MD5 dc7a6e1407087b73b431b001086214bf
BLAKE2b-256 13de01c6756ee126128719f1d2631bc7e09649a8493e1715b94e49736280d703

See more details on using hashes here.

File details

Details for the file pyepo-2.2.3-py3-none-any.whl.

File metadata

  • Download URL: pyepo-2.2.3-py3-none-any.whl
  • Upload date:
  • Size: 160.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pyepo-2.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5e76a218391d615e8c8c416b266179af8957721a63f614c2e6d78d473c72f1a8
MD5 b9f064cce44eb9b2a0faf6505de2423b
BLAKE2b-256 a2242b4d77a9256d3ca6df3897a8881d83d0212133924b7758fd035f80c217e6

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