From: Jesse Pollard <pollard@tomcat.admin.navo.hpc.mil>
To: Nikita@Namesys.COM, Andrey Ulanov <drey@rt.mipt.ru>
Cc: linux-kernel@vger.kernel.org
Subject: Re: FPU, i386
Date: Wed, 17 Apr 2002 09:40:48 -0500 (CDT) [thread overview]
Message-ID: <200204171440.JAA76065@tomcat.admin.navo.hpc.mil> (raw)
--------- Received message begins Here ---------
>
> Andrey Ulanov writes:
> > Look at this:
> >
> > $ cat test.c
> > #include <stdio.h>
> >
> > main()
> > {
> > double h = 0.2;
> >
> > if(1/h == 5.0)
> > printf("1/h == 5.0\n");
> >
> > if(1/h < 5.0)
> > printf("1/h < 5.0\n");
> > return 0;
> > }
> > $ gcc test.c
>
> $ gcc -O test.c
> $ ./a.out
> 1/h == 5.0
>
> without -O, gcc initializes h to 0.2000000000000000111
>
> > $ ./a.out
> > 1/h < 5.0
> > $
> >
> > I also ran same a.out under FreeBSD. It says "1/h == 5.0".
> > It seems there is difference somewhere in FPU
> > initialization code. And I think it should be fixed.
Nope. -O2 implies constant folding, and h is a constant. What you are
compairing is runtime vs compile time values. 5.0 is compile time.
1/h where h is a constant is compile time (O2) and that would
come out at 5.0 also
Been there done that... My solution (based on the problem I was working
in) was to multiply both sides by the 10^<number of siginificant digits
of the problem set>. Taking the simplistic approach:
if (int(1/h * 100) == int(5.0 * 100))
will give a "proper" result within two decimal places. This is still
limited since there are irrational numbers within that range that COULD
still come out with a wrong answer, but is much less likely to occur.
Exact match of floating point is not possible - 1/h is eleveated to a float.
If your 1/h was actually num/h, and num computed by summing .01 100 times
I suspect the result would also be "wrong".
-------------------------------------------------------------------------
Jesse I Pollard, II
Email: pollard@navo.hpc.mil
Any opinions expressed are solely my own.
next reply other threads:[~2002-04-17 14:41 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2002-04-17 14:40 Jesse Pollard [this message]
2002-04-17 14:49 ` FPU, i386 John Alvord
2002-04-18 8:31 ` Jakob Østergaard
2002-04-25 13:09 ` rpm
2002-04-25 13:22 ` Andreas Schwab
2002-04-25 14:22 ` Richard B. Johnson
2002-04-25 15:24 ` Mark Mielke
2002-04-25 16:08 ` Richard B. Johnson
-- strict thread matches above, loose matches on Subject: below --
2002-04-29 16:19 Kerl, John
2002-04-26 22:10 Kerl, John
2002-04-29 12:33 ` Richard B. Johnson
[not found] <scc7dcc8.053@mail-02.med.umich.edu>
2002-04-25 14:52 ` Richard B. Johnson
2002-04-25 14:38 Nicholas Berry
2002-04-17 14:05 Andrey Ulanov
2002-04-17 14:20 ` Mike Black
2002-04-17 14:26 ` Richard B. Johnson
2002-04-17 14:29 ` Nikita Danilov
2002-04-17 15:20 ` Gunther Mayer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=200204171440.JAA76065@tomcat.admin.navo.hpc.mil \
--to=pollard@tomcat.admin.navo.hpc.mil \
--cc=Nikita@Namesys.COM \
--cc=drey@rt.mipt.ru \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox