Linear-Time Approximation Algorithms for Computing Numerical Summation with Provably Small Errors
Abstract
Given a multiset $X=\{x_1,..., x_n\}$ of real numbers, the {\it floating-point set summation} problem asks for $S_n=x_1+...+x_n$. Let $E^*_n$ denote the minimum worst-case error over all possible orderings of evaluating $S_n$. We prove that if $X$ has both positive and negative numbers, it is NP-hard to compute $S_n$ with the worst-case error equal to $E^*_n$. We then give the first known polynomial-time approximation algorithm that has a provably small error for arbitrary $X$. Our algorithm incurs a worst-case error at most $2(\mix)E^*_n$.\footnote{All logarithms $\log$ in this paper are base 2.} After $X$ is sorted, it runs in O(n) time. For the case where $X$ is either all positive or all negative, we give another approximation algorithm with a worst-case error at most $\lceil\log\log n\rceil E^*_n$. Even for unsorted $X$, this algorithm runs in O(n) time. Previously, the best linear-time approximation algorithm had a worst-case error at most $\lceil\log n\rceil E^*_n$, while $E^*_n$ was known to be attainable in $O(n \log n)$ time using Huffman coding.
- Publication:
-
arXiv e-prints
- Pub Date:
- July 1999
- DOI:
- arXiv:
- arXiv:cs/9907015
- Bibcode:
- 1999cs........7015K
- Keywords:
-
- Computer Science - Data Structures and Algorithms;
- Mathematics - Numerical Analysis;
- G.1;
- F.2
- E-Print:
- SIAM Journal on Computing, 29(5):1568--1576, 2000