提问人:Brianna Drew 提问时间:1/31/2021 更新时间:1/31/2021 访问量:77
为什么在 Python 中这两个被证明相等的小数中的某些被认为是不相等的?
Why are some of these two proven-to-be-equal decimals in Python considered not to be equal?
问:
我正在尝试比较将多个浮点数相加与将多个小数相加之间的准确性,以便在我的 Python 课程中进行实验。实验室的要求之一是计算将 .1 相加的迭代次数得出正确的总和。我的代码中的所有内容都正常工作,除了我的计数器,即十进制加法的加法数是正确的。对于 100 次迭代,它只计 20 次是正确的(每 5 次迭代),即使我已经通过打印每次迭代来证明它们都是正确的。为什么会发生这种情况,如何解决这个问题?谢谢。(您可以在下面找到完整的代码以获取完整的上下文和输出。
法典:
from decimal import *
floatSum = 0
decSum = 0
toAddFloat = .1
toAddDec = Decimal(".1")
max = 100 # number of iterations
floatCorrect = 0
decCorrect = 0
# continually add .1 as floats together for specified number of iterations
for i in range (0, max, 1):
floatSum = floatSum + toAddFloat
print(floatSum,(i + 1) / 10)
if (floatSum == (i + 1) / 10): # check if the addition is what it should be
floatCorrect += 1
i = 0
# continually add .1 as decimals together for specified number of iterations
for i in range (0, max, 1):
decSum = decSum + toAddDec
print(decSum, (i + 1) / 10)
print(decCorrect)
if (decSum == (i + 1) / 10): # check if the addition is what it should be
decCorrect += 1
print("\nFLOAT RESULTS:")
print("--------------")
print("Iterations: ", max, ", Added Number: ", toAddFloat, ", Calculated Sum: ", floatSum,
", Times Correct: ", floatCorrect, ", Correct Result: ", toAddFloat * max, ", Difference: ", (toAddFloat * max) - floatSum, "\n")
print("DECIMAL RESULTS:")
print("----------------")
print("Iterations: ", max, ", Added Number: ", toAddDec, ", Calculated Sum: ", decSum,
", Times Correct: ", decCorrect, ", Correct Result: ", toAddDec * max, ", Difference: ", (toAddDec * max) - decSum)
(部分)输出:
FLOAT RESULTS:
--------------
Iterations: 100 , Added Number: 0.1 , Calculated Sum: 9.99999999999998 , Times Correct: 11 , Correct Result: 10.0 , Difference: 1.9539925233402755e-14
DECIMAL RESULTS:
----------------
Iterations: 100 , Added Number: 0.1 , Calculated Sum: 10.0 , Times Correct: 20 , Correct Result: 10.0 , Difference: 0.0
答:
0赞
Bing Wang
1/31/2021
#1
将此行更新为
if (decSum*10 == (i + 1)):
对于 Python,除法给出浮点结果。如果这个数字没有像它看起来那样精确地呈现,它就赢了;t 等于小数点对应项。
评论