f9cbe6bc47
Formerly, py/formatfloat would print whole numbers inaccurately with nonzero digits beyond the decimal place. This resulted from its strategy of successive scaling of the argument by 0.1 which cannot be exactly represented in floating point. The change in this commit avoids scaling until the value is smaller than 1, so all whole numbers print with zero fractional part. Fixes issue #4212. Signed-off-by: Dan Ellis dan.ellis@gmail.com
16 lines
540 B
Python
16 lines
540 B
Python
# Test formatting of very large ints.
|
|
# Relies on double-precision floats.
|
|
|
|
import array
|
|
import sys
|
|
|
|
# Challenging way to express 1e200 and 1e100.
|
|
print("{:.12e}".format(float("9" * 400 + "e-200")))
|
|
print("{:.12e}".format(float("9" * 400 + "e-300")))
|
|
|
|
# These correspond to the binary representation of 1e200 in float64s:
|
|
v1 = 0x54B249AD2594C37D # 1e100
|
|
v2 = 0x6974E718D7D7625A # 1e200
|
|
print("{:.12e}".format(array.array("d", v1.to_bytes(8, sys.byteorder))[0]))
|
|
print("{:.12e}".format(array.array("d", v2.to_bytes(8, sys.byteorder))[0]))
|