-
Notifications
You must be signed in to change notification settings - Fork 26
Python API
The VPSolver Python API has 3 levels:
- High-level API: high level wrapper functions (easy and direct usage);
- Mid-level API: objects that wrap calls to VPSolver executables;
- Low-level API: direct calls to VPSolver scripts and executables.
Example:
from pyvpsolver.solvers import vbpsolver
W = (5180, 2)
w = [(1120,1), (1250,1), (520,1), (1066,1), (1000,1), (1150,1)]
b = [9, 5, 91, 18, 11, 64]
# Solve a vector packing instance:
obj, sol = vbpsolver.solve(
W, w, b, script="vpsolver_glpk.sh", verbose=False
)
# Print the solution:
vbpsolver.print_solution(obj, sol)
The high level API (pyvpsolver.solvers
) includes:
-
vbpsolver
- for vector packing; -
mvpsolver
- for multiple-choice vector packing; - additional solvers for other applications will be added soon.
How to import:
-
from pyvpsolver.solvers import vbpsolver
.
How to use:
-
obj, sol = vbpsolver.solve(W, w, b, script=None, script_options=None, verbose=None)
- Important parameters:
-
W
: bin capacity; -
w
: item weights; -
b
: item demands; -
script
: VPSolver script that should be used to solve the model; -
script_options
: options to pass to the script (optional).
-
- Returns:
-
obj
: objective value; -
sol
: solution.
-
- Important parameters:
-
vbpsolver.print_solution(obj, lst_sol)
- Important parameters:
-
obj
: objective value; -
lst_sol
: solution.
-
- Outputs:
- The solution formatted.
- Important parameters:
Examples: example_vbp.py.
How to import:
-
from pyvpsolver.solvers import mvpsolver
.
How to use:
-
obj, lst_sol = mvpsolver.solve(Ws, Cs, Qs, ws, b, script=None, script_options=None, verbose=False)
- Important parameters:
-
Ws
: bin capacities for each bin type; -
Cs
: bin costs for each bin type; -
Qs
: number of bins available for each type (-1 if infinity); -
ws
: item weights; -
b
: item demands; -
script
: VPSolver script that should be used to solve the model; -
script_options
: options to pass to the script (optional).
-
- Returns:
-
obj
: objective value; -
lst_sol
: a list of solutions for each bin type.
-
- Important parameters:
-
mvpsolver.print_solution(obj, lst_sol)
- Important parameters:
-
obj
: objective value -
sol
: solution
-
- Outputs:
- The solution formatted.
- Important parameters:
Examples: example_mvp.py and example_vsbpp.py.
Example:
from pyvpsolver import VPSolver # from the low-level API
from pyvpsolver import VBP, AFG, MPS, LP # from the mid-level API
from pyvpsolver.solvers import vbpsolver # from the high-level API
# Create a vector packing instance:
instance = VBP(
(5180,), # bin capacity
[(1120,), (1250,), (520,), (1066,), (1000,), (1150,)], # item weights
[9, 5, 91, 18, 11, 64] # item demands
)
# Create an arc-flow graph for the instance:
afg = AFG(instanceA, verbose=True)
# Create .mps model for the graph:
mps_model = MPS(afg, verbose=False)
# Solve the model an extract the solution:
out, solution = VPSolver.script("vpsolver_glpk.sh", mps_model, afg, verbose=True)
# Print the solution:
obj, sol = solution
vbpsolver.print_solution(obj, sol)
How to import:
-
from pyvpsolver import VBP, MVP, AFG, MPS, LP
.
Objects:
-
VBP
objects:VBP(W, w, b, binary=False, verbose=False)
- Important parameters:
-
W
: bin capacity; -
w
: item weights; -
b
: item demands; -
binary
: binary patterns (ifTrue
) or general integer patterns (ifFalse
).
-
- Important parameters:
-
MVP
objects:MVP(Ws, Cs, Qs, ws, b, binary=False, verbose=False)
- Important parameters:
-
Ws
: bin capacities for each bin type; -
Cs
: bin costs for each bin type; -
Qs
: number of bins available for each type (-1 if infinity); -
ws
: list of lists of weights of item incarnations; -
b
: item demands; -
binary
: binary patterns (ifTrue
) or general integer patterns (ifFalse
).
-
- Important parameters:
-
AFG
objects:AFG(instance, verbose=None)
- Important parameters:
-
instance
: aVBP
/MVP
object.
-
- Creates:
- an arc-flow graph for the vector packing instance.
- Important parameters:
-
MPS
objects:MPS(graph, verbose=None)
- Important parameters:
-
graph
: anAFG
object.
-
- Creates:
- an MPS model.
- Important parameters:
-
LP
objects:LP(graph, verbose=None)
- Important parameters:
-
graph
: anAFG
object.
-
- Creates:
- a LP model.
- Important parameters:
Examples: example.py.
How to import:
-
from pyvpsolver import VPSolver
.
How to use:
-
VPSolver.vbp2afg(vbp_file, afg_file, verbose=None)
- Description: creates arc-flow graphs for vector packing instances.
- Important parameters:
-
vbp_file
: a .vbp file or aVBP
object; -
afg_file
: a .afg file.
-
- Actions:
- calls
bin/vbp2afg
to write an arc-flow graph forvbp_file
inafg_file
.
- calls
-
VPSolver.afg2mps(afg_file, mps_file, verbose=None)
- Description: converts arc-flow grafts to MPS models.
- Important parameters:
-
afg_file
: a .afg file or aAFG
object; -
mps_file
: a .mps file.
-
- Actions:
- calls
bin/afg2mps
to write the MPS model forafg_file
inmps_file
.
- calls
-
VPSolver.afg2lp(afg_file, lp_file, verbose=None)
- Description: converts arc-flow grafts to LP models.
- Important parameters:
-
afg_file
: a .afg file or aAFG
object; -
mps_file
: a .lp file.
-
- Actions:
- calls
bin/afg2lp
to write the LP model forafg_file
inlp_file
.
- calls
-
VPSolver.vbpsol(afg_file, sol_file, verbose=None)
- Description: extracts a vector packing solution from an arc-flow solution.
- Important parameters:
-
afg_file
: a .afg file or aAFG
object; -
sol_file
: a .sol solution file.
-
- Actions:
- calls
bin/vbpsol
to extract the vector packing solution from the arc-flow solutionsol_file
associated with the graphafg_file
.
- calls
-
VPSolver.vpsolver(vbp_file, verbose=None)
- Description: calls VPSolver.
- Important parameters:
-
vbp_file
: a .vbp file or aVBP
object;.
-
- Actions:
- calls
bin/vpsolver
to solve an instance (requires Gurobi).
- calls
-
output, solution = VPSolver.script(script_name, arg1=None, arg2=None, verbose=None)
- Description: calls VPSolver scripts.
- Important parameters:
-
script_name
: vpsolver script name (e.g.,vpsolver_glpk.sh
); -
arg1
,arg2
: parameters to be passed to the script.
-
- Actions:
- calls
script_name
to solve an instance.
- calls
- Usage examples:
-
VPSolver.script(script name, .vbp file/VBP object)
; -
VPSolver.script(script name, .mps file/MPS object)
; -
VPSolver.script(script name, .afg file/VBP object)
; -
VPSolver.script(script name, .lp file/LP object)
; -
VPSolver.script(script name, .mps file/.lp file/MPS object/LP object, .afg file/AFG object)
. - Note: the solution can only be extracted if the graph or the original instance are provided.
-
-
VPSolver.set_verbose(verbose)
- Description: sets the default "verbose" behaviour.
- Parameters:
-
verbose
:True
orFalse
.
-
- Note: The default behavior is overridden if the
verbose
parameter is set to a value different fromNone
in any API call.
Copyright © Filipe Brandão. All rights reserved.
E-mail: [email protected]. [Homepage]