Cutting Plane Methods in Python (CuPPy)
Project description
A collection of ‘naive’ implementations of basic cutting plane algorithms in Python. The collection contains a generator for Gomory Mixed Integer cuts and one for generating the most violated split cut using the method of Saxena and Balas.
The idea is for these implementations to be as transparent as possible. I intend them mainly for educational use. They will most certainly not be effective in a real-world environment. Even on small examples, it is easy to run into numerical difficulties.
The underlying solvers are Clp (https://projects.coin-or.org/Clp) and Cbc (https://projects.coin-or.org/Cbc), which is called via the Python bindings of CyLP (https://github.com/coin-or/CyLP). Through CyLP, one can easily add these as cut generators within Cbc.
The cutting plane procedure can be visualized for 2D examples using the polyhedron2D class of GrUMPy (https://github.com/coin-or/GrUMPy).
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 Distributions
Built Distribution
File details
Details for the file coinor.cuppy-0.9.3-py3-none-any.whl
.
File metadata
- Download URL: coinor.cuppy-0.9.3-py3-none-any.whl
- Upload date:
- Size: 22.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 934d631031a37845386cf7625efc6f2c6c6b301b068ff4963de8b5f27faa7064 |
|
MD5 | d08f2c6677623f8cea4abae90a3d042d |
|
BLAKE2b-256 | 8b46713dbd994bafe5352aff860fc1a63ff805fffc18f6ab4cb180b848f0ed3c |