A parametric error analysis of Goldschmidt's division algorithm
Autor: | Guy Even, Warren E. Ferguson, Peter-M. Seidel |
---|---|
Rok vydání: | 2005 |
Předmět: |
Floating point
Computer science Computer Networks and Communications Applied Mathematics Division algorithm Rounding Division (mathematics) Span (engineering) Formal proof Microarchitecture Theoretical Computer Science Parametric error analysis symbols.namesake Computational Theory and Mathematics Simple (abstract algebra) symbols Floating point arithmetic Goldschmidt's division algorithm Newton's method Algorithm Mathematics Parametric statistics |
Zdroj: | IEEE Symposium on Computer Arithmetic |
ISSN: | 0022-0000 |
DOI: | 10.1016/j.jcss.2004.08.004 |
Popis: | Back in the 60's Goldschmidt presented a variation of Newton-Raphson iterations for division that is well suited for pipelining. The problem in using Goldschmidt's division algorithm is to present an error analysis that enables one to save hardware by using just the right amount of precision for intermediate calculations while still providing correct rounding. Previous implementations relied on combining formal proof methods (that span thousands of lines) with millions of test vectors. These techniques yield correct designs but the analysis is hard to follow and is not quite tight. We present a simple parametric error analysis of Goldschmidt's division algorithm. This analysis sheds more light on the effect of the different parameters on the error. In addition, we derive closed error formulae that allow to determine optimal parameter choices in four practical settings. We apply our analysis to show that a few bits of precision can be saved in the floating-point division (FP-DIV) microarchitecture of the AMD-K7/spl trade/ microprocessor. These reductions in precision apply to the initial approximation and to the lengths of the multiplicands in the multiplier. When translated to cost, the reductions reflect a savings of 10.6% in the overall cost of the FP-DIV microarchitecture. |
Databáze: | OpenAIRE |
Externí odkaz: |