Streaming Algorithms for Geometric Steiner Forest
Abstract
We consider an important generalization of the Steiner tree problem, the Steiner forest problem, in the Euclidean plane: the input is a multiset X ⊂eq R2, partitioned into k color classes C1, C2, …, Ck ⊂eq X. The goal is to find a minimum-cost Euclidean graph G such that every color class Ci is connected in G. We study this Steiner forest problem in the streaming setting, where the stream consists of insertions and deletions of points to X. Each input point x∈ X arrives with its color color(x) ∈ [k], and as usual for dynamic geometric streams, the input points are restricted to the discrete grid \0, …, \2. We design a single-pass streaming algorithm that uses poly(k · ) space and time, and estimates the cost of an optimal Steiner forest solution within ratio arbitrarily close to the famous Euclidean Steiner ratio α2 (currently 1.1547 α2 1.214). This approximation guarantee matches the state-of-the-art bound for streaming Steiner tree, i.e., when k=1, and it is a major open question to improve the ratio to 1 + ε even for this special case. Our approach relies on a novel combination of streaming techniques, like sampling and linear sketching, with the classical Arora-style dynamic-programming framework for geometric optimization problems, which usually requires large memory and has so far not been applied in the streaming setting. We complement our streaming algorithm for the Steiner forest problem with simple arguments showing that any finite approximation requires (k) bits of space.