论文标题
间隔对ZDD上的回溯,以快速枚举所有较低的成本解决方案
Interval-Memoized Backtracking on ZDDs for Fast Enumeration of All Lower Cost Solutions
论文作者
论文摘要
在本文中,我们提出了一种快速的方法,以精确地列举大量所有较低成本解决方案,以解决各种组合问题。我们的方法基于代表所有可行解决方案的给定决策图的回溯。主要思想是记住成本范围的间隔,以避免在回溯过程中重复搜索。与通常的伪多项式时间动态编程方法相反,我们方法的计算时间并不直接取决于总成本值,而是受决策图的输入和输出大小的限制。因此,如果成本值较大,但输入/输出决策图的压缩良好,则可能会更快。我们通过将我们的方法与当前可用的枚举方法进行比较来证明其实际效率:对于汉密尔顿路径问题的非平凡规模实例,我们的方法成功地列举了几秒钟内所有低成本解决方案的数十亿美元,这是百分之一百或多倍的速度。我们的方法可以被视为一种新颖的搜索算法,该算法集成了两种经典技术,即分支和动态编程。此方法在各个领域都有许多应用程序,包括操作研究,数据挖掘,统计测试,硬件/软件系统设计等。
In this paper, we propose a fast method for exactly enumerating a very large number of all lower cost solutions for various combinatorial problems. Our method is based on backtracking for a given decision diagram which represents all the feasible solutions. The main idea is to memoize the intervals of cost bounds to avoid duplicate search in the backtracking process. In contrast to usual pseudo-polynomial-time dynamic programming approaches, the computation time of our method does not directly depend on the total cost values, but is bounded by the input and output size of the decision diagrams. Therefore, it can be much faster if the cost values are large but the input/output decision diagrams are well-compressed. We demonstrate its practical efficiency by comparing our method to current available enumeration methods: for nontrivial size instances of the Hamiltonian path problem, our method succeeded in exactly enumerating billions of all lower cost solutions in a few seconds, which was hundred or much more times faster. Our method can be regarded as a novel search algorithm which integrates the two classical techniques, branch-and-bound and dynamic programming. This method would have many applications in various fields, including operations research, data mining, statistical testing, hardware/software system design, etc.