Learning to branch in mixed integer programming

297Citations
Citations of this article
295Readers
Mendeley users who have this article in their library.

Abstract

The design of strategies for branching in Mixed Integer Programming (MIP) is guided by cycles of parameter tuning and offline experimentation on an extremely heterogeneous testbed, using the average performance. Once devised, these strategies (and their parameter settings) are essentially input-Agnostic. To address these issues, we propose a machine learning (ML) framework for variable branching in MIP. Our method observes the decisions made by Strong Branching (SB), a time-consuming strategy that produces small search trees, collecting features that characterize the candidate branching variables at each node of the tree. Based on the collected data, we learn an easy-To-evaluate surrogate function that mimics the SB strategy, by means of solving a learning-To-rank problem, common in ML. The learned ranking function is then used for branching. The learning is instance-specific, and is performed on-The-fly while executing a branch-And-bound search to solve the instance. Experiments on benchmark instances indicate that our method produces significantly smaller search trees than existing heuristics, and is competitive with a state-of-The-Art commercial solver.

Cite

CITATION STYLE

APA

Khalil, E. B., Bodic, P. L., Song, L., Nemhauser, G., & Dilkina, B. (2016). Learning to branch in mixed integer programming. In 30th AAAI Conference on Artificial Intelligence, AAAI 2016 (pp. 724–731). AAAI press. https://doi.org/10.1609/aaai.v30i1.10080

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free