Register Loading via Linear Programming
Autor: | Minming Li, Gruia Calinescu |
---|---|
Rok vydání: | 2014 |
Předmět: | |
Zdroj: | Algorithmica. 72:1011-1032 |
ISSN: | 1432-0541 0178-4617 |
DOI: | 10.1007/s00453-014-9888-2 |
Popis: | We study the following optimization problem. The input is a number $$k$$k and a directed graph with a specified "start" vertex, each of whose vertices may have one "memory bank requirement", an integer. There are $$k$$k "registers", labeled $$1, \ldots , k$$1,?,k. A valid solution associates to the vertices with no bank requirement one or more "load instructions" $$L[b,j]$$L[b,j], for bank $$b$$b and register $$j$$j, such that every directed trail from the start vertex to some vertex with bank requirement $$c$$c contains a vertex $$u$$u that has been associated $$L[c,i]$$L[c,i] (for some register $$i \le k$$i≤k) and no vertex following $$u$$u in the trail has been associated an $$L[b,i]$$L[b,i], for any other bank $$b$$b. The objective is to minimize the total number of associated load instructions. We give a $$k(k+1)$$k(k+1)-approximation algorithm based on linear programming rounding, with $$(k+1)$$(k+1) being the best possible unless Vertex Cover has approximation $$2 - {\epsilon }$$2-∈ for $${\epsilon }> 0$$∈>0. We also present a $$O(k \log n)$$O(klogn) approximation, with $$n$$n being the number of vertices in the input directed graph. Based on the same linear program, another rounding method outputs a valid solution with objective at most $$2k$$2k times the optimum for $$k$$k registers, using $$2k-1$$2k-1 registers. |
Databáze: | OpenAIRE |
Externí odkaz: |