Traversing combinatorial 0/1-polytopes via optimization
Abstract
--- - In this paper, we present a new framework that exploits combinatorial optimization for efficiently generating a large variety of combinatorial objects based on graphs, matroids, posets and polytopes. Our method relies on a simple and versatile algorithm for computing a Hamilton path on the skeleton of any 0/1-polytope conv(X), where X subset of {0, 1}n. The algorithm uses as a black box any algorithm that solves a variant of the classical linear optimization problem min{w center dot x vertical bar x. X}, and the resulting delay, i.e., the running time per visited vertex on the Hamilton path, is only by a factor of log n larger than the running time of the optimization algorithm. When X encodes a particular class of combinatorial objects, then traversing the skeleton of the polytope conv(X) along a Hamilton path corresponds to listing the combinatorial objects by local change operations, i.e., we obtain Gray code listings. - As concrete results of our general framework, we obtain efficient algorithms for generating all (c-optimal) bases and independent sets in a matroid; (c-optimal) spanning trees, forests, matchings, maximum matchings, and c-optimal matchings in a general graph; vertex covers, minimum vertex covers, c-optimal vertex covers, stable sets, maximum stable sets and c-optimal stable sets in a bipartite graph; as well as antichains, maximum antichains, c-optimal antichains, and c-optimal ideals of a poset. Specifically, the delay and space required by these algorithms are polynomial in the size of the matroid ground set, graph, or poset, respectively. Furthermore, all of these listings correspond to Hamilton paths on the corresponding combinatorial polytopes, namely the base polytope, matching polytope, vertex cover polytope, stable set polytope, chain polytope and order polytope, respectively. - As another corollary from our framework, we obtain an O(t(LP) log n) delay algorithm for the vertex enumeration problem on 0/1-polytopes {x. Rn vertical bar Ax <= b}, where A is an element of R-mxn and b is an element of R-m, and t(LP) is the time needed to solve the linear program min{w center dot x vertical bar Ax <= b}. This improves upon the 25-year old O(t(LP) n) delay algorithm due to Bussieck and Lubbecke.
Más información
Título según WOS: | ID WOS:001137125900070 Not found in local WOS DB |
Título de la Revista: | 2023 IEEE 64TH ANNUAL SYMPOSIUM ON FOUNDATIONS OF COMPUTER SCIENCE, FOCS |
Editorial: | IEEE COMPUTER SOC |
Fecha de publicación: | 2023 |
Página de inicio: | 1282 |
Página final: | 1291 |
DOI: |
10.1109/FOCS57990.2023.00076 |
Notas: | ISI |