ID: 49871
Updated by: [email protected]
Reported By: daniel dot buschke at nextiraone dot de
Status: Bogus
Bug Type: Math related
Operating System: Linux
PHP Version: 5.2.11
New Comment:
Add
ini_set('precision',20);
to the top of your script. That sets the output precision and will
cause your var_dump() to show:
--------- 2.3199999999999998401 --------
float(2.3199999999999998401)
float(231.99999999999997158)
int(231)
--------- 8.2799999999999993605 --------
float(8.2799999999999993605)
float(827.99999999999988631)
int(827)
This precision setting, because it is lossy, isn't applied until you
try to convert the float to a string, usually on output, but as the
previous comment mentioned, you could force it to apply before output
with an explicit conversion. Or you can set your own fuzz factor and
use that. If we magically applied this precision setting on every math
operation, these small floating point errors would become much bigger
when you actually were expecting your floating point to behave as
floating point values.
Previous Comments:
------------------------------------------------------------------------
[2009-10-14 11:37:44] daniel dot buschke at nextiraone dot de
(int)(string)$b
that does the job but is ugly, too
------------------------------------------------------------------------
[2009-10-14 11:16:23] [email protected]
Floating point values have a limited precision. Hence a value might
not have the same string representation after any processing. That also
includes writing a floating point value in your script and directly
printing it without any mathematical operations.
If you would like to know more about "floats" and what IEEE
754 is, read this:
http://docs.sun.com/source/806-3568/ncg_goldberg.html
Thank you for your interest in PHP.
------------------------------------------------------------------------
[2009-10-14 08:36:03] daniel dot buschke at nextiraone dot de
Description:
------------
Hi,
when I convert following float:
float(232)
into an int I get:
int(231).
The float was calculated by 2.32 * 100. I know that this may result in
232.00000000001 or 231.999999999 but the behavior is unexcpected because
var_dump does not show the real (more or less wrong) float number.
This one is exact the same as #2835 but the bug was closed without any
further comments. The provided solution is unacceptable.
How to convert 2.32 into an integer of the value 232?
BTW: Please do not set this bug to bogus or closed with the default
text for that problem ;-). As you can see in your bugtracker the
community wants a solution for that. Please also remember that PHP is a
scripting language which mainly ignores datatypes. This problem is not
comprehensible to beginners (webdesigners ;-) ).
I do not want to blame you with that but I just want to find a usefull
solution. Please keep communication with community.
regards
Daniel
Reproduce code:
---------------
<?php
messUpFloat(2.32);
messUpFloat(8.28);
function messUpFloat($float) {
echo '--------- ' . $float . ' --------' . PHP_EOL;
$a = $float;
var_dump($a);
$b = $a * 100 + 0;
var_dump($b);
$c = (int)$b;
var_dump($c);
}
?>
Expected result:
----------------
--------- 2.32 --------
float(2.32)
float(232)
int(232)
--------- 8.28 --------
float(8.28)
float(828)
int(828)
or (but not preferred ;-) )
--------- 2.32 --------
float(2.32)
float(231.999999999999999)
int(231)
--------- 8.28 --------
float(8.28)
float(827.999999999999999)
int(827)
Actual result:
--------------
--------- 2.32 --------
float(2.32)
float(232)
int(231)
--------- 8.28 --------
float(8.28)
float(828)
int(827)
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=49871&edit=1