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

标签 java math

下面的说法不应该成立吗?

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

但是 Java 返回的不是 Double.NaN

6.123233995736766 * 10^-17    

在我的 64 位机器上。

编辑: 这是复制和粘贴错误。事实上,Java 返回 1.633123935319537E16

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

最佳答案

我得到了一些不同的东西。

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() 是有限的。

关于java - 评估 Math.tan(Math.acos(0d)),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14083681/

相关文章:

用于递归计算ln(n!)的java方法

c++ - 我应该使用哪种方法来确定 2D、3D 和 4D(四元数) vector 的相似性?

java - 将 @RolesAllowed 注释应用于数据库中存储的现有用户

java - onPostExecute 中来自 AsyncTask 的 setText

java - hibernate支持自关联吗?

algorithm - 给定平面上的两条线,如何找到最接近它们交点的整数点?

java - 创建具有多个 View 、许多组件和内存问题的大型 Web 应用程序的最佳实践

java - 更新 mongoDB

algorithm - 找到矩阵中最后一个像螺旋一样行走的正方形

javascript - 如何在给定公差的情况下四舍五入到最接近的整数