Affiliation:
1. Sun Microsystems Laboratories, Burlington, MA
2. Lisp Wizard, Oceanview, Kansas
Abstract
We present algorithms for accurately converting floating-point numbers to decimal representation. The key idea is to carry along with the computation an explicit representation of the required rounding accuracy.We begin with the simpler problem of converting fixed-point fractions. A modification of the well-known algorithm for radix-conversion of fixed-point fractions by multiplication explicitly determines when to terminate the conversion process; a variable number of digits are produced. The algorithm has these properties:• No information is lost; the original fraction can be recovered from the output by rounding.• No "garbage digits" are produced.• The output is correctly rounded.• It is never necessary to propagate carries on rounding.We then derive two algorithms for
free-format
out-put of floating-point numbers. The first simply scales the given floating-point number to an appropriate fractional range and then applies the algorithm for fractions. This is quite fast and simple to code but has inaccuracies stemming from round-off errors and oversimplification. The second algorithm guarantees mathematical accuracy by using multiple-precision integer arithmetic and handling special cases. Both algorithms produce no more digits than necessary (intuitively, the "1.3 prints as 1.2999999" problem does not occur).Finally, we modify the free-format conversion algorithm for use in
fixed-format
applications. Information may be lost if the fixed format provides too few digit positions, but the output is always correctly rounded. On the other hand, no "garbage digits" are ever produced, even if the fixed format specifies too many digit positions (intuitively, the "4/3 prints as 1.333333328366279602" problem does not occur).
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Cited by
8 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Floating-point arithmetic;Acta Numerica;2023-05
2. Fast number parsing without fallback;Software: Practice and Experience;2023-03-04
3. Number parsing at a gigabyte per second;Software: Practice and Experience;2021-05-11
4. Basic Properties and Algorithms;Handbook of Floating-Point Arithmetic;2018
5. An Array and List Processing System;Proceedings of ILC 2014 on 8th International Lisp Conference;2014-08-14