评估Math.tan(Math.acos(0d))

时间:2012-12-29 16:34:44

标签: java math

以下陈述不应该成立吗?

assertTrue(Double.isNaN(Math.tan(Math.acos(0d))));

但不是Double.NaN Java返回

6.123233995736766 * 10^-17    

在我的64位盒子上。

修改 这是一个复制和粘贴错误。事实上,Java返回1.633123935319537E16

我知道这是因为浮点表示,但我的印象是切线函数的那些未定义值将得到与例如相同的处理。 Math.sqrt(-1d)但我想在这种情况下java.lang.Math只是在评估之前检查参数是否为正。

1 个答案:

答案 0 :(得分:3)

我得到了不同的东西。

System.out.println(Math.tan(Math.acos(0d)));
// and the tan for the next representable value.
System.out.println(Math.tan(Math.acos(0d) + Math.ulp(Math.acos(0d))));

打印

1.633123935319537E16
-6.218431163823738E15

64位浮点不能完全表示PI / 2(它具有无穷多个数字),它表示接近此值的数字,并且该值的tan()是有限的。