mirror of
https://github.com/ANL-CEEESA/MIPLearn.git
synced 2025-12-06 01:18:52 -06:00
Simply Pyomo solvers
This commit is contained in:
@@ -23,16 +23,22 @@ class BasePyomoSolver(InternalSolver):
|
|||||||
Base class for all Pyomo solvers.
|
Base class for all Pyomo solvers.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(
|
||||||
|
self,
|
||||||
|
solver_factory,
|
||||||
|
params,
|
||||||
|
):
|
||||||
self.instance = None
|
self.instance = None
|
||||||
self.model = None
|
self.model = None
|
||||||
self._all_vars = None
|
self._all_vars = None
|
||||||
self._bin_vars = None
|
self._bin_vars = None
|
||||||
self._is_warm_start_available = False
|
self._is_warm_start_available = False
|
||||||
self._pyomo_solver = None
|
self._pyomo_solver = solver_factory
|
||||||
self._obj_sense = None
|
self._obj_sense = None
|
||||||
self._varname_to_var = {}
|
self._varname_to_var = {}
|
||||||
self._cname_to_constr = {}
|
self._cname_to_constr = {}
|
||||||
|
for (key, value) in params.items():
|
||||||
|
self._pyomo_solver.options[key] = value
|
||||||
|
|
||||||
def solve_lp(self, tee=False):
|
def solve_lp(self, tee=False):
|
||||||
for var in self._bin_vars:
|
for var in self._bin_vars:
|
||||||
@@ -244,3 +250,6 @@ class BasePyomoSolver(InternalSolver):
|
|||||||
|
|
||||||
def get_sense(self):
|
def get_sense(self):
|
||||||
raise Exception("Not implemented")
|
raise Exception("Not implemented")
|
||||||
|
|
||||||
|
def set_branching_priorities(self, priorities):
|
||||||
|
raise Exception("Not supported")
|
||||||
|
|||||||
@@ -9,29 +9,27 @@ from .base import BasePyomoSolver
|
|||||||
|
|
||||||
|
|
||||||
class CplexPyomoSolver(BasePyomoSolver):
|
class CplexPyomoSolver(BasePyomoSolver):
|
||||||
def __init__(self, options=None):
|
"""
|
||||||
"""
|
An InternalSolver that uses CPLEX and the Pyomo modeling language.
|
||||||
Creates a new CPLEX solver, accessed through Pyomo.
|
|
||||||
|
|
||||||
Parameters
|
Parameters
|
||||||
----------
|
----------
|
||||||
options: dict
|
params: dict
|
||||||
Dictionary of options to pass to the Pyomo solver. For example,
|
Dictionary of options to pass to the Pyomo solver. For example,
|
||||||
{"mip_display": 5} to increase the log verbosity.
|
{"mip_display": 5} to increase the log verbosity.
|
||||||
"""
|
"""
|
||||||
super().__init__()
|
|
||||||
self._pyomo_solver = pe.SolverFactory("cplex_persistent")
|
def __init__(self, params=None):
|
||||||
self._pyomo_solver.options["randomseed"] = randint(low=0, high=1000).rvs()
|
super().__init__(
|
||||||
self._pyomo_solver.options["mip_display"] = 4
|
solver_factory=pe.SolverFactory("cplex_persistent"),
|
||||||
if options is not None:
|
params={
|
||||||
for (key, value) in options.items():
|
"randomseed": randint(low=0, high=1000).rvs(),
|
||||||
self._pyomo_solver.options[key] = value
|
"mip_display": 4,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
def _get_warm_start_regexp(self):
|
def _get_warm_start_regexp(self):
|
||||||
return "MIP start .* with objective ([0-9.e+-]*)\\."
|
return "MIP start .* with objective ([0-9.e+-]*)\\."
|
||||||
|
|
||||||
def _get_node_count_regexp(self):
|
def _get_node_count_regexp(self):
|
||||||
return "^[ *] *([0-9]+)"
|
return "^[ *] *([0-9]+)"
|
||||||
|
|
||||||
def set_branching_priorities(self, priorities):
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|||||||
@@ -15,22 +15,23 @@ logger = logging.getLogger(__name__)
|
|||||||
|
|
||||||
|
|
||||||
class GurobiPyomoSolver(BasePyomoSolver):
|
class GurobiPyomoSolver(BasePyomoSolver):
|
||||||
def __init__(self, options=None):
|
"""
|
||||||
"""
|
An InternalSolver that uses Gurobi and the Pyomo modeling language.
|
||||||
Creates a new Gurobi solver, accessed through Pyomo.
|
|
||||||
|
|
||||||
Parameters
|
Parameters
|
||||||
----------
|
----------
|
||||||
options: dict
|
params: dict
|
||||||
Dictionary of options to pass to the Pyomo solver. For example,
|
Dictionary of options to pass to the Pyomo solver. For example,
|
||||||
{"Threads": 4} to set the number of threads.
|
{"Threads": 4} to set the number of threads.
|
||||||
"""
|
"""
|
||||||
super().__init__()
|
|
||||||
self._pyomo_solver = pe.SolverFactory("gurobi_persistent")
|
def __init__(self, params=None):
|
||||||
self._pyomo_solver.options["Seed"] = randint(low=0, high=1000).rvs()
|
super().__init__(
|
||||||
if options is not None:
|
solver_factory=pe.SolverFactory("gurobi_persistent"),
|
||||||
for (key, value) in options.items():
|
params={
|
||||||
self._pyomo_solver.options[key] = value
|
"Seed": randint(low=0, high=1000).rvs(),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
def _extract_node_count(self, log):
|
def _extract_node_count(self, log):
|
||||||
return max(1, int(self._pyomo_solver._solver_model.getAttr("NodeCount")))
|
return max(1, int(self._pyomo_solver._solver_model.getAttr("NodeCount")))
|
||||||
|
|||||||
Reference in New Issue
Block a user