Share your thoughts, 1 month free Claude Pro on usSee more
WorkDL logo mark

Learning to branch with Tree MDPs

About

State-of-the-art Mixed Integer Linear Program (MILP) solvers combine systematic tree search with a plethora of hard-coded heuristics, such as the branching rule. The idea of learning branching rules from data has received increasing attention recently, and promising results have been obtained by learning fast approximations of the strong branching expert. In this work, we instead propose to learn branching rules from scratch via Reinforcement Learning (RL). We revisit the work of Etheve et al. (2020) and propose tree Markov Decision Processes, or tree MDPs, a generalization of temporal MDPs that provides a more suitable framework for learning to branch. We derive a tree policy gradient theorem, which exhibits a better credit assignment compared to its temporal counterpart. We demonstrate through computational experiments that tree MDPs improve the learning convergence, and offer a promising framework for tackling the learning-to-branch problem in MILPs.

Lara Scavuzzo, Feng Yang Chen, Didier Ch\'etelat, Maxime Gasse, Andrea Lodi, Neil Yorke-Smith, Karen Aardal• 2022

Related benchmarks

TaskDatasetResultRank
MILP SolvingMaximum independent set larger size (transfer)
Search Tree Nodes2.76e+3
10
MILP SolvingCombinatorial auctions (test)
Search Tree Nodes86.1
10
MILP SolvingCombinatorial auctions larger size (transfer)
Nodes Explored1.80e+3
10
MILP SolvingSet covering same size as training (test)
Search Tree Nodes190.8
10
MILP SolvingSet covering transfer larger size
Nodes Explored816.8
10
MILP SolvingMaximum independent set same size as training (test)
Search Tree Nodes85.4
10
Mixed Integer Linear Programming BranchingMILP Standard Suite (test)
Set Covering Time (s)2.32
10
Mixed Integer Linear Programming BranchingMILP Suite Transfer instances Standard
Set Covering Time (s)221
10
MILP SolvingMaximum independent set Transfer
Nodes Explored3.13e+3
9
MILP SolvingMaximum independent set (train)
Nodes Explored153.6
9
Showing 10 of 24 rows

Other info

Code

Follow for update