-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSolverSetup.py
144 lines (119 loc) · 5.42 KB
/
SolverSetup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
# This file is part of GenMap and released under the MIT License, see LICENSE.
# Author: Takuya Kojima
import os
import pulp
import cvxpy as cp
try:
import mosek as MOSEK
except ImportError:
MOSEK = None
class SolverSetup():
class SolverSetupError(Exception):
pass
def __init__(self, sol_type, threads = 1):
self.__sol_type_list = ["ILP", "CP"]
self.__threads = threads
self.__ilp_solver_setup = {"gurobi": self.__gurobi_ilp_setup,
"mosek": self.__mosek_ilp_setup,
"cbc": self.__cbc_ilp_setup}
self.__cp_solver_setup = {"ecos": self.__ecos_cp_setup,
"scs": self.__scs_cp_setup,
"mosek": self.__mosek_cp_setup}
if not sol_type in self.__sol_type_list:
raise ValueError("sol_type must be in " +\
str(self.__sol_type_list))
self.__solver = None
if sol_type == "ILP":
# Integer Linear Program
self.__setup_ilp()
elif sol_type == "CP":
# Convex Optimization Program
self.__setup_cp()
def getSolver(self):
return self.__solver
def __mosek_lic_check(self):
prob = pulp.LpProblem("test", pulp.LpMinimize)
x = pulp.LpVariable("x", 0, 1, pulp.LpContinuous)
prob += x
prob += x <= 1
try:
prob.solve(self.__solver)
except MOSEK.Error as e:
print(e)
return False
return True
def __setup_cp(self):
# supported solvers: ecos, scs, mosek
solver = os.getenv("GMP_CP_SOLVER")
if solver is None:
solver = "ecos"
if not solver.lower() in self.__cp_solver_setup.keys():
print("WARN: CP solver specified by the GMP_CP_SOLVER:",
solver, "is not supported. The default solver (ecos) is used")
solver = "ecos"
self.__cp_solver_setup[solver.lower()]()
def __setup_ilp(self):
# supported solvers: cbc, gurobi, mosek
solver = os.getenv("GMP_ILP_SOLVER")
if solver is None:
# default
solver = "cbc"
if not solver.lower() in self.__ilp_solver_setup.keys():
print("WARN: ILP solver specified by the GMP_ILP_SOLVER:",
solver, "is not supported. The default solver (cbc) is used")
solver = "cbc"
self.__ilp_solver_setup[solver.lower()]()
def __gurobi_ilp_setup(self):
self.__solver = pulp.GUROBI_CMD(msg = False, \
threads = self.__threads)
if not self.__solver.available():
raise SolverSetup.SolverSetupError\
("Gurobi is not available. Please check PATH setting and" +
" make sure gurobi is installed and you have a valid license")
def __mosek_ilp_setup(self):
# check installation
if MOSEK is None:
raise SolverSetup.SolverSetupError("mosek is not installed. " + \
"Please install mosek's python API like 'pip install mosek'")
# check multithread option
options = {MOSEK.iparam.num_threads: self.__threads,
MOSEK.iparam.intpnt_multi_thread: \
MOSEK.onoffkey.off,\
MOSEK.dparam.mio_max_time: 3600.0}
self.__solver = pulp.MOSEK(msg=False, options = options)
if not self.__solver.available():
raise SolverSetup.SolverSetupError("Unexpected error: fails to setup mosek")
# check license
if not self.__mosek_lic_check():
raise SolverSetup.SolverSetupError("Please check your license for mosek")
def __cbc_ilp_setup(self):
self.__solver = pulp.PULP_CBC_CMD(msg = False,\
threads = self.__threads if self.__threads > 1 \
else None)
def __ecos_cp_setup(self):
if not "ECOS" in cp.installed_solvers():
raise SolverSetup.SolverSetupError\
("ECOS is not installed.")
print("WARN: ECOS might be fail to solve a convex problem for a certain condition")
self.__solver = {"solver": "ECOS", "verbose": False}
def __scs_cp_setup(self):
if not "SCS" in cp.installed_solvers():
raise SolverSetup.SolverSetupError\
("SCS is not installed.")
print("WARN: SCS might be fail to solve a convex problem for a certain condition")
self.__solver = {"solver": "SCS", "verbose": False}
def __mosek_cp_setup(self):
if not "MOSEK" in cp.installed_solvers() or MOSEK is None:
raise SolverSetup.SolverSetupError\
("mosek is not installed. " + "Please install mosek's python API like 'pip install mosek'")
solver = {"solver": "MOSEK", "verbose": False}
mt_flag = MOSEK.onoffkey.on if self.__threads > 1 else \
MOSEK.onoffkey.off
solver["mosek_params"] = {MOSEK.iparam.num_threads: self.__threads,
MOSEK.iparam.intpnt_multi_thread: mt_flag }
# check license
self.__solver = pulp.MOSEK(msg=False)
if not self.__mosek_lic_check():
self.__solver = None
raise SolverSetup.SolverSetupError("Please check your license for mosek")
self.__solver = solver