Re: magic integer converter number 62?
Re: magic integer converter number 62?
- Subject: Re: magic integer converter number 62?
- From: Chris Nebel <email@hidden>
- Date: Thu, 22 Feb 2001 14:49:18 -0800
- Organization: Apple Computer, Inc.
M Shaw wrote:
>
Can anybody figure out why this works:
>
>
set x to 62
>
set b to ((x + (2.6 - (2.6 mod 1))) - x) as integer
>
>
and this doesn't:
>
>
set x to 61
>
set b to ((x + (2.6 - (2.6 mod 1))) - x) as integer
OK, this has gone on quite long enough. The basic problem has to do
with the limitations of finite-precision numbers. What scripting
additions you have installed makes no difference, but the version of
AppleScript does, since we've tweaked the behavior several times.
(Obviously, it's still not quite right.)
AppleScript does its floating point math using IEEE double-precision
numbers, which are stored as a fractional part from zero to one and an
exponent, both in binary. The tricky bit is that many numbers that look
clean to us (e.g. 232 or 0.6) are long repeating "decimals" in binary,
and therefore can't be stored exactly given a finite number of bits --
in this case, 48.
In most cases, this doesn't matter much -- you're only interested in the
first few decimal places anyway, and the inaccuracy is down around the
12th decimal place. However, naive div and mod will amplify these
errors, so you have to fudge things slightly to come up with the "right"
answer. If it's done wrong, you wind up with answers that are off by
one from what you expect, or numbers that look like they're integral but
aren't. Additionally, "as integer" has always been extremely intolerant
of low-order noise. This is all on our list of things to fix for
post-1.6.
--Chris Nebel
AppleScript Engineering