diff options
author | Jim Meyering <jim@meyering.net> | 2000-03-12 17:54:52 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2000-03-12 17:54:52 +0000 |
commit | fb190362cc82a9ed073cb2ba618eee463c760d13 (patch) | |
tree | e9fea7c7588d33c21ad08b5eb8105f373c80dd10 /doc | |
parent | d21d0a4c040bb2655e068d402f2cb0020813c318 (diff) | |
download | coreutils-fb190362cc82a9ed073cb2ba618eee463c760d13.tar.xz |
describe seq gotcha re FP arith
Diffstat (limited to 'doc')
-rw-r--r-- | doc/sh-utils.texi | 37 |
1 files changed, 33 insertions, 4 deletions
diff --git a/doc/sh-utils.texi b/doc/sh-utils.texi index d1c3fe1d6..069a39e1f 100644 --- a/doc/sh-utils.texi +++ b/doc/sh-utils.texi @@ -3175,13 +3175,13 @@ $ factor `echo '2^64-1'|bc` @code{seq} prints a sequence of numbers to standard output. Synopses: @example -seq [@var{option}]@dots{} [@var{first} [@var{step}]] @var{last}@dots{} +seq [@var{option}]@dots{} [@var{first} [@var{increment}]] @var{last}@dots{} @end example @code{seq} prints the numbers from @var{first} to @var{last} by -@var{step}. By default, @var{first} and @var{step} are both 1, and each -number is printed on its own line. All numbers can be reals, not just -integers. +@var{increment}. By default, @var{first} and @var{increment} are both 1, +and each number is printed on its own line. All numbers can be reals, +not just integers. The program accepts the following options. Also see @ref{Common options}. @@ -3269,6 +3269,35 @@ FFFFFFFF 100000000 @end example +Be careful when using @code{seq} with a fractional @var{increment}, +otherwise you may see surprising results. Most people would expect to +see @code{0.3} printed as the last number in this example: + +@example +$ seq -s' ' 0 .1 .3 +0 0.1 0.2 +@end example + +But doesn't happen on most systems because @code{seq} is implemented using +binary floating point arithmetic (via the C @code{double} type) -- which +means some decimal numbers like @code{.1} cannot be represented exactly. +That in turn means some nonintuitive conditions like @code{.1 * 3 > .3} +will end up being true. + +To work around that in the above example, use a slightly larger number as +the @var{last} value: + +@example +$ seq -s' ' 0 .1 .31 +0 0.1 0.2 0.3 +@end example + +In general, when using an @var{increment} with a fractional part, where +(@var{last} - @var{first}) / @var{increment} is (mathematically) a whole +number, specify a slightly larger (or smaller, if @var{increment} is negative) +value for @var{last} to ensure that @var{last} is the final value printed +by seq. + @node Index @unnumbered Index |