为什么PHP浮点除法和POW会给出错误的结果和意外的结果?

有谁知道为什么会这样以及是否可以解决.我正在比较C和PHP的结果,但是PHP给了我不同的结果.

如果需要,我可以提供一些代码,但是以前有没有人经历过?

PHP代码

$tempnum = 1.0e - 5 * -44954; // substr($line1,53,6);
$bstar = $tempnum / pow(10.0, 3);

$bstar gives me -0.00044954 in PHP but it should be -0.000450

C代码

double tempnum = 1.0e - 5 * -44954;
double bstar = tempnum / pow(10.0, 3);

printf bstar gives me -0.000450

到目前为止,感谢您的答复,但是PHP如何得出这个结论…

$twopi =        6.28318530717958623;    /* 2*Pi  */
$xmnpda=        1440; //1.44E3  ;       /* Minutes per day */

$temp = (($twopi/$xmnpda)/$xmnpda);

$xndt2o = -0.000603;
$xndt2o = $xndt2o * $temp;

echo $xndt2o gives me -1.8256568188E-9 in PHP but in C it gives me -0.000000

我不知道PHP的全部含义.

解决方法:

精度有限的浮点格式几乎总是有点不准确,并且这些不正确之处会相互叠加并以意想不到的方式表现出来.通常,结果并没有那么多错误,但是唯一的问题是您没有想到不正确的地方.有关一般说明,请阅读The Floating-Point Guide.

也许与您的问题最相关:永远不要期望计算序列在平台之间产生完全相同的结果,因为有许多因素可能导致执行不同的实际基本操作. This paper explains it in great detail..

对于您所看到的差异的更简单的解释可能是,PHP代码以某种方式仅在某处使用32位浮点数,因为该差异显示在小数点6/7左右,而32位浮点数的精度恰好在此结束.

上一篇:在java分区操作中决定Nan和Infinity的是什么


下一篇:【JZOJ】6272. 整除 (division)