我正在用Java和C/C++编写几个参考算法。其中一些算法使用π。我希望每种算法的两个实现都能产生相同的结果,而不会有不同的舍入。到目前为止,实现此操作的一种方法是使用自定义的pi常量,这在两种语言中都是完全相同的,比如3.14159。然而,当Java和GCC库中已经定义了高精度常量时,我觉得定义pi是愚蠢的。
我花了一些时间编写快速测试程序,查看每个库的文档,并阅读浮点类型。但我无法说服自己,在math.h中,java.lang.Math.PI (或java.lang.StrictMath.PI)是否等于M_PI。
GCC 3.4.4 (cygwin) math.h包含:
#define M_PI 3.14159265358979323846
^^^^^但这是
printf("%.20f", M_PI);产生
3.14159265358979311600
^^^^^这意味着最后的5位数是不可信的。
同时,Javadocs说java.lang.Math.PI是:
double值,它比任何其他值都更接近π,即圆周与直径的比值。
和
public static final double PI 3.141592653589793d从常量中忽略了可疑的最后五位数。
System.out.printf("%.20f\n", Math.PI);产生
3.14159265358979300000
^^^^^如果你在浮点数据类型方面有一些专长,你能让我相信这些库常量是完全相等的吗?还是说他们绝对不平等?
https://stackoverflow.com/questions/825559
复制相似问题