Powiel możliwe:
Python rounding error with float numbers
python maths is wrongBłąd w języku Python w podstawowym odejmowaniu?
nie mogę Python, aby poprawnie zrobić odejmowania 1 - 0,8 i przypisać ją. Nadchodzi z nieprawidłową odpowiedzią, 0.19999999999999996.
ja zbadałem trochę:
sq = {}
sub = {}
for i in range(1000):
sq[str(i/1000.)+'**2']=((i/1000.)**2)
sub['1-'+str(i/1000.)]=(1.0-(i/1000.))
i odkrył, że ten błąd ma miejsce z nieco przypadkowej grupy pływaków między 0 i 1 do trzeciego miejsca po przecinku. Podobny błąd występuje również, gdy wyrównasz te zmienne, ale w innym podzbiorze.
Mam nadzieję, że wyjaśnienie tego i jak sprawić, aby Python zrobił arytmetykę dobrze. Używanie round(x,3)
jest rozwiązaniem, którego obecnie używam, ale nie jest eleganckie.
Dzięki!
Jest to sesja w moim Python 2.7.3 shell:
*** Python 2.7.3 (default, Apr 10 2012, 23:24:47) [MSC v.1500 64 bit (AMD64)] on win32. ***
*** Remote Python engine is active ***
>>> 1-0.8
0.19999999999999996
>>> print 1-0.8
0.2
>>> a = 1-0.8
>>> a
0.19999999999999996
>>> print a
0.2
>>> a = 0.2
>>> print a
0.2
>>> a
0.2
>>>
Oto kod umieścić w kilku tłumaczy forum:
def doit():
d = {'a':1-0.8}
return d
print doit()
i wyjście:
{'a': 0.19999999999999996}
check http://www.yoda.arachsys.com/csharp/floatingpoint.html – avasal
http://effbot.org/pyfaq/why-are - obliczenia punktowe-tak-inaccurate.htm –