Parece que JDK 8 y JDK 13 tienen puntos flotantes diferentes.
Me meto en JDK 8, usando Math:
cos(2.3) = -0.666276021279824
Y en JDK 13:
cos(2.3) = -0.6662760212798241
¿Como sucedió esto? La diferencia se muestra en Intel de 11.ª generación y en AMD Ryzen con Windows 10.
Editar 20.03.2022:
Usando Long.toHexString(Double.doubleToRawLongBits()) obtengo diferentes patrones de bits:
Me pongo en JDK 8:
cos(2.3) = 0xbfe5522217302fe0
Y me meto en JDK 13:
cos(2.3) = 0xbfe5522217302fe1
Esto parece deberse a una función intrínseca de JVM para Math.cos
, que se describe en el problema relacionado JDK-8242461 . El comportamiento experimentado allí no se considera un problema:
Los resultados devueltos informados en este error son, de hecho, valores de punto flotante adyacentes [ este también es el caso aquí ]
[...]
Por lo tanto, si bien es posible que uno u otro de los valores devueltos esté fuera de los límites de precisión, tener valores devueltos diferentes para Math.cos no es en sí mismo evidencia de un problema.
Para obtener resultados reproducibles, utilice StrictMath.cos en su lugar.
Y, de hecho, deshabilitar los intrínsecos usando -XX:+UnlockDiagnosticVMOptions -XX:DisableIntrinsic=_dcos
(como se propone en el problema vinculado), hace que Math.cos
tenga el mismo resultado (esperado) que StrictMath.cos
.
Por lo tanto, parece que el comportamiento que está viendo aquí probablemente también cumpla con la documentación de Math
.