Copyright (C) 2013-2015, Filipe Brandão
Faculdade de Ciencias, Universidade do Porto
Porto, Portugal. All rights reserved. E-mail: [email protected].
VPSolver is a vector packing solver based on an arc-flow formulation with graph compression. VPSolver generates very strong models (equivalent to Gilmore and Gomory's) that can be solved using general-purpose mixed-integer programming solvers such as Gurobi and GLPK [1]. VPSolver does not explicitly require any MIP solver in particular, though a good MIP solver may be necessary for solving large models.
For modelling other problems easily, VPSolver includes a Python API, a modelling language PyMPL, and a Web App. VPSolver has been successfully compiled and run on Linux and Mac OS X. VPSolver also runs on a large variety of platforms including Windows using a Docker container.
For more details, please refer to the project wiki or to the manual.
- Project Homepage: http://vpsolver.dcc.fc.up.pt/
- GiHub repository: https://github.com/fdabrandao/vpsolver
- BitBucket repository: https://bitbucket.org/fdabrandao/vpsolver
- Docker repository: https://hub.docker.com/r/fdabrandao/vpsolver/
- MIP solver: Gurobi, CPLEX, GLPK, COIN-OR, SCIP, lp_solve, ...
g++ >= 4.8
make >= 3.81
For the Python API and Web App:
python-2.7
python-pip
python-dev
python-pygraphviz
glpk-utils
It has been successfully compiled and run on the following platforms:
- Linux
- Mac OS X
- On a large variety of platforms including Windows using a Docker container.
Without the python interface:
$ bash build.sh
With the python interface:
$ bash build.sh
$ sudo pip install -r requirements.txt
$ sudo pip install . --upgrade
$ bash test.sh test_install
or simply:
$ bash install.sh
$ bash test.sh test_install
Docker is an open platform for building, shipping and running applications. Docker allows VPSolver to run on a large variety of platforms with very little effort.
Install Docker [Docker installation instructions].
Option 1: simply pull
VPSolver from Docker repository (without building):
$ docker pull fdabrandao/vpsolver
Option 2: clone
VPSolver and build
locally:
$ git clone [email protected]:fdabrandao/vpsolver.git vpsolver
$ docker build -t fdabrandao/vpsolver vpsolver
Directly using the command line interface:
$ docker run -it fdabrandao/vpsolver bash
root@55d14f6b6f32:~# python examples/vpsolver/example_vbp.py
...
or through the VPSolver Web App (example URL: http://172.17.0.60:5555/
):
$ docker run -it -p 5555 fdabrandao/vpsolver
eth0 Link encap:Ethernet HWaddr 02:42:ac:11:00:3c
inet addr:*172.17.0.60* Bcast:0.0.0.0 Mask:255.255.0.0
inet6 addr: fe80::42:acff:fe11:3c/64 Scope:Link
UP BROADCAST MTU:1500 Metric:1
RX packets:2 errors:0 dropped:0 overruns:0 frame:0
TX packets:2 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:168 (168.0 B) TX bytes:180 (180.0 B)
* Running on http://0.0.0.0:5555/
...
For more details, please refer to the project wiki [https://github.com/fdabrandao/vpsolver/wiki/docker].
VPSolver includes a Web App that can be started as follows:
$ python -m pyvpsolver.webapp.app
The Web App can then be accessed on a web browser at http://127.0.0.1:5555/
.
$ bin/vpsolver intance.vbp
: solves a vector packing instance using the method proposed in [1]. Note: requires Gurobi 5.0.0 or superior;$ bin/vbp2afg instance.vbp graph.afg
: builds an arc-flow graphgraph.afg
forinstance.vbp
;$ bin/afg2mps graph.afg model.mps
: creates a MPS modelmodel.mps
forgraph.afg
;$ bin/afg2lp graph.afg model.lp
: creates a LP modelmodel.lp
forgraph.afg
;$ bin/solve_gurobi model.mps vars.sol
: solvesmodel.mps
using Gurobi and writes the solution tovars.sol
;$ bin/solve_glpk model.mps vars.sol
: solvesmodel.mps
using GLPK and writes the solution tovars.sol
;$ bin/vbpsol graph.afg vars.sol
: extracts a vector packing solution from an arc-flow solutionvars.sol
associated with the graphgraph.afg
.
Usage:
# 1. Build the arc-flow graph graph.afg for example.vbp:
$ bin/vbp2afg example.vbp graph.afg
# 2. Convert the arc-flow graph into a .mps file model.mps:
$ bin/afg2mps graph.afg model.mps
# 3. Solve the MIP model and stores the solution in vars.sol:
$ bin/solve_gurobi model.mps vars.sol
# 4. Extract the vector packing solution:
$ bin/vbpsol graph.afg vars.sol
VPSolver includes several scripts for solving arc-flow models using different solvers:
scripts/vpsolver_gurobi.sh
: Gurobiscripts/vpsolver_cplex.sh
: IBM CPLEXscripts/vpsolver_coinor.sh
: COIN-OR CBCscripts/vpsolver_glpk.sh
: GLPKscripts/vpsolver_scip.sh
: SCIPscripts/vpsolver_lpsolve.sh
: lp_solve
Usage:
$ vpsolver_X.sh --vbp instance.vbp
$ vpsolver_X.sh --afg graph.afg
$ vpsolver_X.sh --mps/--lp model.mps/.lp
$ vpsolver_X.sh --mps/--lp model.mps/.lp --afg graph.afg
docs/
: documentationbin/
: vpsolver executablesscripts/
: vpsolver scriptssrc/
: vpsolver source code in C++pyvpsolver/
: pyvpsolver source code in Python 2.7examples/
: vpsolver and pyvpsolver examplesreports/
: technical reports on the underlying algorithms and models
VPSolver was proposed in:
- [1] Brandão, F. and Pedroso, J. P. (2013). Bin Packing and Related Problems: General Arc-flow Formulation with Graph Compression. Technical Report DCC-2013-08, Faculdade de Ciências da Universidade do Porto, Universidade do Porto, Portugal. Available at: http://arxiv.org/abs/1310.6887.
See also:
-
[2] Brandão, F. and Pedroso, J. P. (2013). Multiple-choice Vector Bin Packing: Arc-flow Formulation with Graph Compression. Technical Report DCC-2013-13, Faculdade de Ciências da Universidade do Porto, Universidade do Porto, Portugal.
-
[3] Brandão, F. and Pedroso, J. P. (2013). Cutting Stock with Binary Patterns: Arc-flow Formulation with Graph Compression. Technical Report DCC-2013-09, Faculdade de Ciências da Universidade do Porto, Universidade do Porto, Portugal.
-
[4] Brandão, F. (2012). Bin Packing and Related Problems: Pattern-Based Approaches Master’s thesis, Faculdade de Ciências da Universidade do Porto, Portugal.
-
[5] Computational results on several benchmark test data sets:
http://www.dcc.fc.up.pt/~fdabrandao/research/vpsolver/results/
Copyright © Filipe Brandão. All rights reserved.
E-mail: [email protected]. [Homepage]