gpt4 book ai didi

python - 对于给定的精度,float32 将给出与 float64 相同结果的最大值是多少?

转载 作者:行者123 更新时间:2023-12-02 15:55:01 25 4
gpt4 key购买 nike

使用 numpy,我试图了解可以从 float64 向下转换为 float32 且精度损失小于或等于 0.001 的最大值是多少。

由于在网上找不到简单的解释,所以很快想出了这段代码来测试:

result = {}
for j in range(1,1000):
for i in range (1, 1_000_000):
num = i + j/1000
x=np.array([num],dtype=np.float32)
y=np.array([num],dtype=np.float64)
if abs(x[0]-y[0]) > 0.001:
result[j] = i
break

根据结果,似乎任何正值 <32768 都可以安全地从 float64 向下转换为 float32,精度损失可以接受(给定 <=0.001 的标准)

这是正确的吗?有人可以解释背后的数学原理吗?

非常感谢

最佳答案

假设 IEEE 754 表示,float32具有 24 位有效数字精度,而 float64具有 53 位有效数字精度(“非正规”数字除外)。

为了表示绝对误差最大为 0.001 的数字,二进制小数点右边至少需要 9 位,这意味着数字四舍五入到最接近的 1/512 的倍数,因此有最大表示误差为 1/1024 = 0.0009765625 < 0.001。

一共24位有效位,小数点右边9位,小数点左边还有15位,可以表示小于215 = 32768的所有整数,正如您通过实验确定的那样。

但是,有一些高于这个阈值的数字仍然有小于 0.001 的误差。正如 Eric Postpischil 在他的评论中指出的那样,所有 float64 值都在 32768.0 和 32768.001 之间(最大正好是 32768+137438953/237),float32 转换为精确到 32768.0,满足您的精度要求。当然,任何恰好可以用 float32 表示的数字都不会出现表示错误。

关于python - 对于给定的精度,float32 将给出与 float64 相同结果的最大值是多少?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71649665/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com