递减和递增循环的不同结果
Different results for loops with decrement and increment
我开始意识到在递增和递减的迭代之间我没有得到相同的结果。当此数学表达式 n + (1/(i^4))
迭代并在其自身上添加一个新值 75 次以上时,我得到一个细微的差异,即 i
迭代次数。在 75 次迭代下,每个循环的结果保持不变。为什么会发生这种情况的任何想法?这是我的代码 运行:
y=0
for i in 1:75
y = y + (1/(i^4))
end
print("final y value: ",y,"\n")
x=0
for i in 75:-1:1
x = x + (1/(i^4))
end
print("final x value: ",x,"\n")
我为 x 和 y 得到了这个:
final y value: 1.0823224592496965
final x value: 1.0823224592496967
但是如果我将循环限制更改为 74 或更少(在以下示例中为 74),我会得到两个循环的相同结果:
final y value: 1.0823224276447583
final x value: 1.0823224276447583
这是因为 Float64 的精度导致在加法过程中出现浮点舍入错误。如果舍入误差很重要,您可以使用任意精度浮点数(即 BigFloats)来解决这个问题。
y = BigFloat(0)
#0.000000000000000000000000000000000000000000000000000000000000000000000000000000
for i in 1:75
y += 1/(i^4)
end
x = BigFloat(0)
for i in 75:-1:1
x += 1/(i^4)
end
print("final x value: ",x,"\n")
#final x value: 1.082322459249696627186876349853547531892905553263517504092305898666381835937500
print("final y value: ",y,"\n")
#final y value: 1.082322459249696627186876349853547531892905553263517504092305898666381835937500
另请注意,在您的原始代码中,您将 x 和 y 定义为 Int,然后继续向它们添加 Float64 - 这将严重降低您的代码速度 (https://docs.julialang.org/en/latest/manual/performance-tips/#Avoid-changing-the-type-of-a-variable-1)
我开始意识到在递增和递减的迭代之间我没有得到相同的结果。当此数学表达式 n + (1/(i^4))
迭代并在其自身上添加一个新值 75 次以上时,我得到一个细微的差异,即 i
迭代次数。在 75 次迭代下,每个循环的结果保持不变。为什么会发生这种情况的任何想法?这是我的代码 运行:
y=0
for i in 1:75
y = y + (1/(i^4))
end
print("final y value: ",y,"\n")
x=0
for i in 75:-1:1
x = x + (1/(i^4))
end
print("final x value: ",x,"\n")
我为 x 和 y 得到了这个:
final y value: 1.0823224592496965
final x value: 1.0823224592496967
但是如果我将循环限制更改为 74 或更少(在以下示例中为 74),我会得到两个循环的相同结果:
final y value: 1.0823224276447583
final x value: 1.0823224276447583
这是因为 Float64 的精度导致在加法过程中出现浮点舍入错误。如果舍入误差很重要,您可以使用任意精度浮点数(即 BigFloats)来解决这个问题。
y = BigFloat(0)
#0.000000000000000000000000000000000000000000000000000000000000000000000000000000
for i in 1:75
y += 1/(i^4)
end
x = BigFloat(0)
for i in 75:-1:1
x += 1/(i^4)
end
print("final x value: ",x,"\n")
#final x value: 1.082322459249696627186876349853547531892905553263517504092305898666381835937500
print("final y value: ",y,"\n")
#final y value: 1.082322459249696627186876349853547531892905553263517504092305898666381835937500
另请注意,在您的原始代码中,您将 x 和 y 定义为 Int,然后继续向它们添加 Float64 - 这将严重降低您的代码速度 (https://docs.julialang.org/en/latest/manual/performance-tips/#Avoid-changing-the-type-of-a-variable-1)