ID: 43624 Updated by: [EMAIL PROTECTED] Reported By: csaba at alum dot mit dot edu -Status: Open +Status: Bogus Bug Type: Math related Operating System: Win XP PHP Version: 5.2.5 New Comment:
Discuss using mails. This is not a discussion forum! Previous Comments: ------------------------------------------------------------------------ [2007-12-18 15:41:10] [EMAIL PROTECTED] C code: --- float a = 6.5, b = 1.3; double c = 6.5, d = 1.3; puts("Float:"); printf("%f\n", fmod(a, b)); printf("%f\n", a / b); printf("%f\n", b - fmod(a, b)); puts("Double:"); printf("%G\n", fmod(c, d)); printf("%G\n", c / d); printf("%G\n", d - fmod(c, d)); --- Result: Float: 0.000000 5.000000 1.300000 Double: 1.3 5 2.22045E-16 ------------------------------------------------------------------------ [2007-12-18 14:36:48] csaba at alum dot mit dot edu Description: ------------ This continues bug report 43572 at http://bugs.php.net/bug.php?id=43572&edit=2 which discussion is incomplete, yet has been prematurely closed. > The value that you expect (0) is obtained using float precision. > (In C) PHP uses double, and with this type fmod() returns 1.3. So, to be concrete: $a = 6.5; print gettype($a); // double $b = 1.3; print gettype($b); // double $c = $a / $b; print gettype($c); // double $d = 5.0; print gettype ($d); // double print $c - $d; // 0 print (gettype($c - $d)); // double print ($c===$d) ? "same" : "different"; // same print gettype ($b - fmod($a, $b)); // double print $b - fmod($a, $b); // 2.22044604925E-16 In other words, PHP's own (double) math shows that 6.5 / 1.3 === 5.0 Regardless of the internal representation and precision of 6.5 and 1.3, division of the former ($a) by the latter ($b) results in a double value identical to 5.0. fMod should return 0 in this situation. Csaba Gabor from New York PS. I would prefer that these comments be moved to bug 43572 and that it be reopened until the discussion is completed, rather than having multiple threads. ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=43624&edit=1