Parallelized approximation algorithms for minimum routing cost spanning trees
Abstract
Let be an undirected graph with a nonnegative edge-weight function The routing cost of a spanning tree of is where denotes the weight of the simple - path in The Minimum Routing Cost Spanning Tree (MRCT) problem WLB+ [00] asks for a spanning tree of with the minimum routing cost. In this paper, we parallelize several previously proposed approximation algorithms for the MRCT problem and some of its variants. Let be an arbitrary constant. When the edge-weight function is given in unary, we parallelize the -approximation algorithm for the MRCT problem WCT00b by implementing it using an circuit. There are other variants of the MRCT problem. In the Sum-Requirement Optimal Communication Spanning Tree (SROCT) problem WCT00a, each vertex is associated with a requirement The objective is to find a spanning tree of minimizing When the edge-weight function and the vertex-requirement function are given in unary, we parallelize the -approximation algorithm for the SROCT problem WCT00a by realizing it using circuits, with a slight degradation in the approximation ratio from to In the weighted -MRCT problem Wu [02], we have additional inputs and The objective is to find a spanning tree of minimizing When the edge-weight function is given in unary, we parallelize the -approximation algorithm Wu [02] into circuits, with a slight degradation in the approximation ratio from to To the best of our knowledge, our results are the first parallelized approximation algorithms for the MRCT problem and its variants.
1 Introduction
Let be an undirected graph with a nonnegative edge-weight function The routing cost of a spanning tree of is where is the weight of any shortest - path in or equivalently, the weight of the simple - path in The Minimum Routing Cost Spanning Tree (MRCT) problem WLB+ [00] asks for a spanning tree of with the minimum routing cost. It is also known as the Shortest Total Path Length Spanning Tree problem. The MRCT problem is first proposed by Hu Hu [74], who referred to the problem as the Optimum Distance Spanning Tree Problem. In Huβs formulation of the more general Optimum Communication Spanning Tree (OCT) problem Hu [74], an additional value is given for each pair of vertices. The communication cost Hu [74] of a spanning tree of is The OCT problem asks for a spanning tree of with the minimum communication cost. When is a complete graph and the edge-weight function obeys the triangle inequality, a randomized -approximation algorithm is known for the OCT problem Bar [98], CCGG [98], WLB+ [00], FRT [03]. The MRCT problem is the special case of the OCT problem when for all
The MRCT problem has applications in network design Hu [74], JLK [78] as well as multiple sequences alignment in computational biology FD [87], Pev [92], Gus [93], BLP [94], WLB+ [00]. Unfortunately, it is shown to be -hard JLK [78], and it is -hard even when all edge weights are equal JLK [78], GJ [79] or when the edge-weight function obeys the triangle inequality WLB+ [00].
Exact and approximation algorithms for the MRCT problem have been extensively researched BFW [73], Hoa [73], DF [79], Won [80], WCT00b , WLB+ [00], FLS [02]. Boyce et al. BFW [73], Hoang Hoa [73] and Dionne and Florian DF [79] study branch-and-bound algorithms as well as heuristic approximation algorithms for the Optimal Network Design problem BFW [73], which includes the MRCT problem as a special case. Fischetti et al. FLS [02] give exact algorithms for the MRCT problem while avoiding exhaustive search. Wong Won [80] gives a polynomial-time -approximation algorithm for the MRCT problem. That is, he gives a polynomial-time algorithm that, given a graph with a nonnegative edge-weight function outputs a spanning tree of whose routing cost is at most times the minimum. Subsequent work by Wu et al. WCT00b shows a different polynomial-time -approximation algorithm as well as polynomial-time and -approximation algorithms for the MRCT problem, where is an arbitrary constant. Their results are later improved by Wu et al. WLB+ [00] to give a polynomial-time approximation scheme (PTAS) CLRS [01] for the MRCT problem. That is, a polynomial-time -approximation algorithm is given for any constant
There are other variants of the MRCT problem that also have applications in network design WLB+ [00], WCT00a , WCT00c , Wu [02]. In the Sum-Requirement Optimal Communication Spanning Tree (SROCT) problem WCT00a, each vertex is associated with a requirement The objective is to find a spanning tree of minimizing The Product-Requirement Optimal Communication Spanning Tree (PROCT) WCT00a problem is to find a spanning tree of minimizing The SROCT and PROCT problems are clearly generalizations of the MRCT problem.
Wu et al. WCT00a give a -approximation algorithm for the SROCT problem. They also propose a -approximation algorithm WCT00a for the PROCT problem. The result is improved by Wu et al. WCT00c to yield a polynomial-time approximation scheme (PTAS) for the PROCT problem.
Another variant of the MRCT problem is the -MRCT problem Wu [02]. In this problem, except for and we are given two source vertices The objective is to find a spanning tree of minimizing This problem is -hard even when obeys the triangle inequality Wu [02]. Wu Wu [02] shows a -approximation algorithm as well as a PTAS for this problem. A variant of the -MRCT problem is the weighted -MRCT problem Wu [02] where an additional is given as input. The objective is to find a spanning tree of minimizing Wu Wu [02] proposes a -approximation algorithm for the weighted -MRCT problem. When the edge-weight function obeys the triangle inequality, there is a PTAS for the weighted -MRCT problem Wu [02].
In this paper, however, we will focus on parallelizing the approximation algorithms for the above problems. We first describe our results concerning the MRCT problem. For an arbitrary and when the edge-weight function is given in unary, we show that the -approximation algorithm proposed by Wu et al. WCT00b can be implemented by an circuit. That is, the approximation algorithm can be performed by a uniform polynomial-size circuit Pap [94] with random gates and poly-logarithmic depth. Indeed, with a small probability our parallelized algorithm may fail to find a -approximate solution, in which case it outputs βfail.β Thus, our algorithm does not fail (to find a -approximate solution) without ever knowing that it fails, which is a desirable property for randomized algorithms with a small probability of failure.
We now turn to describe our results concerning the SROCT problem. When the edge-weight and the vertex-requirement functions are given in unary, we parallelize the -approximation algorithm WCT00a by realizing it using circuits, with a slight degradation in the approximation ratio (from the currently best to our ). Still, with a small probability our algorithm may fail to output a -approximate solution, in which case it knows the failure and outputs βfail.β
Finally, for the weighted -MRCT problem with the edge-weight function given in unary, we parallelize the -approximation algorithm Wu [02] into circuits, with a slight degradation in the approximation ratio (from the currently best to our ). Again, there is a small probability that our algorithm fails to find a -approximate solution, in which case it outputs βfail.β
To the best of our knowledge, our results are the first efforts towards parallelized approximation algorithms for the MRCT problem and its variants. Our results open up new opportunities to compute approximate solutions to the above problems in parallel poly-logarithmic time. In the applications of the MRCT problem to network design Hu [74], JLK [78] as well as the applications of the SROCT and PROCT problems to network design WCT00a , WCT00c, the network is often modeled as a graph with a nonnegative edge-weight function representing the distances between pairs of nodes. Although approximate solutions to the aforementioned problems (MRCT, SROCT, PROCT, weighted -MRCT) are attainable in polynomial time, in any real networking environment, however, the cost of traffic between any pair of nodes may vary over time. Thus, it is highly desirable to be able to compute approximate solutions to these problems as fast as possible, so as to reduce the risk that the traffic costs change during the computation. Our results imply that approximate solutions to the MRCT, SROCT and weighted -MRCT problems can indeed by computed in parallel poly-logarithmic time on multiprocessors.
For other applications of the MRCT problem where the data does not change quickly over time, for example multiple sequences alignment in computational biology FD [87], Pev [92], Gus [93], BLP [94], WLB+ [00], being able to compute approximate solutions to the MRCT problem in parallel sublinear time is still beneficial. Indeed, Fischer Fis [01] argues that in many practical applications today, the input size is so large that even performing linear-time computations is too time-consuming. Certainly, multiple sequences alignment in computational biology constitutes a good example where the input size is usually too large. It is therefore a desirable property that our algorithms operate in parallel sublinear time, and in fact poly-logarithmic time.
The main idea underlying our proofs is that many of the previously proposed approximation algorithms for the MRCT, SROCT and weighted -MRCT problems rely heavily on finding shortest paths between pairs of vertices in a graph. This motivates applying the well-known result that to parallelize these algorithms since we can guess a path (possibly the shortest one) between two vertices of a graph in nondeterministic logarithmic space. There is the complication that, in our proofs, we will often need to generate the same shortest path between two vertices whenever a shortest - path is needed. For this purpose, we use the isolation technique Wig [94], GW [96], RA [00] to slightly modify the edge-weight function of the input graph, so that there is exactly one shortest path between each pair of vertices with high probability. We then apply the double-counting technique RA [00] to decide whether the input graph (with the modified edge-weight function) exhibits a unique shortest path between each pair of vertices. If so, we are able use the double counting technique to generate the unique shortest - path whenever it is needed. The whole procedure runs in unambiguous logarithmic space and our results follow by The approximation ratio would be slightly degraded. The degradation comes from randomly modifying the edge-weight function when we apply the isolation technique.
Our paper is organized as follows. Section 2 provides the basic definitions. Section 3 presents the parallelized -approximation algorithm for the MRCT problem. Section 4β5 describe our parallelized approximation algorithms for the SROCT and the weighted -MRCT problems, respectively. Section 6 concludes the paper. Proofs are given in the appendix for references.
2 Notations and basic facts
Throughout this paper, graphs are simple undirected graphs Wes [01]. That is, we disallow parallel edges and self-loops. There will always be a nonnegative edge-weight function mapping each edge to a nonnegative real number. For a graph is its vertex set and is its edge set. Let be a subgraph of A path connects a vertex to (or ) if one endpoint of is and the other is in An edge connecting two vertices and is denoted A path connecting two vertices and is said to be a - path. A path is one which traverses in that order. A simple path is a path that traverses each vertex at most once Wes [01]. A graph contains another graph if is a subgraph of The set of nonnegative real numbers is denoted
Definition 1.
Let be an undirected graph and be a nonnegative edge-weight function. The lexicographical ordering on is that of the encodings of the vertices in assuming any reasonable encoding of a graph. Let and be a subgraph of The sum of edge weights of is denoted When is a path, is called the weight or length of For we use to denote the weight of any shortest - path. We use (or ) for The lexicographically first vertex satisfying is denoted (or ). The set of all shortest paths connecting and is denoted (or ) is the set of shortest paths connecting and That is, is the set of paths that connect and and have weight equal to For denotes the set of vertices reachable from with at most edges. denotes the set of all shortest paths among those - paths with at most edges. That is, is the set of - paths with at most edges whose weight is not larger than any other path with at most edges. The union of two graphs and is the graph The graph is strongly min-unique with respect to if for all and we have When is clear from the context, we may simply say that is strongly min-unique without referring to
In Definition 1, it is not hard to show that is strongly min-unique if for all and provided
The MRCT of a graph, standing for its Minimum Routing Cost spanning Tree, is defined below.
Definition 2.
(WC [04]) Given a connected graph with a nonnegative edge-weight function the routing cost of a spanning tree of is A spanning tree of with the minimum routing cost is an MRCT of which is denoted by for convenience.
The MRCT problem asks for on input The following fact shows that the routing cost of a tree can be computed efficiently.
Fact 3.
(WC [04]) Let be a graph with a nonnegative edge-weight function and be a spanning tree of For each edge let and be the two trees formed by removing from We have and
To ease the description, we introduce the following definition.
Definition 4.
(RA [00]) A nondeterministic Turing machine outputs a string unambiguously on input if it outputs on exactly one non-rejecting computation branch, and rejects on all other computation branches. The unambiguously output string is also denoted
Throughout this paper, when a nondeterministic Turing machine runs or simulates another nondeterministic machine it means that runs and make nondeterministic branches as does. It does not mean that enumerates all computation branches of and simulate them deterministically. For convenience, does not necessarily have to output βs output. Instead, it may extract portions of βs output for output.
We will need the notion of a general star to introduce the approximation algorithms for the MRCT problem.
Definition 5.
(WC [04]) Let be a connected graph with a nonnegative edge-weight function and be a subtree of A spanning tree containing is a general star with core if each vertex satisfies When is a singleton, a general star with core is also called a shortest path tree rooted at
Given any subtree of a general star with core exists WCT00b. This follows by observing that for any shortest path connecting and the part of from any vertex to constitutes a shortest path connecting and
The notion of a metric graph is defined below.
Definition 6.
(WLB+ [00]) A complete graph with a non-negative edge-weight function is metric if for all
3 A parallelized -approximation for MRCT
We begin with the following form of the famous isolation lemma. It is implicit in some previous works Wig [94], GW [96], RA [00].
Theorem 7.
(RA [00]) Let be a graph with a nonnegative edge-weight Let assign the weight of each independently and randomly from the uniform distribution over a set With probability at least the graph is strongly min-unique with respect to
The following theorem is implicit in RA [00]. It uses the double counting technique RA [00] similar to the inductive counting technique used to prove the Immerman-SzelepcsΓ©nyi theorem Imm [88], Sze [88].
Theorem 8.
(RA [00]) There is a nondeterministic logarithmic-space Turing machine FIND-PATH that, on input a graph with a nonnegative edge-weight function and two vertices satisfies the following conditions.
- 1.
If is not strongly min-unique, then FIND-PATH outputs βnot strongly min-uniqueβ unambiguously.
- 2.
If is strongly min-unique and has an -path, then FIND-PATH outputs the unique path and its weight unambiguously. The edges in are output in the direction going from to
- 3.
If is strongly min-unique and does not have an -path, then FIND-PATH has no accepting computation branches.
The following theorem is due to Wu et al. WCT00b.
Theorem 9.
(WCT00b) Let be a constant and be a connected, strongly min-unique graph with a nonnegative edge-weight function For and let be the subgraph of containing only For let where is the unique shortest path connecting and For some and every general star with core satisfies
That in Theorem 9 is a subtree of for is easily shown because for each by the strong min-uniqueness of The core in Theorem 9 is unambiguously computable in logarithmic space on strongly min-unique connected graphs. To show this, we need the following lemma.
Lemma 10.
There is a nondeterministic logarithmic-space Turing machine ADD-PATH that, on input a strongly min-unique connected graph with a nonnegative edge-weight function a subgraph of and a vertex outputs the unique path unambiguously.
With Lemma 10, we are able to compute the core in Theorem 9 unambiguously in logarithmic space on strongly min-unique connected graphs.
Lemma 11.
Let be a constant. There is a nondeterministic logarithmic-space Turing machine CORE that, on input a strongly min-unique connected graph with a nonnegative edge-weight function and where unambiguously outputs defined below. is the subgraph of containing only For where
is the unique shortest path connecting and
Fact 12.
Let be a constant and be a strongly min-unique, connected graph with a nonnegative edge-weight function For a sequence of at most vertices in let and for Then
is a general star with core and
for some
The general star with a core in Fact 12 can be computed unambiguously in logarithmic space, as the next lemma shows.
Lemma 13.
Let be a constant. There is a nondeterministic logarithmic-space Turing machine STAR that, on input a strongly min-unique connected graph with a nonnegative edge-weight function and a sequence of at most vertices in outputs and each unique path in for unambiguously.
The following lemma allows unambiguous logarithmic-space computation of the routing cost of a tree.
Lemma 14.
There is a nondeterministic logarithmic-space Turing machine ROUT-PAIR that, on input a tree with a nonnegative edge-weight function and unambiguously outputs the unique simple path connecting and in and
Lemma 15.
Let be a constant. There exists a nondeterministic logarithmic-space Turing machine APPROX that, on input a strongly min-unique connected graph with a nonnegative edge-weight function unambiguously outputs a spanning tree of with
The following lemma will be useful.
Lemma 16.
Let be a constant. Let be a graph with a nonnegative edge-weight function and the minimum nonzero weight assigned by if it exists, is at least Let and be spanning trees of Let assign to each edge a nonnegative weight and Then
(1) |
implies
(2) |
for sufficiently large
Theorem 17.
Let be a constant. There is an algorithm PARALLEL that, on input a weighted undirected graph with a nonnegative edge-weight function satisfies the following.
- 1.
If is disconnected, then outputs βdisconnected.β
- 2.
If is connected, then outputs a spanning tree of unambiguously or outputs βfailβ unambiguously. The probability that outputs a spanning tree of unambiguously is at least If outputs a spanning tree of unambiguously, then
4 The SROCT problem
We begin this section with the following definition.
Definition 18.
(WCT00a , Wu [02]) Let be a graph with a nonnegative edge-weight function and be a requirement function on vertices. Let be two vertices of and be a spanning tree of The sum-requirement communication (s.r.c.) cost of is
The Sum-Requirement Optimal Communication Spanning Tree (SROCT) problem is to find a spanning tree of with the minimum value of over all spanning trees of We use to denote an arbitrary spanning tree of with the minimum s.r.c. cost. The two-source routing cost of with sources is
The -MRCT problem is to find a spanning tree of with the minimum value of over all spanning trees of (in this problem and are part of the input). We use to denote an arbitrary spanning tree of with the minimum two-source routing cost when the sources are clear from the context. Let The weighted two-source routing cost of with sources and weight is
The weighted -MRCT problem is to find a spanning tree of with the minimum value of over all spanning trees of (in this problem and are part of the input). We use to denote an arbitrary spanning tree of with the minimum weighted two-source routing cost when and the sources are clear from the context.
The SROCT, -MRCT and weighted -MRCT problems are all -hard, even on metric graphs WLB+ [00], WCT00a , WCT00c , Wu [02].
The following theorem gives a -approximation solution to the SROCT problem.
Theorem 19.
(WCT00a) Let be a connected graph with a nonnegative edge-weight function and a nonnegative vertex-requirement function There exists a vertex such that any shortest path tree rooted at satisfies
Theorems 7β8, 19 and Lemma 14 give the following parallelized -approximation solution to the SROCT problem.
Theorem 20.
There is an algorithm PARALLEL-SROCT that, on input a connected graph with a nonnegative edge-weight function and a nonnegative vertex-requirement function outputs a spanning of with
with high probability. If PARALLEL-SROCT does not output such a spanning tree, it outputs βfail.β
5 Weighted -MRCT problem
For the weighted -MRCT problem, we can assume without loss of generality that the two sources are such that where is the input graph. Otherwise, the problem reduces to finding a shortest path tree rooted at which was implicitly done in the proof of Theorem 20. Wu Wu [02] has the following -approximation solution for the weighted -MRCT problem.
Theorem 21.
(Wu [02]) Let be a connected graph with a nonnegative edge-weight function two sources with and Denote
and
for Let and Let be arbitrary. Denote
where is the first vertex on (in the direction from to ) that is not in (it is easy to see that ). For each let and be arbitrary. If and are trees, then is a spanning tree of and
Theorem 22.
There is an algorithm WEIGHTED--MRCT that, on input a graph with a nonnegative edge-weight function and with high probability outputs a spanning tree with
If WEIGHTED--MRCT does not output such a spanning tree, it outputs βfail.β
We make the following concluding remark. All our algorithms are shown to be -computable by showing that they run in unambiguous logarithmic space and succeed in giving an approximate solution when the random input specifies an edge-weight function such that is strongly min-unique with respect to By a method similar to that in RA [00], we can also turn the random weight assignment into polynomially long advices. This is summarized below.
Corollary 23.
Let be a constant. There are algorithms for -approximating the MRCT problem, -approximating the SROCT problem and -approximating the weighted -MRCT problem, where the respective edge-weight and vertex-requirement functions are given in unary.
6 Conclusion
We have given parallelized approximation algorithms for the minimum routing cost spanning tree problem and some of its variants. Our results show that, by exhibiting multiple processors, we can compute approximate solutions to the considered problems in parallel poly-logarithmic time. We hope this will shed light on the many areas in which the considered problems are concerned, for example network design Hu [74], JLK [78] and multiple sequences alignment in computational biology FD [87], Pev [92], Gus [93], BLP [94], WLB+ [00].
Acknowledgments
The authors are grateful to Wen-Hui Chen for his helpful comments and suggestions.
Appendix
Proof of Theorem 7..
The theorem is clearly true for If is not strongly min-unique with respect to and we have seen that there exist such that where the edge weights are given with respect to This implies the existence of an edge such that at least one path in contains and at least one does not. In this case we say that blames Thus, the probability that is not strongly min-unique is at most the sum over and of the probability that blames
For any and any partial weight assignment of to there is at most one assignment of to to make blame This is because if blames when is assigned a value then increasing or decreasing the value of forces all shortest paths among those - paths with at most edges to exclude or include respectively, making no longer blamed by Therefore,
completing the proof. β
Proof of Theorem 8..
Before describing how FIND-PATH works, we describe a few procedures that are useful. For let Let be arbitrary and Note that the definition of does not depend on exactly which path in is chosen as It is clear that and
We first introduce a nondeterministic logarithmic-space subroutine OUTPUT that outputs unambiguously, given and that for each OUTPUT just needs to nondeterministically guess each vertex to be in or out of and if the guess is then it outputs It verifies each guess of by nondeterministically guessing an - path with at most edges and rejecting if it fails. Along the way OUTPUT counts the number of vertices verified to be in and accumulates the weights of the guessed - paths (for verified to be in ) in a variable It then rejects if or Clearly, guessing any vertex out of to be in results in rejection. For a computation branch of OUTPUT not to reject, it must have reach which requires successfully guessing an - path with at most edges for each But to have not exceed the guessed - path for each should be the unique one in So has a unique non-rejecting computation branch, on which it correctly guesses whether each vertex belongs to and if so, correctly guesses the unique path in
We now describe a procedure INDUCTIVE that computes and and determines whether for some unambiguously, given and and that for each For each vertex INDUCTIVE runs to determine whether unambiguously and if so, accumulates the weight of the unique path in as it is guessed by OUTPUT. For each such that is an edge, INDUCTIVE also determines whether unambiguously and if so, accumulates the weight of the unique path in as it is guessed. INDUCTIVE then computes the weight of any shortest - path with at most edges as
where
if and
otherwise. If INDUCTIVE knows that Otherwise and the weight of any path in is known to be In case of a tie when computing INDUCTIVE knows that Doing the above for all allows INDUCTIVE to compute and and determine whether for some unambiguously. During the computation of INDUCTIVE does not store the set Instead, INDUCTIVE computes the elements of one by one and stores the smallest element in that has been computed so far, as well as a flag indicating whether is achieved by two elements at any time.
We are now ready to describe how FIND-PATH works. Assume FIND-PATH starts with and repeatedly simulates INDUCTIVE until it computes or until it determines that for some and Doing the above with each other vertex replacing the role of guarantees that if is not strongly min-unique, then we must find for some and Instead, if is strongly min-unique then FIND-PATH will compute all the way from to It then runs As we have seen, has a unique non-rejecting computation branch, on which the unique shortest - path is correctly guessed by OUTPUT. The weight is accumulated along the way. The strong min-uniqueness of guarantees that is also the unique path in β
Proof of Lemma 10..
For each ADD-PATH runs to unambiguously generate the unique shortest path and its weight In this way, ADD-PATH could compute as well as Then ADD-PATH simulates to output the unique path in unambiguously. β
Proof of Lemma 11..
Clearly, CORE could output unambiguously. Let To output unambiguously, CORE recursively outputs and then runs to unambiguously output There is an additional complication that CORE does not store before calling ADD-PATH. Instead, whenever ADD-PATH wants to read any bit encoding CORE recursively outputs unambiguously on the fly to support the required bit. Each level of recursion uses up logarithmic space and the depth of recursion is at most a constant. The space requirement is therefore logarithmic.
β
Proof of Lemma 13..
STAR begins by running to output unambiguously. For any STAR runs to unambiguously determine whether If STAR needs to output the unique path in For this purpose, it computes as follows. For each STAR tests if again by running If STAR goes on with the next Otherwise, STAR invokes to generate the unique path and its weight unambiguously. STAR records the that has generated the smallest value of so far, favoring lexicographically smaller values of in case of a tie. In the end, the recorded must be by the definition of At this time STAR just invokes to output the unique path in unambiguously. Doing the above for all does the job. β
Proof of Lemma 14..
If the task is trivial. We assume otherwise. ROUT-PAIR nondeterministically guesses a path that does not enter a vertex immediately after it has left that vertex. If is an - path, then ROUT-PAIR accepts, otherwise it rejects. The simple - path in is the only - path that does not enter a vertex immediately after leaving it. Its weight can be accumulated as it is guessed. β
Proof of Lemma 15..
For each sequence of at most vertices in Lemma 13 enables us to unambiguously output and then each unique path in for Furthermore, Fact 12 guarantees that
is a spanning tree of and satisfies
for some Thus, we need only compute unambiguously for each sequence of at most vertices, and output unambiguously for the sequence of at most vertices satisfying By Definition 2, can be computed unambiguously by running for all pairs and summing up the weight of the simple paths as they are output. There is a complication that APPROX does not store before calling ROUT-PAIR. Instead, when ROUT-PAIR wants to read any bit in the encoding of APPROX runs to generate the required bit unambiguously on the fly. This enables us to obtain unambiguously and thus unambiguously by running β
Proof of Lemma 16..
It is clear that either or Also, Fact 3 implies that
(3) |
Proof of Theorem 17..
We will show that PARALLEL needs only take a -long random input and do the rest of the computation in unambiguous logarithmic space. The standard proof technique for showing that Pap [94], Sip [05] then completes the proof.
PARALLEL tests the connectedness of by testing each pair of vertices for connectedness in logarithmic space Rei [05].
Below we assume that is connected. If we assume that this theorem is true when is not identically zero, then PARALLEL can also deal with the identically zero case by using the unit edge-weight function instead. The output spanning tree would have zero routing cost under the identically zero edge-weight function, so item is still satisfied. Thus, we can assume without loss of generality that is not identically zero. Furthermore, we can normalize to give
The random input to PARALLEL determines an edge-weight function where for each is independently and randomly chosen from the uniform distribution over Note that for every Denote Let be an MRCT with respect to and be that with respect to By Theorem 7, with probability at least is strongly min-unique with respect to PARALLEL runs for an arbitrary pair to unambiguously test if is strongly min-unique with respect to and outputs βfailβ if it is not. PARALLEL then runs to unambiguously output a tree with
(4) | |||||
by invoking Lemma 15 with a sufficiently large constant such that
Sketch of proof of Theorem 20..
We omit the simple case where is identically zero and assume without loss of generality that Let be the subgraph of formed by the zero-weight edges of PARALLEL-SROCT tests whether is a connected spanning subgraph of in logarithmic space Rei [05] and if so, outputs a spanning tree of by calling, say, where denotes the identically zero function.
Below we assume that is disconnected. The random input to PARALLEL-SROCT determines an edge-weight function where for each is independently and randomly chosen from the uniform distribution over Let Note that By Theorem 7, is strongly min-unique with respect to with high probability. PARALLEL-SROCT uses FIND-PATH to determine if is strongly min-unique with respect to and outputs βfailβ if it is not. Below we assume that is strongly min-unique with respect to For each a shortest path tree rooted at can be output unambiguously by running for each The s.r.c. cost of can be computed unambiguously by running and accumulating the weight of the output path multiplied by for all During the computation of ROUT-PAIR, each time any bit encoding is needed, it is generated on the fly. The spanning tree with the minimum (over ) s.r.c. cost with respect to is output. The final step in establishing the approximation ratio goes by showing that for every spanning tree of
by the disconnectedness of and whereas
by Fact 3. The fact that completes the proof. β
Sketch of proof of Theorem 22..
We omit the simple case when is identically zero and assume that The case where the zero-weight edges of form a connected spanning subgraph of is dealt with as in the proof of Theorem 20, so we may assume that it is not the case. The random input to WEIGHTED--MRCT determines an edge-weight function where for each is independently and randomly chosen from the uniform distribution over Let Note that WEIGHTED--MRCT detects whether is strongly min-unique with respect to by running FIND-PATH and outputs βfailβ if it is not, which occurs with a small probability by Theorem 7. Now, assume that is strongly min-unique with respect to The sets in Theorem 21 where is measured with respect to are computable in unambiguous logarithmic space by Theorem 8. For each let and be the unique shortest paths with respect to By Theorem 8, and are unambiguously computable in logarithmic space and they are trees by the strong min-uniqueness of with respect to The unique shortest path with respect to is also unambiguously computable by running so is its first vertex outside of Theorem 21 then implies that a tree satisfying
can be output in unambiguous logarithmic space. The final step in establishing the approximation ratio is to show that for every spanning tree of
(6) |
whereas
The fact that completes the proof. β
References
- Bar [98] Y. Bartal, On approximating arbitrary metrics by tree metrics, Proceedings of the 30th Annual ACM Symposium on Theory of Computing, 1998, pp. 161β169.
- BFW [73] D. E. Boyce, A. Farhi, and R. Weischedel, Optimal network problem: A branch-and-bound algorithm, Environment and Planning 5 (1973), 519β533.
- BLP [94] V. Bafna, E. L. Lawler, and P. Pevzner, Approximations algorithms for multiple sequence alignment, Proceedings of the 5th Combinatorial Pattern Matching Conference, vol. 807, 1994, pp. 43β53.
- CCGG [98] M. Charikar, C. Chekuri, A. Goel, and S. Guha, Rounding via trees: Deterministic approximation algorithms for group Steiner trees and k-median, Proceedings of the 30th Annual ACM Symposium on Theory of Computing, 1998, pp. 114β123.
- CLRS [01] T. H. Cormen, C. E. Leiserson, R. L. Rivest, and C. Stein, Introduction to algorithms., MIT Press, 2001.
- DF [79] R. Dionne and M. Florian, Exact and approximate algorithm for optimal network design, Networks 9 (1979), no. 1, 37β60.
- FD [87] D. Feng and R. Doolittle, Progressive sequence alignment as a prerequisite to correct phylogenetic trees, Journal of Molecular Evolution 25 (1987), 351β360.
- Fis [01] Fischer, The art of uninformed decisions: A primer to property testing, Bulletin of the European Association for Theoretical Computer Science 75 (2001).
- FLS [02] M. Fischetti, G. Lancia, and P. Serafini, Exact algorithms for minimum routing cost trees, Networks 39 (2002), 161β173.
- FRT [03] J. Fakcharoenphol, S. Rao, and K. Talwar, A tight bound on approximating arbitrary metrics by tree metrics, Proceedings of the 35th Annual ACM Symposium on Theory of Computing, 2003, pp. 448β455.
- GJ [79] M. R. Garey and D. S. Johnson, Computers and intractability: A guide to the theory of -completeness, Freeman, 1979.
- Gus [93] D. Gusfield, Efficient methods for multiple sequence alignment with guaranteed error bounds, Bulletin of Mathematical Biology 55 (1993).
- GW [96] A. GΓ‘l and A. Wigderson, Boolean vs. arithmetic complexity classes: randomized reductions, Random Structures and Algorithms 9 (1996), 99β111.
- Hoa [73] H. H. Hoang, A computational approach to the selection of an optimal network, Management Science 19 (1973), no. 5, 488β498.
- Hu [74] T. C. Hu, Optimum communication spanning trees, SIAM Journal on Computing 3 (1974), 188β195.
- Imm [88] N. Immerman, Nondeterministic space is closed under complementation, SIAM Journal on Computing (1988), 935β938.
- JLK [78] D. S. Johnson, J. K. Lenstra, and A. H. G. Rinnooy Kan, The complexity of the network design problem, Networks 8 (1978), 279β285.
- Pap [94] C. H. Papadimitriou, Computational complexity, Addison-Wesley, 1994.
- Pev [92] P. Pevzner, Multiple alignment, communication cost, and graph matching, SIAM Journal on Applied Mathematics 52 (1992), 1763β1779.
- RA [00] K. Reinhardt and E. Allender, Making nondeterminism unambiguous, SIAM Journal on Computing 29 (2000), no. 4, 1118β1131.
- Rei [05] O. Reingold, Undirected ST-connectivity in log-space, Proceedings of the 37th Annual ACM Symposium on Theory of Computing, 2005, pp. 376β385.
- Sip [05] M. Sipser, Introduction to the theory of computation, 2nd ed., Course Technology, 2005.
- Sze [88] R. SzelepcsΓ©nyi, The method of forced enumeration for nondeterministic automata, Acta Informatica 26 (1988), 279β284.
- WC [04] B. Y. Wu and K.-M. Chao, Spanning trees and optimization problems, Chapman & Hall/CRC Press, 2004.
- [25] B. Y. Wu, K.-M. Chao, and C. Y. Tang, Approximation algorithms for some optimum communication spanning tree problems, Discrete Applied Mathematics 102 (2000), 245β266.
- [26] β, Approximation algorithms for the shortest total path length spanning tree problem, Discrete Applied Mathematics 105 (2000), 273β289.
- [27] β, A polynomial time approximation scheme for optimal product-requirement communication spanning trees, Journal of Algorithms 36 (2000), 182β204.
- Wes [01] D. B. West, Introduction to graph theory, 2nd ed., Prentice-Hall, 2001.
- Wig [94] A. Wigderson, , Proceedings of the 9th IEEE Structure in Complexity Conference, 1994, pp. 59β62.
- WLB+ [00] B. Y. Wu, G. Lancia, V. Bafna, K.-M. Chao, R. Ravi, and C. Y. Tang, A polynomial time approximation scheme for minimum routing cost spanning trees, SIAM Journal on Computing 29 (2000), 761β778.
- Won [80] R. T. Wong, Worst-case analysis of network design problem heuristics, SIAM Journal on Matrix Analysis and Applications 1 (1980), 51β63.
- Wu [02] B. Y. Wu, A polynomial time approximation scheme for the two-source minimum routing cost spanning trees, Journal of Algorithms 44 (2002), 359β378.