Sample page from NUMERICAL RECIPES IN C: THE ART OF SCIENTIFIC COMPUTING (ISBN 0-521-43108-5) Copyright (C) 1988-1992 by Cambridge
University Press. Programs Copyright (C) 1988-1992 by Numerical Recipes Software. Permission is granted for internet users to make one paper copy for their own personal use. Further reproduction, or any copying of machinereadable files (including this one) to any server computer, is strictly prohibited. To order Numerical Recipes books or CDROMs, visit website http://www.nr.com or call 1-800-872-7423 (North America only), or send email to directcustserv@cambridge.org (outside North America).
Chapter 20. Less-Numerical Algorithms
20.0 Introduction
You can stop reading now. You are done with Numerical Recipes, as such. This nal chapter is an idiosyncratic collection of less-numerical recipes which, for one reason or another, we have decided to include between the covers of an otherwise more-numerically oriented book. Authors of computer science texts, weve noticed, like to throw in a token numerical subject (usually quite a dull one  quadrature, for example). We nd that we are not free of the reverse tendency. Our selection of material is not completely arbitrary. One topic, Gray codes, was already used in the construction of quasi-random sequences (7.7), and here needs only some additional explication. Two other topics, on diagnosing a computers oating-point parameters, and on arbitrary precision arithmetic, give additional insight into the machinery behind the casual assumption that computers are useful for doing things with numbers (as opposed to bits or characters). The latter of these topics also shows a very different use for Chapter 12s fast Fourier transform. The three other topics (checksums, Huffman and arithmetic coding) involve different aspects of data coding, compression, and validation. If you handle a large amount of data  numerical data, even  then a passing familiarity with these subjects might at some point come in handy. In 13.6, for example, we already encountered a good use for Huffman coding. But again, you dont have to read this chapter. (And you should learn about quadrature from Chapters 4 and 16, not from a computer science text!)
20.1 Diagnosing Machine Parameters
A convenient ction is that a computers oating-point arithmetic is accurate enough. If you believe this ction, then numerical analysis becomes a very clean subject. Roundoff error disappears from view; many nite algorithms become exact; only docile truncation error (1.3) stands between you and a perfect calculation. Sounds rather naive, doesnt it? Yes, it is naive. Notwithstanding, it is a ction necessarily adopted throughout most of this book. To do a good job of answering the question of how roundoff error 889