Hacker News new | past | comments | ask | show | jobs | submit login

Good stuff. That's pretty nice to re-use the existing ROI solver bindings. I can see there's also an experimental ROI plugin for Gurobi (https://github.com/kuol/ROI.plugin.gurobi ) - my former MIP-loving colleagues used to delight in how much better Gurobi seemed to perform then CPLEX.

Similarly, if anyone uses python and is interested in solving similar problems you may find the following links useful:

https://pythonhosted.org/PuLP/

http://cvxopt.org/ http://www.cvxpy.org/en/latest/ (not MIPs but able to tackle a variety of convex optimisation problems)

I think once you start getting into harder optimisation problems then sometimes you need to take advantage of the APIs offered by specific solvers (e.g. for lazy constraint generation using callbacks) which tends to get in the way of using a lot of this, but these DSLs + common solver interfaces are pretty nice for prototyping and rapid development during projects while the definition of what optimisation problem you're meant to be solving is still oscillating...




Is there any documentation for Gurobi being much better for MILP than CPLEX? I'd be very interested in those details.


a good place for MIP solver comparisons (including expensive commercial solvers like Gurobi and CPLEX, as well as other commercial and open source options) is Hans Mittelmann's website:

http://plato.asu.edu/bench.html

here are MILP current benchmark results (updated this month) including CPLEX and Gurobi

http://plato.asu.edu/ftp/milpc.html

If you are interested in which is the best (fastest? finds feasible solutions most often?) solver for a particular kind of problem, these general benchmarks perhaps don't matter as much - you need to compare the solvers on instances of your problem.

edit: i think it is possible to get free trials of commercial solvers if you are interested in trying them on your problems. Gurobi also appears to have a cloud offering where you can pay to rent a solver for a short time.


Thanks for the help. My company uses CPLEX in production on some massive models with a lot of constraints. I'm always curious if Gurobi would be better, but I'm not sure how much work it would be to port it to run on a trial version of Gurobi on the same hardware.

Edit: What are the numbers in the links provided? Number of solved cases or time?




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: