× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.


  • Subject: Re: Decimal rounding of a float data type in Java.
  • From: "James Donkin" <James@xxxxxxxxxxxxxxx>
  • Date: Fri, 2 Mar 2001 09:25:05 -0000
  • Organization: Du Maurier Design


> Well, not exactly.  Your "average" doesn't become 4.22, it becomes
something
> that's extremely close to 4.22.  Floating point numbers can't express
*any*
> fraction exactly unless it's a power of 0.5.  So don't be surprised if you
> do "System.out.println(average)" and you find something like
> "4.2200000000033775" appearing.
e.g. average = 422 / 100;

This will always give 4.22. The time you get problems is with 323 / 34 or
some other fraction which generates an irrational number. Saying that

    float average = 422 / 100;

 will give 4.22000032 is like saying that

    float average = 4.22;

 will leave average = 4.2200042. Dividing by 100 just generates a two digit
shift.

----- Original Message -----
From: Clapham, Paul <pclapham@core-mark.com>
To: <JAVA400-L@midrange.com>
Sent: Thursday, March 01, 2001 4:56 PM
Subject: RE: Decimal rounding of a float data type in Java.


> Well, not exactly.  Your "average" doesn't become 4.22, it becomes
something
> that's extremely close to 4.22.  Floating point numbers can't express
*any*
> fraction exactly unless it's a power of 0.5.  So don't be surprised if you
> do "System.out.println(average)" and you find something like
> "4.2200000000033775" appearing.  That was the problem experienced in the
> original post, I believe.  You can mask the problem by using a
DecimalFormat
> object to display the number, or you can use BigDecimal objects, but in
> either case you may get burned by rounding that you didn't expect.
> (BigDecimal provides a half-dozen different ways to round.)
>
> In commercial work this isn't likely to be much of a problem, but in
> scientific work it can be, and there's a whole field of mathematics
devoted
> to this kind of thing.
>
> PC2
>
> -----Original Message-----
> From: James Donkin [mailto:James@DuMaurier.co.uk]
> Sent: March 1, 2001 05:49
> To: JAVA400-L@midrange.com
> Subject: Re: Decimal rounding of a float data type in Java.
>
> </snip>
>
> One way for getting rid of the rounding problem would be to...
>
>     float roundedInt = Float.parseFloat(twoDigits.format( average ));
>
> Or you could...
>
>     int temp = (int)(average * 100);
>     average = (float)temp / 100;
>
> e.g. average = 4.222222222222
>       temp then =  422
>       average then becomes 4.22
>
> </snip>
> +---
> | This is the JAVA/400 Mailing List!
> | To submit a new message, send your mail to JAVA400-L@midrange.com.
> | To subscribe to this list send email to JAVA400-L-SUB@midrange.com.
> | To unsubscribe from this list send email to
JAVA400-L-UNSUB@midrange.com.
> | Questions should be directed to the list owner: joe@zappie.net
> +---
>

+---
| This is the JAVA/400 Mailing List!
| To submit a new message, send your mail to JAVA400-L@midrange.com.
| To subscribe to this list send email to JAVA400-L-SUB@midrange.com.
| To unsubscribe from this list send email to JAVA400-L-UNSUB@midrange.com.
| Questions should be directed to the list owner: joe@zappie.net
+---

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2024 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.