blob: 4e6f85469795a969ea75a0d78796ef3b0ed88da5 [file] [log] [blame]
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001
2import unittest, struct
Christian Heimes827b35c2007-12-10 22:19:17 +00003import os
Eric Smith0923d1d2009-04-16 20:16:10 +00004import sys
Benjamin Petersonee8712c2008-05-20 21:35:26 +00005from test import support
Christian Heimes53876d92008-04-19 00:31:39 +00006import math
Mark Dickinson65fe25e2008-07-16 11:30:51 +00007from math import isinf, isnan, copysign, ldexp
Christian Heimes53876d92008-04-19 00:31:39 +00008import operator
Amaury Forgeot d'Arc7e958d12008-09-06 21:03:22 +00009import random, fractions
Michael W. Hudsonba283e22005-05-27 15:23:20 +000010
Christian Heimes53876d92008-04-19 00:31:39 +000011INF = float("inf")
12NAN = float("nan")
Christian Heimes99170a52007-12-19 02:07:34 +000013
Benjamin Petersone401c682010-07-02 23:25:44 +000014have_getformat = hasattr(float, "__getformat__")
15requires_getformat = unittest.skipUnless(have_getformat,
16 "requires __getformat__")
17requires_setformat = unittest.skipUnless(hasattr(float, "__setformat__"),
18 "requires __setformat__")
Mark Dickinson9ab44b52009-12-30 16:22:49 +000019
Eric Smith0923d1d2009-04-16 20:16:10 +000020#locate file with float format test values
21test_dir = os.path.dirname(__file__) or os.curdir
22format_testfile = os.path.join(test_dir, 'formatfloat_testcases.txt')
23
Christian Heimes81ee3ef2008-05-04 22:42:01 +000024class GeneralFloatCases(unittest.TestCase):
25
26 def test_float(self):
27 self.assertEqual(float(3.14), 3.14)
28 self.assertEqual(float(314), 314.0)
29 self.assertEqual(float(" 3.14 "), 3.14)
Amaury Forgeot d'Arc7e958d12008-09-06 21:03:22 +000030 self.assertEqual(float(b" 3.14 "), 3.14)
Christian Heimes81ee3ef2008-05-04 22:42:01 +000031 self.assertRaises(ValueError, float, " 0x3.1 ")
32 self.assertRaises(ValueError, float, " -0x3.p-1 ")
33 self.assertRaises(ValueError, float, " +0x3.p-1 ")
34 self.assertRaises(ValueError, float, "++3.14")
35 self.assertRaises(ValueError, float, "+-3.14")
36 self.assertRaises(ValueError, float, "-+3.14")
37 self.assertRaises(ValueError, float, "--3.14")
Eric Smith0923d1d2009-04-16 20:16:10 +000038 self.assertRaises(ValueError, float, ".nan")
39 self.assertRaises(ValueError, float, "+.inf")
40 self.assertRaises(ValueError, float, ".")
41 self.assertRaises(ValueError, float, "-.")
Alexander Belopolsky942af5a2010-12-04 03:38:46 +000042 self.assertRaises(ValueError, float, b"-")
43 self.assertRaises(TypeError, float, {})
44 # Lone surrogate
45 self.assertRaises(UnicodeEncodeError, float, '\uD8F0')
Mark Dickinsonc2d86892010-02-12 21:18:34 +000046 # check that we don't accept alternate exponent markers
47 self.assertRaises(ValueError, float, "-1.7d29")
48 self.assertRaises(ValueError, float, "3D-14")
Alexander Belopolsky942af5a2010-12-04 03:38:46 +000049 self.assertEqual(float(" \u0663.\u0661\u0664 "), 3.14)
50 self.assertEqual(float("\N{EM SPACE}3.14\N{EN SPACE}"), 3.14)
Mark Dickinsona9023be2009-10-27 22:12:20 +000051 # extra long strings should not be a problem
52 float(b'.' + b'1'*1000)
53 float('.' + '1'*1000)
Christian Heimes81ee3ef2008-05-04 22:42:01 +000054
Alexander Belopolsky942af5a2010-12-04 03:38:46 +000055 def test_error_message(self):
56 testlist = ('\xbd', '123\xbd', ' 123 456 ')
57 for s in testlist:
58 try:
59 float(s)
60 except ValueError as e:
61 self.assertIn(s.strip(), e.args[0])
62 else:
63 self.fail("Expected int(%r) to raise a ValueError", s)
64
65
Benjamin Petersonee8712c2008-05-20 21:35:26 +000066 @support.run_with_locale('LC_NUMERIC', 'fr_FR', 'de_DE')
Christian Heimes81ee3ef2008-05-04 22:42:01 +000067 def test_float_with_comma(self):
68 # set locale to something that doesn't use '.' for the decimal point
69 # float must not accept the locale specific decimal point but
Ezio Melotti13925002011-03-16 11:05:33 +020070 # it still has to accept the normal python syntax
Christian Heimes81ee3ef2008-05-04 22:42:01 +000071 import locale
72 if not locale.localeconv()['decimal_point'] == ',':
73 return
74
75 self.assertEqual(float(" 3.14 "), 3.14)
76 self.assertEqual(float("+3.14 "), 3.14)
77 self.assertEqual(float("-3.14 "), -3.14)
78 self.assertEqual(float(".14 "), .14)
79 self.assertEqual(float("3. "), 3.0)
80 self.assertEqual(float("3.e3 "), 3000.0)
81 self.assertEqual(float("3.2e3 "), 3200.0)
82 self.assertEqual(float("2.5e-1 "), 0.25)
83 self.assertEqual(float("5e-1"), 0.5)
84 self.assertRaises(ValueError, float, " 3,14 ")
85 self.assertRaises(ValueError, float, " +3,14 ")
86 self.assertRaises(ValueError, float, " -3,14 ")
87 self.assertRaises(ValueError, float, " 0x3.1 ")
88 self.assertRaises(ValueError, float, " -0x3.p-1 ")
89 self.assertRaises(ValueError, float, " +0x3.p-1 ")
90 self.assertEqual(float(" 25.e-1 "), 2.5)
Eli Bendersky67ebabd2011-02-25 10:14:17 +000091 self.assertAlmostEqual(float(" .25e-1 "), .025)
Christian Heimes81ee3ef2008-05-04 22:42:01 +000092
93 def test_floatconversion(self):
94 # Make sure that calls to __float__() work properly
95 class Foo0:
96 def __float__(self):
97 return 42.
98
99 class Foo1(object):
100 def __float__(self):
101 return 42.
102
103 class Foo2(float):
104 def __float__(self):
105 return 42.
106
107 class Foo3(float):
108 def __new__(cls, value=0.):
109 return float.__new__(cls, 2*value)
110
111 def __float__(self):
112 return self
113
114 class Foo4(float):
115 def __float__(self):
116 return 42
117
Benjamin Peterson2808d3c2009-04-15 21:34:27 +0000118 # Issue 5759: __float__ not called on str subclasses (though it is on
119 # unicode subclasses).
120 class FooStr(str):
121 def __float__(self):
122 return float(str(self)) + 1
123
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000124 self.assertAlmostEqual(float(Foo0()), 42.)
125 self.assertAlmostEqual(float(Foo1()), 42.)
126 self.assertAlmostEqual(float(Foo2()), 42.)
127 self.assertAlmostEqual(float(Foo3(21)), 42.)
128 self.assertRaises(TypeError, float, Foo4(42))
Benjamin Peterson2808d3c2009-04-15 21:34:27 +0000129 self.assertAlmostEqual(float(FooStr('8')), 9.)
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000130
131 def test_floatasratio(self):
132 for f, ratio in [
133 (0.875, (7, 8)),
134 (-0.875, (-7, 8)),
135 (0.0, (0, 1)),
136 (11.5, (23, 2)),
137 ]:
138 self.assertEqual(f.as_integer_ratio(), ratio)
139
140 for i in range(10000):
141 f = random.random()
142 f *= 10 ** random.randint(-100, 100)
143 n, d = f.as_integer_ratio()
144 self.assertEqual(float(n).__truediv__(d), f)
145
146 R = fractions.Fraction
147 self.assertEqual(R(0, 1),
148 R(*float(0.0).as_integer_ratio()))
149 self.assertEqual(R(5, 2),
150 R(*float(2.5).as_integer_ratio()))
151 self.assertEqual(R(1, 2),
152 R(*float(0.5).as_integer_ratio()))
153 self.assertEqual(R(4728779608739021, 2251799813685248),
154 R(*float(2.1).as_integer_ratio()))
155 self.assertEqual(R(-4728779608739021, 2251799813685248),
156 R(*float(-2.1).as_integer_ratio()))
157 self.assertEqual(R(-2100, 1),
158 R(*float(-2100.0).as_integer_ratio()))
159
160 self.assertRaises(OverflowError, float('inf').as_integer_ratio)
161 self.assertRaises(OverflowError, float('-inf').as_integer_ratio)
162 self.assertRaises(ValueError, float('nan').as_integer_ratio)
163
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000164 def test_float_containment(self):
165 floats = (INF, -INF, 0.0, 1.0, NAN)
166 for f in floats:
Benjamin Peterson577473f2010-01-19 00:09:57 +0000167 self.assertIn(f, [f])
Benjamin Peterson577473f2010-01-19 00:09:57 +0000168 self.assertIn(f, (f,))
Benjamin Peterson577473f2010-01-19 00:09:57 +0000169 self.assertIn(f, {f})
Benjamin Peterson577473f2010-01-19 00:09:57 +0000170 self.assertIn(f, {f: None})
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000171 self.assertEqual([f].count(f), 1, "[].count('%r') != 1" % f)
Benjamin Peterson577473f2010-01-19 00:09:57 +0000172 self.assertIn(f, floats)
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000173
174 for f in floats:
175 # nonidentical containers, same type, same contents
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000176 self.assertTrue([f] == [f], "[%r] != [%r]" % (f, f))
177 self.assertTrue((f,) == (f,), "(%r,) != (%r,)" % (f, f))
178 self.assertTrue({f} == {f}, "{%r} != {%r}" % (f, f))
179 self.assertTrue({f : None} == {f: None}, "{%r : None} != "
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000180 "{%r : None}" % (f, f))
181
182 # identical containers
183 l, t, s, d = [f], (f,), {f}, {f: None}
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000184 self.assertTrue(l == l, "[%r] not equal to itself" % f)
185 self.assertTrue(t == t, "(%r,) not equal to itself" % f)
186 self.assertTrue(s == s, "{%r} not equal to itself" % f)
187 self.assertTrue(d == d, "{%r : None} not equal to itself" % f)
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000188
Mark Dickinson9ab44b52009-12-30 16:22:49 +0000189 def assertEqualAndEqualSign(self, a, b):
190 # fail unless a == b and a and b have the same sign bit;
191 # the only difference from assertEqual is that this test
Ezio Melotti13925002011-03-16 11:05:33 +0200192 # distinguishes -0.0 and 0.0.
Mark Dickinson9ab44b52009-12-30 16:22:49 +0000193 self.assertEqual((a, copysign(1.0, a)), (b, copysign(1.0, b)))
194
Eric Smith3ab08ca2010-12-04 15:17:38 +0000195 @support.requires_IEEE_754
Mark Dickinsond2a9b202010-12-04 12:25:30 +0000196 def test_float_mod(self):
197 # Check behaviour of % operator for IEEE 754 special cases.
198 # In particular, check signs of zeros.
199 mod = operator.mod
200
201 self.assertEqualAndEqualSign(mod(-1.0, 1.0), 0.0)
202 self.assertEqualAndEqualSign(mod(-1e-100, 1.0), 1.0)
203 self.assertEqualAndEqualSign(mod(-0.0, 1.0), 0.0)
204 self.assertEqualAndEqualSign(mod(0.0, 1.0), 0.0)
205 self.assertEqualAndEqualSign(mod(1e-100, 1.0), 1e-100)
206 self.assertEqualAndEqualSign(mod(1.0, 1.0), 0.0)
207
208 self.assertEqualAndEqualSign(mod(-1.0, -1.0), -0.0)
209 self.assertEqualAndEqualSign(mod(-1e-100, -1.0), -1e-100)
210 self.assertEqualAndEqualSign(mod(-0.0, -1.0), -0.0)
211 self.assertEqualAndEqualSign(mod(0.0, -1.0), -0.0)
212 self.assertEqualAndEqualSign(mod(1e-100, -1.0), -1.0)
213 self.assertEqualAndEqualSign(mod(1.0, -1.0), -0.0)
214
Eric Smith3ab08ca2010-12-04 15:17:38 +0000215 @support.requires_IEEE_754
Mark Dickinson9ab44b52009-12-30 16:22:49 +0000216 def test_float_pow(self):
217 # test builtin pow and ** operator for IEEE 754 special cases.
218 # Special cases taken from section F.9.4.4 of the C99 specification
219
220 for pow_op in pow, operator.pow:
221 # x**NAN is NAN for any x except 1
222 self.assertTrue(isnan(pow_op(-INF, NAN)))
223 self.assertTrue(isnan(pow_op(-2.0, NAN)))
224 self.assertTrue(isnan(pow_op(-1.0, NAN)))
225 self.assertTrue(isnan(pow_op(-0.5, NAN)))
226 self.assertTrue(isnan(pow_op(-0.0, NAN)))
227 self.assertTrue(isnan(pow_op(0.0, NAN)))
228 self.assertTrue(isnan(pow_op(0.5, NAN)))
229 self.assertTrue(isnan(pow_op(2.0, NAN)))
230 self.assertTrue(isnan(pow_op(INF, NAN)))
231 self.assertTrue(isnan(pow_op(NAN, NAN)))
232
233 # NAN**y is NAN for any y except +-0
234 self.assertTrue(isnan(pow_op(NAN, -INF)))
235 self.assertTrue(isnan(pow_op(NAN, -2.0)))
236 self.assertTrue(isnan(pow_op(NAN, -1.0)))
237 self.assertTrue(isnan(pow_op(NAN, -0.5)))
238 self.assertTrue(isnan(pow_op(NAN, 0.5)))
239 self.assertTrue(isnan(pow_op(NAN, 1.0)))
240 self.assertTrue(isnan(pow_op(NAN, 2.0)))
241 self.assertTrue(isnan(pow_op(NAN, INF)))
242
243 # (+-0)**y raises ZeroDivisionError for y a negative odd integer
244 self.assertRaises(ZeroDivisionError, pow_op, -0.0, -1.0)
245 self.assertRaises(ZeroDivisionError, pow_op, 0.0, -1.0)
246
247 # (+-0)**y raises ZeroDivisionError for y finite and negative
248 # but not an odd integer
249 self.assertRaises(ZeroDivisionError, pow_op, -0.0, -2.0)
250 self.assertRaises(ZeroDivisionError, pow_op, -0.0, -0.5)
251 self.assertRaises(ZeroDivisionError, pow_op, 0.0, -2.0)
252 self.assertRaises(ZeroDivisionError, pow_op, 0.0, -0.5)
253
254 # (+-0)**y is +-0 for y a positive odd integer
255 self.assertEqualAndEqualSign(pow_op(-0.0, 1.0), -0.0)
256 self.assertEqualAndEqualSign(pow_op(0.0, 1.0), 0.0)
257
258 # (+-0)**y is 0 for y finite and positive but not an odd integer
259 self.assertEqualAndEqualSign(pow_op(-0.0, 0.5), 0.0)
260 self.assertEqualAndEqualSign(pow_op(-0.0, 2.0), 0.0)
261 self.assertEqualAndEqualSign(pow_op(0.0, 0.5), 0.0)
262 self.assertEqualAndEqualSign(pow_op(0.0, 2.0), 0.0)
263
264 # (-1)**+-inf is 1
265 self.assertEqualAndEqualSign(pow_op(-1.0, -INF), 1.0)
266 self.assertEqualAndEqualSign(pow_op(-1.0, INF), 1.0)
267
268 # 1**y is 1 for any y, even if y is an infinity or nan
269 self.assertEqualAndEqualSign(pow_op(1.0, -INF), 1.0)
270 self.assertEqualAndEqualSign(pow_op(1.0, -2.0), 1.0)
271 self.assertEqualAndEqualSign(pow_op(1.0, -1.0), 1.0)
272 self.assertEqualAndEqualSign(pow_op(1.0, -0.5), 1.0)
273 self.assertEqualAndEqualSign(pow_op(1.0, -0.0), 1.0)
274 self.assertEqualAndEqualSign(pow_op(1.0, 0.0), 1.0)
275 self.assertEqualAndEqualSign(pow_op(1.0, 0.5), 1.0)
276 self.assertEqualAndEqualSign(pow_op(1.0, 1.0), 1.0)
277 self.assertEqualAndEqualSign(pow_op(1.0, 2.0), 1.0)
278 self.assertEqualAndEqualSign(pow_op(1.0, INF), 1.0)
279 self.assertEqualAndEqualSign(pow_op(1.0, NAN), 1.0)
280
281 # x**+-0 is 1 for any x, even if x is a zero, infinity, or nan
282 self.assertEqualAndEqualSign(pow_op(-INF, 0.0), 1.0)
283 self.assertEqualAndEqualSign(pow_op(-2.0, 0.0), 1.0)
284 self.assertEqualAndEqualSign(pow_op(-1.0, 0.0), 1.0)
285 self.assertEqualAndEqualSign(pow_op(-0.5, 0.0), 1.0)
286 self.assertEqualAndEqualSign(pow_op(-0.0, 0.0), 1.0)
287 self.assertEqualAndEqualSign(pow_op(0.0, 0.0), 1.0)
288 self.assertEqualAndEqualSign(pow_op(0.5, 0.0), 1.0)
289 self.assertEqualAndEqualSign(pow_op(1.0, 0.0), 1.0)
290 self.assertEqualAndEqualSign(pow_op(2.0, 0.0), 1.0)
291 self.assertEqualAndEqualSign(pow_op(INF, 0.0), 1.0)
292 self.assertEqualAndEqualSign(pow_op(NAN, 0.0), 1.0)
293 self.assertEqualAndEqualSign(pow_op(-INF, -0.0), 1.0)
294 self.assertEqualAndEqualSign(pow_op(-2.0, -0.0), 1.0)
295 self.assertEqualAndEqualSign(pow_op(-1.0, -0.0), 1.0)
296 self.assertEqualAndEqualSign(pow_op(-0.5, -0.0), 1.0)
297 self.assertEqualAndEqualSign(pow_op(-0.0, -0.0), 1.0)
298 self.assertEqualAndEqualSign(pow_op(0.0, -0.0), 1.0)
299 self.assertEqualAndEqualSign(pow_op(0.5, -0.0), 1.0)
300 self.assertEqualAndEqualSign(pow_op(1.0, -0.0), 1.0)
301 self.assertEqualAndEqualSign(pow_op(2.0, -0.0), 1.0)
302 self.assertEqualAndEqualSign(pow_op(INF, -0.0), 1.0)
303 self.assertEqualAndEqualSign(pow_op(NAN, -0.0), 1.0)
304
305 # x**y defers to complex pow for finite negative x and
306 # non-integral y.
307 self.assertEqual(type(pow_op(-2.0, -0.5)), complex)
308 self.assertEqual(type(pow_op(-2.0, 0.5)), complex)
309 self.assertEqual(type(pow_op(-1.0, -0.5)), complex)
310 self.assertEqual(type(pow_op(-1.0, 0.5)), complex)
311 self.assertEqual(type(pow_op(-0.5, -0.5)), complex)
312 self.assertEqual(type(pow_op(-0.5, 0.5)), complex)
313
314 # x**-INF is INF for abs(x) < 1
315 self.assertEqualAndEqualSign(pow_op(-0.5, -INF), INF)
316 self.assertEqualAndEqualSign(pow_op(-0.0, -INF), INF)
317 self.assertEqualAndEqualSign(pow_op(0.0, -INF), INF)
318 self.assertEqualAndEqualSign(pow_op(0.5, -INF), INF)
319
320 # x**-INF is 0 for abs(x) > 1
321 self.assertEqualAndEqualSign(pow_op(-INF, -INF), 0.0)
322 self.assertEqualAndEqualSign(pow_op(-2.0, -INF), 0.0)
323 self.assertEqualAndEqualSign(pow_op(2.0, -INF), 0.0)
324 self.assertEqualAndEqualSign(pow_op(INF, -INF), 0.0)
325
326 # x**INF is 0 for abs(x) < 1
327 self.assertEqualAndEqualSign(pow_op(-0.5, INF), 0.0)
328 self.assertEqualAndEqualSign(pow_op(-0.0, INF), 0.0)
329 self.assertEqualAndEqualSign(pow_op(0.0, INF), 0.0)
330 self.assertEqualAndEqualSign(pow_op(0.5, INF), 0.0)
331
332 # x**INF is INF for abs(x) > 1
333 self.assertEqualAndEqualSign(pow_op(-INF, INF), INF)
334 self.assertEqualAndEqualSign(pow_op(-2.0, INF), INF)
335 self.assertEqualAndEqualSign(pow_op(2.0, INF), INF)
336 self.assertEqualAndEqualSign(pow_op(INF, INF), INF)
337
338 # (-INF)**y is -0.0 for y a negative odd integer
339 self.assertEqualAndEqualSign(pow_op(-INF, -1.0), -0.0)
340
341 # (-INF)**y is 0.0 for y negative but not an odd integer
342 self.assertEqualAndEqualSign(pow_op(-INF, -0.5), 0.0)
343 self.assertEqualAndEqualSign(pow_op(-INF, -2.0), 0.0)
344
345 # (-INF)**y is -INF for y a positive odd integer
346 self.assertEqualAndEqualSign(pow_op(-INF, 1.0), -INF)
347
348 # (-INF)**y is INF for y positive but not an odd integer
349 self.assertEqualAndEqualSign(pow_op(-INF, 0.5), INF)
350 self.assertEqualAndEqualSign(pow_op(-INF, 2.0), INF)
351
352 # INF**y is INF for y positive
353 self.assertEqualAndEqualSign(pow_op(INF, 0.5), INF)
354 self.assertEqualAndEqualSign(pow_op(INF, 1.0), INF)
355 self.assertEqualAndEqualSign(pow_op(INF, 2.0), INF)
356
357 # INF**y is 0.0 for y negative
358 self.assertEqualAndEqualSign(pow_op(INF, -2.0), 0.0)
359 self.assertEqualAndEqualSign(pow_op(INF, -1.0), 0.0)
360 self.assertEqualAndEqualSign(pow_op(INF, -0.5), 0.0)
361
362 # basic checks not covered by the special cases above
363 self.assertEqualAndEqualSign(pow_op(-2.0, -2.0), 0.25)
364 self.assertEqualAndEqualSign(pow_op(-2.0, -1.0), -0.5)
365 self.assertEqualAndEqualSign(pow_op(-2.0, -0.0), 1.0)
366 self.assertEqualAndEqualSign(pow_op(-2.0, 0.0), 1.0)
367 self.assertEqualAndEqualSign(pow_op(-2.0, 1.0), -2.0)
368 self.assertEqualAndEqualSign(pow_op(-2.0, 2.0), 4.0)
369 self.assertEqualAndEqualSign(pow_op(-1.0, -2.0), 1.0)
370 self.assertEqualAndEqualSign(pow_op(-1.0, -1.0), -1.0)
371 self.assertEqualAndEqualSign(pow_op(-1.0, -0.0), 1.0)
372 self.assertEqualAndEqualSign(pow_op(-1.0, 0.0), 1.0)
373 self.assertEqualAndEqualSign(pow_op(-1.0, 1.0), -1.0)
374 self.assertEqualAndEqualSign(pow_op(-1.0, 2.0), 1.0)
375 self.assertEqualAndEqualSign(pow_op(2.0, -2.0), 0.25)
376 self.assertEqualAndEqualSign(pow_op(2.0, -1.0), 0.5)
377 self.assertEqualAndEqualSign(pow_op(2.0, -0.0), 1.0)
378 self.assertEqualAndEqualSign(pow_op(2.0, 0.0), 1.0)
379 self.assertEqualAndEqualSign(pow_op(2.0, 1.0), 2.0)
380 self.assertEqualAndEqualSign(pow_op(2.0, 2.0), 4.0)
381
382 # 1 ** large and -1 ** large; some libms apparently
383 # have problems with these
384 self.assertEqualAndEqualSign(pow_op(1.0, -1e100), 1.0)
385 self.assertEqualAndEqualSign(pow_op(1.0, 1e100), 1.0)
386 self.assertEqualAndEqualSign(pow_op(-1.0, -1e100), 1.0)
387 self.assertEqualAndEqualSign(pow_op(-1.0, 1e100), 1.0)
388
389 # check sign for results that underflow to 0
390 self.assertEqualAndEqualSign(pow_op(-2.0, -2000.0), 0.0)
391 self.assertEqual(type(pow_op(-2.0, -2000.5)), complex)
392 self.assertEqualAndEqualSign(pow_op(-2.0, -2001.0), -0.0)
393 self.assertEqualAndEqualSign(pow_op(2.0, -2000.0), 0.0)
394 self.assertEqualAndEqualSign(pow_op(2.0, -2000.5), 0.0)
395 self.assertEqualAndEqualSign(pow_op(2.0, -2001.0), 0.0)
396 self.assertEqualAndEqualSign(pow_op(-0.5, 2000.0), 0.0)
397 self.assertEqual(type(pow_op(-0.5, 2000.5)), complex)
398 self.assertEqualAndEqualSign(pow_op(-0.5, 2001.0), -0.0)
399 self.assertEqualAndEqualSign(pow_op(0.5, 2000.0), 0.0)
400 self.assertEqualAndEqualSign(pow_op(0.5, 2000.5), 0.0)
401 self.assertEqualAndEqualSign(pow_op(0.5, 2001.0), 0.0)
402
403 # check we don't raise an exception for subnormal results,
404 # and validate signs. Tests currently disabled, since
405 # they fail on systems where a subnormal result from pow
406 # is flushed to zero (e.g. Debian/ia64.)
407 #self.assertTrue(0.0 < pow_op(0.5, 1048) < 1e-315)
408 #self.assertTrue(0.0 < pow_op(-0.5, 1048) < 1e-315)
409 #self.assertTrue(0.0 < pow_op(0.5, 1047) < 1e-315)
410 #self.assertTrue(0.0 > pow_op(-0.5, 1047) > -1e-315)
411 #self.assertTrue(0.0 < pow_op(2.0, -1048) < 1e-315)
412 #self.assertTrue(0.0 < pow_op(-2.0, -1048) < 1e-315)
413 #self.assertTrue(0.0 < pow_op(2.0, -1047) < 1e-315)
414 #self.assertTrue(0.0 > pow_op(-2.0, -1047) > -1e-315)
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000415
416
Benjamin Petersone401c682010-07-02 23:25:44 +0000417@requires_setformat
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000418class FormatFunctionsTestCase(unittest.TestCase):
419
420 def setUp(self):
421 self.save_formats = {'double':float.__getformat__('double'),
422 'float':float.__getformat__('float')}
423
424 def tearDown(self):
425 float.__setformat__('double', self.save_formats['double'])
426 float.__setformat__('float', self.save_formats['float'])
427
428 def test_getformat(self):
Ezio Melottib58e0bd2010-01-23 15:40:09 +0000429 self.assertIn(float.__getformat__('double'),
430 ['unknown', 'IEEE, big-endian', 'IEEE, little-endian'])
431 self.assertIn(float.__getformat__('float'),
432 ['unknown', 'IEEE, big-endian', 'IEEE, little-endian'])
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000433 self.assertRaises(ValueError, float.__getformat__, 'chicken')
434 self.assertRaises(TypeError, float.__getformat__, 1)
435
436 def test_setformat(self):
437 for t in 'double', 'float':
438 float.__setformat__(t, 'unknown')
439 if self.save_formats[t] == 'IEEE, big-endian':
440 self.assertRaises(ValueError, float.__setformat__,
441 t, 'IEEE, little-endian')
442 elif self.save_formats[t] == 'IEEE, little-endian':
443 self.assertRaises(ValueError, float.__setformat__,
444 t, 'IEEE, big-endian')
445 else:
446 self.assertRaises(ValueError, float.__setformat__,
447 t, 'IEEE, big-endian')
448 self.assertRaises(ValueError, float.__setformat__,
449 t, 'IEEE, little-endian')
450 self.assertRaises(ValueError, float.__setformat__,
451 t, 'chicken')
452 self.assertRaises(ValueError, float.__setformat__,
453 'chicken', 'unknown')
454
Guido van Rossum2be161d2007-05-15 20:43:51 +0000455BE_DOUBLE_INF = b'\x7f\xf0\x00\x00\x00\x00\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000456LE_DOUBLE_INF = bytes(reversed(BE_DOUBLE_INF))
Guido van Rossum2be161d2007-05-15 20:43:51 +0000457BE_DOUBLE_NAN = b'\x7f\xf8\x00\x00\x00\x00\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000458LE_DOUBLE_NAN = bytes(reversed(BE_DOUBLE_NAN))
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000459
Guido van Rossum2be161d2007-05-15 20:43:51 +0000460BE_FLOAT_INF = b'\x7f\x80\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000461LE_FLOAT_INF = bytes(reversed(BE_FLOAT_INF))
Guido van Rossum2be161d2007-05-15 20:43:51 +0000462BE_FLOAT_NAN = b'\x7f\xc0\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000463LE_FLOAT_NAN = bytes(reversed(BE_FLOAT_NAN))
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000464
465# on non-IEEE platforms, attempting to unpack a bit pattern
466# representing an infinity or a NaN should raise an exception.
467
Benjamin Petersone401c682010-07-02 23:25:44 +0000468@requires_setformat
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000469class UnknownFormatTestCase(unittest.TestCase):
470 def setUp(self):
471 self.save_formats = {'double':float.__getformat__('double'),
472 'float':float.__getformat__('float')}
473 float.__setformat__('double', 'unknown')
474 float.__setformat__('float', 'unknown')
Tim Peters5d36a552005-06-03 22:40:27 +0000475
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000476 def tearDown(self):
477 float.__setformat__('double', self.save_formats['double'])
478 float.__setformat__('float', self.save_formats['float'])
479
480 def test_double_specials_dont_unpack(self):
481 for fmt, data in [('>d', BE_DOUBLE_INF),
482 ('>d', BE_DOUBLE_NAN),
483 ('<d', LE_DOUBLE_INF),
484 ('<d', LE_DOUBLE_NAN)]:
485 self.assertRaises(ValueError, struct.unpack, fmt, data)
486
487 def test_float_specials_dont_unpack(self):
488 for fmt, data in [('>f', BE_FLOAT_INF),
489 ('>f', BE_FLOAT_NAN),
490 ('<f', LE_FLOAT_INF),
491 ('<f', LE_FLOAT_NAN)]:
492 self.assertRaises(ValueError, struct.unpack, fmt, data)
493
494
495# on an IEEE platform, all we guarantee is that bit patterns
496# representing infinities or NaNs do not raise an exception; all else
497# is accident (today).
Guido van Rossum04110fb2007-08-24 16:32:05 +0000498# let's also try to guarantee that -0.0 and 0.0 don't get confused.
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000499
500class IEEEFormatTestCase(unittest.TestCase):
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000501
Eric Smith3ab08ca2010-12-04 15:17:38 +0000502 @support.requires_IEEE_754
Benjamin Petersone401c682010-07-02 23:25:44 +0000503 def test_double_specials_do_unpack(self):
504 for fmt, data in [('>d', BE_DOUBLE_INF),
505 ('>d', BE_DOUBLE_NAN),
506 ('<d', LE_DOUBLE_INF),
507 ('<d', LE_DOUBLE_NAN)]:
508 struct.unpack(fmt, data)
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000509
Eric Smith3ab08ca2010-12-04 15:17:38 +0000510 @support.requires_IEEE_754
Benjamin Petersone401c682010-07-02 23:25:44 +0000511 def test_float_specials_do_unpack(self):
512 for fmt, data in [('>f', BE_FLOAT_INF),
513 ('>f', BE_FLOAT_NAN),
514 ('<f', LE_FLOAT_INF),
515 ('<f', LE_FLOAT_NAN)]:
516 struct.unpack(fmt, data)
Guido van Rossum04110fb2007-08-24 16:32:05 +0000517
Eric Smith8c663262007-08-25 02:26:07 +0000518class FormatTestCase(unittest.TestCase):
Benjamin Petersone401c682010-07-02 23:25:44 +0000519
Eric Smith11fe3e02007-08-31 01:33:06 +0000520 def test_format(self):
Eric Smith8c663262007-08-25 02:26:07 +0000521 # these should be rewritten to use both format(x, spec) and
522 # x.__format__(spec)
523
524 self.assertEqual(format(0.0, 'f'), '0.000000')
525
526 # the default is 'g', except for empty format spec
527 self.assertEqual(format(0.0, ''), '0.0')
528 self.assertEqual(format(0.01, ''), '0.01')
529 self.assertEqual(format(0.01, 'g'), '0.01')
530
Eric Smith63376222009-05-05 14:04:18 +0000531 # empty presentation type should format in the same way as str
532 # (issue 5920)
533 x = 100/7.
534 self.assertEqual(format(x, ''), str(x))
535 self.assertEqual(format(x, '-'), str(x))
536 self.assertEqual(format(x, '>'), str(x))
537 self.assertEqual(format(x, '2'), str(x))
Eric Smith8c663262007-08-25 02:26:07 +0000538
539 self.assertEqual(format(1.0, 'f'), '1.000000')
Eric Smith8c663262007-08-25 02:26:07 +0000540
541 self.assertEqual(format(-1.0, 'f'), '-1.000000')
Eric Smith8c663262007-08-25 02:26:07 +0000542
543 self.assertEqual(format( 1.0, ' f'), ' 1.000000')
544 self.assertEqual(format(-1.0, ' f'), '-1.000000')
545 self.assertEqual(format( 1.0, '+f'), '+1.000000')
546 self.assertEqual(format(-1.0, '+f'), '-1.000000')
547
548 # % formatting
549 self.assertEqual(format(-1.0, '%'), '-100.000000%')
550
551 # conversion to string should fail
552 self.assertRaises(ValueError, format, 3.0, "s")
553
Eric Smith7b69c6c2008-01-27 21:07:59 +0000554 # other format specifiers shouldn't work on floats,
555 # in particular int specifiers
556 for format_spec in ([chr(x) for x in range(ord('a'), ord('z')+1)] +
557 [chr(x) for x in range(ord('A'), ord('Z')+1)]):
558 if not format_spec in 'eEfFgGn%':
559 self.assertRaises(ValueError, format, 0.0, format_spec)
560 self.assertRaises(ValueError, format, 1.0, format_spec)
561 self.assertRaises(ValueError, format, -1.0, format_spec)
562 self.assertRaises(ValueError, format, 1e100, format_spec)
563 self.assertRaises(ValueError, format, -1e100, format_spec)
564 self.assertRaises(ValueError, format, 1e-100, format_spec)
565 self.assertRaises(ValueError, format, -1e-100, format_spec)
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000566
Eric Smith741191f2009-05-06 13:08:15 +0000567 # issue 3382
568 self.assertEqual(format(NAN, 'f'), 'nan')
569 self.assertEqual(format(NAN, 'F'), 'NAN')
570 self.assertEqual(format(INF, 'f'), 'inf')
571 self.assertEqual(format(INF, 'F'), 'INF')
572
Eric Smith3ab08ca2010-12-04 15:17:38 +0000573 @support.requires_IEEE_754
Eric Smith0923d1d2009-04-16 20:16:10 +0000574 def test_format_testfile(self):
Brian Curtin076623b2010-10-31 00:03:45 +0000575 with open(format_testfile) as testfile:
576 for line in testfile:
577 if line.startswith('--'):
578 continue
579 line = line.strip()
580 if not line:
581 continue
Eric Smith0923d1d2009-04-16 20:16:10 +0000582
Brian Curtin076623b2010-10-31 00:03:45 +0000583 lhs, rhs = map(str.strip, line.split('->'))
584 fmt, arg = lhs.split()
585 self.assertEqual(fmt % float(arg), rhs)
586 self.assertEqual(fmt % -float(arg), '-' + rhs)
Eric Smith0923d1d2009-04-16 20:16:10 +0000587
Mark Dickinsond3ca5572009-04-29 18:47:07 +0000588 def test_issue5864(self):
Ezio Melottib3aedd42010-11-20 19:04:17 +0000589 self.assertEqual(format(123.456, '.4'), '123.5')
590 self.assertEqual(format(1234.56, '.4'), '1.235e+03')
591 self.assertEqual(format(12345.6, '.4'), '1.235e+04')
Mark Dickinsond3ca5572009-04-29 18:47:07 +0000592
Mark Dickinson7efad9e2009-04-17 20:59:58 +0000593class ReprTestCase(unittest.TestCase):
594 def test_repr(self):
595 floats_file = open(os.path.join(os.path.split(__file__)[0],
596 'floating_points.txt'))
597 for line in floats_file:
598 line = line.strip()
599 if not line or line.startswith('#'):
600 continue
601 v = eval(line)
602 self.assertEqual(v, eval(repr(v)))
603 floats_file.close()
604
Eric Smith0923d1d2009-04-16 20:16:10 +0000605 @unittest.skipUnless(getattr(sys, 'float_repr_style', '') == 'short',
606 "applies only when using short float repr style")
607 def test_short_repr(self):
608 # test short float repr introduced in Python 3.1. One aspect
609 # of this repr is that we get some degree of str -> float ->
610 # str roundtripping. In particular, for any numeric string
611 # containing 15 or fewer significant digits, those exact same
612 # digits (modulo trailing zeros) should appear in the output.
613 # No more repr(0.03) -> "0.029999999999999999"!
614
615 test_strings = [
616 # output always includes *either* a decimal point and at
617 # least one digit after that point, or an exponent.
618 '0.0',
619 '1.0',
620 '0.01',
621 '0.02',
622 '0.03',
623 '0.04',
624 '0.05',
625 '1.23456789',
626 '10.0',
627 '100.0',
628 # values >= 1e16 get an exponent...
629 '1000000000000000.0',
630 '9999999999999990.0',
631 '1e+16',
632 '1e+17',
633 # ... and so do values < 1e-4
634 '0.001',
635 '0.001001',
636 '0.00010000000000001',
637 '0.0001',
638 '9.999999999999e-05',
639 '1e-05',
640 # values designed to provoke failure if the FPU rounding
641 # precision isn't set correctly
642 '8.72293771110361e+25',
643 '7.47005307342313e+26',
644 '2.86438000439698e+28',
645 '8.89142905246179e+28',
646 '3.08578087079232e+35',
647 ]
648
649 for s in test_strings:
650 negs = '-'+s
651 self.assertEqual(s, repr(float(s)))
652 self.assertEqual(negs, repr(float(negs)))
Mark Dickinson388122d2010-08-04 20:56:28 +0000653 # Since Python 3.2, repr and str are identical
654 self.assertEqual(repr(float(s)), str(float(s)))
655 self.assertEqual(repr(float(negs)), str(float(negs)))
Benjamin Petersone401c682010-07-02 23:25:44 +0000656
Eric Smith3ab08ca2010-12-04 15:17:38 +0000657@support.requires_IEEE_754
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000658class RoundTestCase(unittest.TestCase):
Benjamin Petersone401c682010-07-02 23:25:44 +0000659
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000660 def test_inf_nan(self):
661 self.assertRaises(OverflowError, round, INF)
662 self.assertRaises(OverflowError, round, -INF)
663 self.assertRaises(ValueError, round, NAN)
Mark Dickinson4ca33d12009-11-24 10:59:34 +0000664 self.assertRaises(TypeError, round, INF, 0.0)
665 self.assertRaises(TypeError, round, -INF, 1.0)
666 self.assertRaises(TypeError, round, NAN, "ceci n'est pas un integer")
667 self.assertRaises(TypeError, round, -0.0, 1j)
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000668
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000669 def test_large_n(self):
670 for n in [324, 325, 400, 2**31-1, 2**31, 2**32, 2**100]:
671 self.assertEqual(round(123.456, n), 123.456)
672 self.assertEqual(round(-123.456, n), -123.456)
673 self.assertEqual(round(1e300, n), 1e300)
674 self.assertEqual(round(1e-320, n), 1e-320)
675 self.assertEqual(round(1e150, 300), 1e150)
676 self.assertEqual(round(1e300, 307), 1e300)
677 self.assertEqual(round(-3.1415, 308), -3.1415)
678 self.assertEqual(round(1e150, 309), 1e150)
679 self.assertEqual(round(1.4e-315, 315), 1e-315)
680
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000681 def test_small_n(self):
682 for n in [-308, -309, -400, 1-2**31, -2**31, -2**31-1, -2**100]:
683 self.assertEqual(round(123.456, n), 0.0)
684 self.assertEqual(round(-123.456, n), -0.0)
685 self.assertEqual(round(1e300, n), 0.0)
686 self.assertEqual(round(1e-320, n), 0.0)
687
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000688 def test_overflow(self):
689 self.assertRaises(OverflowError, round, 1.6e308, -308)
690 self.assertRaises(OverflowError, round, -1.7e308, -308)
691
692 @unittest.skipUnless(getattr(sys, 'float_repr_style', '') == 'short',
693 "applies only when using short float repr style")
694 def test_previous_round_bugs(self):
695 # particular cases that have occurred in bug reports
696 self.assertEqual(round(562949953421312.5, 1),
697 562949953421312.5)
698 self.assertEqual(round(56294995342131.5, 3),
699 56294995342131.5)
700 # round-half-even
701 self.assertEqual(round(25.0, -1), 20.0)
702 self.assertEqual(round(35.0, -1), 40.0)
703 self.assertEqual(round(45.0, -1), 40.0)
704 self.assertEqual(round(55.0, -1), 60.0)
705 self.assertEqual(round(65.0, -1), 60.0)
706 self.assertEqual(round(75.0, -1), 80.0)
707 self.assertEqual(round(85.0, -1), 80.0)
708 self.assertEqual(round(95.0, -1), 100.0)
709
710 @unittest.skipUnless(getattr(sys, 'float_repr_style', '') == 'short',
711 "applies only when using short float repr style")
712 def test_matches_float_format(self):
713 # round should give the same results as float formatting
714 for i in range(500):
715 x = i/1000.
716 self.assertEqual(float(format(x, '.0f')), round(x, 0))
717 self.assertEqual(float(format(x, '.1f')), round(x, 1))
718 self.assertEqual(float(format(x, '.2f')), round(x, 2))
719 self.assertEqual(float(format(x, '.3f')), round(x, 3))
720
721 for i in range(5, 5000, 10):
722 x = i/1000.
723 self.assertEqual(float(format(x, '.0f')), round(x, 0))
724 self.assertEqual(float(format(x, '.1f')), round(x, 1))
725 self.assertEqual(float(format(x, '.2f')), round(x, 2))
726 self.assertEqual(float(format(x, '.3f')), round(x, 3))
727
728 for i in range(500):
729 x = random.random()
730 self.assertEqual(float(format(x, '.0f')), round(x, 0))
731 self.assertEqual(float(format(x, '.1f')), round(x, 1))
732 self.assertEqual(float(format(x, '.2f')), round(x, 2))
733 self.assertEqual(float(format(x, '.3f')), round(x, 3))
734
Eric Smith8a10ecc2009-12-02 17:58:24 +0000735 def test_format_specials(self):
736 # Test formatting of nans and infs.
737
738 def test(fmt, value, expected):
739 # Test with both % and format().
740 self.assertEqual(fmt % value, expected, fmt)
Eric Smith984bb582010-11-25 16:08:06 +0000741 fmt = fmt[1:] # strip off the %
742 self.assertEqual(format(value, fmt), expected, fmt)
Eric Smith8a10ecc2009-12-02 17:58:24 +0000743
744 for fmt in ['%e', '%f', '%g', '%.0e', '%.6f', '%.20g',
745 '%#e', '%#f', '%#g', '%#.20e', '%#.15f', '%#.3g']:
746 pfmt = '%+' + fmt[1:]
747 sfmt = '% ' + fmt[1:]
748 test(fmt, INF, 'inf')
749 test(fmt, -INF, '-inf')
750 test(fmt, NAN, 'nan')
751 test(fmt, -NAN, 'nan')
752 # When asking for a sign, it's always provided. nans are
753 # always positive.
754 test(pfmt, INF, '+inf')
755 test(pfmt, -INF, '-inf')
756 test(pfmt, NAN, '+nan')
757 test(pfmt, -NAN, '+nan')
758 # When using ' ' for a sign code, only infs can be negative.
759 # Others have a space.
760 test(sfmt, INF, ' inf')
761 test(sfmt, -INF, '-inf')
762 test(sfmt, NAN, ' nan')
763 test(sfmt, -NAN, ' nan')
764
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000765
Christian Heimes99170a52007-12-19 02:07:34 +0000766# Beginning with Python 2.6 float has cross platform compatible
Georg Brandl2ee470f2008-07-16 12:55:28 +0000767# ways to create and represent inf and nan
Christian Heimes99170a52007-12-19 02:07:34 +0000768class InfNanTest(unittest.TestCase):
769 def test_inf_from_str(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000770 self.assertTrue(isinf(float("inf")))
771 self.assertTrue(isinf(float("+inf")))
772 self.assertTrue(isinf(float("-inf")))
773 self.assertTrue(isinf(float("infinity")))
774 self.assertTrue(isinf(float("+infinity")))
775 self.assertTrue(isinf(float("-infinity")))
Christian Heimes99170a52007-12-19 02:07:34 +0000776
777 self.assertEqual(repr(float("inf")), "inf")
778 self.assertEqual(repr(float("+inf")), "inf")
779 self.assertEqual(repr(float("-inf")), "-inf")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000780 self.assertEqual(repr(float("infinity")), "inf")
781 self.assertEqual(repr(float("+infinity")), "inf")
782 self.assertEqual(repr(float("-infinity")), "-inf")
Christian Heimes99170a52007-12-19 02:07:34 +0000783
784 self.assertEqual(repr(float("INF")), "inf")
785 self.assertEqual(repr(float("+Inf")), "inf")
786 self.assertEqual(repr(float("-iNF")), "-inf")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000787 self.assertEqual(repr(float("Infinity")), "inf")
788 self.assertEqual(repr(float("+iNfInItY")), "inf")
789 self.assertEqual(repr(float("-INFINITY")), "-inf")
Christian Heimes99170a52007-12-19 02:07:34 +0000790
791 self.assertEqual(str(float("inf")), "inf")
792 self.assertEqual(str(float("+inf")), "inf")
793 self.assertEqual(str(float("-inf")), "-inf")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000794 self.assertEqual(str(float("infinity")), "inf")
795 self.assertEqual(str(float("+infinity")), "inf")
796 self.assertEqual(str(float("-infinity")), "-inf")
Christian Heimes99170a52007-12-19 02:07:34 +0000797
798 self.assertRaises(ValueError, float, "info")
799 self.assertRaises(ValueError, float, "+info")
800 self.assertRaises(ValueError, float, "-info")
801 self.assertRaises(ValueError, float, "in")
802 self.assertRaises(ValueError, float, "+in")
803 self.assertRaises(ValueError, float, "-in")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000804 self.assertRaises(ValueError, float, "infinit")
805 self.assertRaises(ValueError, float, "+Infin")
806 self.assertRaises(ValueError, float, "-INFI")
807 self.assertRaises(ValueError, float, "infinitys")
Christian Heimes99170a52007-12-19 02:07:34 +0000808
Mark Dickinsonbd16edd2009-05-20 22:05:25 +0000809 self.assertRaises(ValueError, float, "++Inf")
810 self.assertRaises(ValueError, float, "-+inf")
811 self.assertRaises(ValueError, float, "+-infinity")
812 self.assertRaises(ValueError, float, "--Infinity")
813
Christian Heimes99170a52007-12-19 02:07:34 +0000814 def test_inf_as_str(self):
815 self.assertEqual(repr(1e300 * 1e300), "inf")
816 self.assertEqual(repr(-1e300 * 1e300), "-inf")
817
818 self.assertEqual(str(1e300 * 1e300), "inf")
819 self.assertEqual(str(-1e300 * 1e300), "-inf")
820
821 def test_nan_from_str(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000822 self.assertTrue(isnan(float("nan")))
823 self.assertTrue(isnan(float("+nan")))
824 self.assertTrue(isnan(float("-nan")))
Christian Heimes99170a52007-12-19 02:07:34 +0000825
826 self.assertEqual(repr(float("nan")), "nan")
827 self.assertEqual(repr(float("+nan")), "nan")
828 self.assertEqual(repr(float("-nan")), "nan")
829
830 self.assertEqual(repr(float("NAN")), "nan")
831 self.assertEqual(repr(float("+NAn")), "nan")
832 self.assertEqual(repr(float("-NaN")), "nan")
833
834 self.assertEqual(str(float("nan")), "nan")
835 self.assertEqual(str(float("+nan")), "nan")
836 self.assertEqual(str(float("-nan")), "nan")
837
838 self.assertRaises(ValueError, float, "nana")
839 self.assertRaises(ValueError, float, "+nana")
840 self.assertRaises(ValueError, float, "-nana")
841 self.assertRaises(ValueError, float, "na")
842 self.assertRaises(ValueError, float, "+na")
843 self.assertRaises(ValueError, float, "-na")
844
Mark Dickinsonbd16edd2009-05-20 22:05:25 +0000845 self.assertRaises(ValueError, float, "++nan")
846 self.assertRaises(ValueError, float, "-+NAN")
847 self.assertRaises(ValueError, float, "+-NaN")
848 self.assertRaises(ValueError, float, "--nAn")
849
Christian Heimes99170a52007-12-19 02:07:34 +0000850 def test_nan_as_str(self):
851 self.assertEqual(repr(1e300 * 1e300 * 0), "nan")
852 self.assertEqual(repr(-1e300 * 1e300 * 0), "nan")
853
854 self.assertEqual(str(1e300 * 1e300 * 0), "nan")
855 self.assertEqual(str(-1e300 * 1e300 * 0), "nan")
Christian Heimes827b35c2007-12-10 22:19:17 +0000856
Christian Heimes53876d92008-04-19 00:31:39 +0000857 def notest_float_nan(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000858 self.assertTrue(NAN.is_nan())
859 self.assertFalse(INF.is_nan())
860 self.assertFalse((0.).is_nan())
Christian Heimes53876d92008-04-19 00:31:39 +0000861
862 def notest_float_inf(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000863 self.assertTrue(INF.is_inf())
864 self.assertFalse(NAN.is_inf())
865 self.assertFalse((0.).is_inf())
Christian Heimes53876d92008-04-19 00:31:39 +0000866
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000867fromHex = float.fromhex
868toHex = float.hex
869class HexFloatTestCase(unittest.TestCase):
870 MAX = fromHex('0x.fffffffffffff8p+1024') # max normal
871 MIN = fromHex('0x1p-1022') # min normal
872 TINY = fromHex('0x0.0000000000001p-1022') # min subnormal
873 EPS = fromHex('0x0.0000000000001p0') # diff between 1.0 and next float up
874
875 def identical(self, x, y):
876 # check that floats x and y are identical, or that both
877 # are NaNs
878 if isnan(x) or isnan(y):
879 if isnan(x) == isnan(y):
880 return
881 elif x == y and (x != 0.0 or copysign(1.0, x) == copysign(1.0, y)):
882 return
883 self.fail('%r not identical to %r' % (x, y))
884
885 def test_ends(self):
Mark Dickinson38bbc482008-07-16 11:32:23 +0000886 self.identical(self.MIN, ldexp(1.0, -1022))
887 self.identical(self.TINY, ldexp(1.0, -1074))
888 self.identical(self.EPS, ldexp(1.0, -52))
889 self.identical(self.MAX, 2.*(ldexp(1.0, 1023) - ldexp(1.0, 970)))
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000890
891 def test_invalid_inputs(self):
892 invalid_inputs = [
893 'infi', # misspelt infinities and nans
894 '-Infinit',
895 '++inf',
896 '-+Inf',
897 '--nan',
898 '+-NaN',
899 'snan',
900 'NaNs',
901 'nna',
Mark Dickinsond1ec8b22009-05-11 15:45:15 +0000902 'an',
903 'nf',
904 'nfinity',
905 'inity',
906 'iinity',
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000907 '0xnan',
908 '',
909 ' ',
910 'x1.0p0',
911 '0xX1.0p0',
912 '+ 0x1.0p0', # internal whitespace
913 '- 0x1.0p0',
914 '0 x1.0p0',
915 '0x 1.0p0',
916 '0x1 2.0p0',
917 '+0x1 .0p0',
918 '0x1. 0p0',
919 '-0x1.0 1p0',
920 '-0x1.0 p0',
921 '+0x1.0p +0',
922 '0x1.0p -0',
923 '0x1.0p 0',
924 '+0x1.0p+ 0',
925 '-0x1.0p- 0',
926 '++0x1.0p-0', # double signs
927 '--0x1.0p0',
928 '+-0x1.0p+0',
929 '-+0x1.0p0',
930 '0x1.0p++0',
931 '+0x1.0p+-0',
932 '-0x1.0p-+0',
933 '0x1.0p--0',
934 '0x1.0.p0',
935 '0x.p0', # no hex digits before or after point
936 '0x1,p0', # wrong decimal point character
937 '0x1pa',
938 '0x1p\uff10', # fullwidth Unicode digits
939 '\uff10x1p0',
940 '0x\uff11p0',
941 '0x1.\uff10p0',
942 '0x1p0 \n 0x2p0',
943 '0x1p0\0 0x1p0', # embedded null byte is not end of string
944 ]
945 for x in invalid_inputs:
Mark Dickinson589b7952008-08-21 20:05:56 +0000946 try:
947 result = fromHex(x)
948 except ValueError:
949 pass
950 else:
951 self.fail('Expected float.fromhex(%r) to raise ValueError; '
952 'got %r instead' % (x, result))
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000953
954
Mark Dickinsond1ec8b22009-05-11 15:45:15 +0000955 def test_whitespace(self):
956 value_pairs = [
957 ('inf', INF),
958 ('-Infinity', -INF),
959 ('nan', NAN),
960 ('1.0', 1.0),
961 ('-0x.2', -0.125),
962 ('-0.0', -0.0)
963 ]
964 whitespace = [
965 '',
966 ' ',
967 '\t',
968 '\n',
969 '\n \t',
970 '\f',
971 '\v',
972 '\r'
973 ]
974 for inp, expected in value_pairs:
975 for lead in whitespace:
976 for trail in whitespace:
977 got = fromHex(lead + inp + trail)
978 self.identical(got, expected)
979
980
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000981 def test_from_hex(self):
982 MIN = self.MIN;
983 MAX = self.MAX;
984 TINY = self.TINY;
985 EPS = self.EPS;
986
987 # two spellings of infinity, with optional signs; case-insensitive
988 self.identical(fromHex('inf'), INF)
989 self.identical(fromHex('+Inf'), INF)
990 self.identical(fromHex('-INF'), -INF)
991 self.identical(fromHex('iNf'), INF)
992 self.identical(fromHex('Infinity'), INF)
993 self.identical(fromHex('+INFINITY'), INF)
994 self.identical(fromHex('-infinity'), -INF)
995 self.identical(fromHex('-iNFiNitY'), -INF)
996
997 # nans with optional sign; case insensitive
998 self.identical(fromHex('nan'), NAN)
999 self.identical(fromHex('+NaN'), NAN)
1000 self.identical(fromHex('-NaN'), NAN)
1001 self.identical(fromHex('-nAN'), NAN)
1002
1003 # variations in input format
1004 self.identical(fromHex('1'), 1.0)
1005 self.identical(fromHex('+1'), 1.0)
1006 self.identical(fromHex('1.'), 1.0)
1007 self.identical(fromHex('1.0'), 1.0)
1008 self.identical(fromHex('1.0p0'), 1.0)
1009 self.identical(fromHex('01'), 1.0)
1010 self.identical(fromHex('01.'), 1.0)
1011 self.identical(fromHex('0x1'), 1.0)
1012 self.identical(fromHex('0x1.'), 1.0)
1013 self.identical(fromHex('0x1.0'), 1.0)
1014 self.identical(fromHex('+0x1.0'), 1.0)
1015 self.identical(fromHex('0x1p0'), 1.0)
1016 self.identical(fromHex('0X1p0'), 1.0)
1017 self.identical(fromHex('0X1P0'), 1.0)
1018 self.identical(fromHex('0x1P0'), 1.0)
1019 self.identical(fromHex('0x1.p0'), 1.0)
1020 self.identical(fromHex('0x1.0p0'), 1.0)
1021 self.identical(fromHex('0x.1p4'), 1.0)
1022 self.identical(fromHex('0x.1p04'), 1.0)
1023 self.identical(fromHex('0x.1p004'), 1.0)
1024 self.identical(fromHex('0x1p+0'), 1.0)
1025 self.identical(fromHex('0x1P-0'), 1.0)
1026 self.identical(fromHex('+0x1p0'), 1.0)
1027 self.identical(fromHex('0x01p0'), 1.0)
1028 self.identical(fromHex('0x1p00'), 1.0)
1029 self.identical(fromHex(' 0x1p0 '), 1.0)
1030 self.identical(fromHex('\n 0x1p0'), 1.0)
1031 self.identical(fromHex('0x1p0 \t'), 1.0)
1032 self.identical(fromHex('0xap0'), 10.0)
1033 self.identical(fromHex('0xAp0'), 10.0)
1034 self.identical(fromHex('0xaP0'), 10.0)
1035 self.identical(fromHex('0xAP0'), 10.0)
1036 self.identical(fromHex('0xbep0'), 190.0)
1037 self.identical(fromHex('0xBep0'), 190.0)
1038 self.identical(fromHex('0xbEp0'), 190.0)
1039 self.identical(fromHex('0XBE0P-4'), 190.0)
1040 self.identical(fromHex('0xBEp0'), 190.0)
1041 self.identical(fromHex('0xB.Ep4'), 190.0)
1042 self.identical(fromHex('0x.BEp8'), 190.0)
1043 self.identical(fromHex('0x.0BEp12'), 190.0)
1044
1045 # moving the point around
1046 pi = fromHex('0x1.921fb54442d18p1')
1047 self.identical(fromHex('0x.006487ed5110b46p11'), pi)
1048 self.identical(fromHex('0x.00c90fdaa22168cp10'), pi)
1049 self.identical(fromHex('0x.01921fb54442d18p9'), pi)
1050 self.identical(fromHex('0x.03243f6a8885a3p8'), pi)
1051 self.identical(fromHex('0x.06487ed5110b46p7'), pi)
1052 self.identical(fromHex('0x.0c90fdaa22168cp6'), pi)
1053 self.identical(fromHex('0x.1921fb54442d18p5'), pi)
1054 self.identical(fromHex('0x.3243f6a8885a3p4'), pi)
1055 self.identical(fromHex('0x.6487ed5110b46p3'), pi)
1056 self.identical(fromHex('0x.c90fdaa22168cp2'), pi)
1057 self.identical(fromHex('0x1.921fb54442d18p1'), pi)
1058 self.identical(fromHex('0x3.243f6a8885a3p0'), pi)
1059 self.identical(fromHex('0x6.487ed5110b46p-1'), pi)
1060 self.identical(fromHex('0xc.90fdaa22168cp-2'), pi)
1061 self.identical(fromHex('0x19.21fb54442d18p-3'), pi)
1062 self.identical(fromHex('0x32.43f6a8885a3p-4'), pi)
1063 self.identical(fromHex('0x64.87ed5110b46p-5'), pi)
1064 self.identical(fromHex('0xc9.0fdaa22168cp-6'), pi)
1065 self.identical(fromHex('0x192.1fb54442d18p-7'), pi)
1066 self.identical(fromHex('0x324.3f6a8885a3p-8'), pi)
1067 self.identical(fromHex('0x648.7ed5110b46p-9'), pi)
1068 self.identical(fromHex('0xc90.fdaa22168cp-10'), pi)
1069 self.identical(fromHex('0x1921.fb54442d18p-11'), pi)
1070 # ...
1071 self.identical(fromHex('0x1921fb54442d1.8p-47'), pi)
1072 self.identical(fromHex('0x3243f6a8885a3p-48'), pi)
1073 self.identical(fromHex('0x6487ed5110b46p-49'), pi)
1074 self.identical(fromHex('0xc90fdaa22168cp-50'), pi)
1075 self.identical(fromHex('0x1921fb54442d18p-51'), pi)
1076 self.identical(fromHex('0x3243f6a8885a30p-52'), pi)
1077 self.identical(fromHex('0x6487ed5110b460p-53'), pi)
1078 self.identical(fromHex('0xc90fdaa22168c0p-54'), pi)
1079 self.identical(fromHex('0x1921fb54442d180p-55'), pi)
1080
1081
1082 # results that should overflow...
1083 self.assertRaises(OverflowError, fromHex, '-0x1p1024')
1084 self.assertRaises(OverflowError, fromHex, '0x1p+1025')
1085 self.assertRaises(OverflowError, fromHex, '+0X1p1030')
1086 self.assertRaises(OverflowError, fromHex, '-0x1p+1100')
1087 self.assertRaises(OverflowError, fromHex, '0X1p123456789123456789')
1088 self.assertRaises(OverflowError, fromHex, '+0X.8p+1025')
1089 self.assertRaises(OverflowError, fromHex, '+0x0.8p1025')
1090 self.assertRaises(OverflowError, fromHex, '-0x0.4p1026')
1091 self.assertRaises(OverflowError, fromHex, '0X2p+1023')
1092 self.assertRaises(OverflowError, fromHex, '0x2.p1023')
1093 self.assertRaises(OverflowError, fromHex, '-0x2.0p+1023')
1094 self.assertRaises(OverflowError, fromHex, '+0X4p+1022')
1095 self.assertRaises(OverflowError, fromHex, '0x1.ffffffffffffffp+1023')
1096 self.assertRaises(OverflowError, fromHex, '-0X1.fffffffffffff9p1023')
1097 self.assertRaises(OverflowError, fromHex, '0X1.fffffffffffff8p1023')
1098 self.assertRaises(OverflowError, fromHex, '+0x3.fffffffffffffp1022')
1099 self.assertRaises(OverflowError, fromHex, '0x3fffffffffffffp+970')
1100 self.assertRaises(OverflowError, fromHex, '0x10000000000000000p960')
1101 self.assertRaises(OverflowError, fromHex, '-0Xffffffffffffffffp960')
1102
1103 # ...and those that round to +-max float
1104 self.identical(fromHex('+0x1.fffffffffffffp+1023'), MAX)
1105 self.identical(fromHex('-0X1.fffffffffffff7p1023'), -MAX)
1106 self.identical(fromHex('0X1.fffffffffffff7fffffffffffffp1023'), MAX)
1107
1108 # zeros
1109 self.identical(fromHex('0x0p0'), 0.0)
1110 self.identical(fromHex('0x0p1000'), 0.0)
1111 self.identical(fromHex('-0x0p1023'), -0.0)
1112 self.identical(fromHex('0X0p1024'), 0.0)
1113 self.identical(fromHex('-0x0p1025'), -0.0)
1114 self.identical(fromHex('0X0p2000'), 0.0)
1115 self.identical(fromHex('0x0p123456789123456789'), 0.0)
1116 self.identical(fromHex('-0X0p-0'), -0.0)
1117 self.identical(fromHex('-0X0p-1000'), -0.0)
1118 self.identical(fromHex('0x0p-1023'), 0.0)
1119 self.identical(fromHex('-0X0p-1024'), -0.0)
1120 self.identical(fromHex('-0x0p-1025'), -0.0)
1121 self.identical(fromHex('-0x0p-1072'), -0.0)
1122 self.identical(fromHex('0X0p-1073'), 0.0)
1123 self.identical(fromHex('-0x0p-1074'), -0.0)
1124 self.identical(fromHex('0x0p-1075'), 0.0)
1125 self.identical(fromHex('0X0p-1076'), 0.0)
1126 self.identical(fromHex('-0X0p-2000'), -0.0)
1127 self.identical(fromHex('-0x0p-123456789123456789'), -0.0)
1128
1129 # values that should underflow to 0
1130 self.identical(fromHex('0X1p-1075'), 0.0)
1131 self.identical(fromHex('-0X1p-1075'), -0.0)
1132 self.identical(fromHex('-0x1p-123456789123456789'), -0.0)
1133 self.identical(fromHex('0x1.00000000000000001p-1075'), TINY)
1134 self.identical(fromHex('-0x1.1p-1075'), -TINY)
1135 self.identical(fromHex('0x1.fffffffffffffffffp-1075'), TINY)
1136
1137 # check round-half-even is working correctly near 0 ...
1138 self.identical(fromHex('0x1p-1076'), 0.0)
1139 self.identical(fromHex('0X2p-1076'), 0.0)
1140 self.identical(fromHex('0X3p-1076'), TINY)
1141 self.identical(fromHex('0x4p-1076'), TINY)
1142 self.identical(fromHex('0X5p-1076'), TINY)
1143 self.identical(fromHex('0X6p-1076'), 2*TINY)
1144 self.identical(fromHex('0x7p-1076'), 2*TINY)
1145 self.identical(fromHex('0X8p-1076'), 2*TINY)
1146 self.identical(fromHex('0X9p-1076'), 2*TINY)
1147 self.identical(fromHex('0xap-1076'), 2*TINY)
1148 self.identical(fromHex('0Xbp-1076'), 3*TINY)
1149 self.identical(fromHex('0xcp-1076'), 3*TINY)
1150 self.identical(fromHex('0Xdp-1076'), 3*TINY)
1151 self.identical(fromHex('0Xep-1076'), 4*TINY)
1152 self.identical(fromHex('0xfp-1076'), 4*TINY)
1153 self.identical(fromHex('0x10p-1076'), 4*TINY)
1154 self.identical(fromHex('-0x1p-1076'), -0.0)
1155 self.identical(fromHex('-0X2p-1076'), -0.0)
1156 self.identical(fromHex('-0x3p-1076'), -TINY)
1157 self.identical(fromHex('-0X4p-1076'), -TINY)
1158 self.identical(fromHex('-0x5p-1076'), -TINY)
1159 self.identical(fromHex('-0x6p-1076'), -2*TINY)
1160 self.identical(fromHex('-0X7p-1076'), -2*TINY)
1161 self.identical(fromHex('-0X8p-1076'), -2*TINY)
1162 self.identical(fromHex('-0X9p-1076'), -2*TINY)
1163 self.identical(fromHex('-0Xap-1076'), -2*TINY)
1164 self.identical(fromHex('-0xbp-1076'), -3*TINY)
1165 self.identical(fromHex('-0xcp-1076'), -3*TINY)
1166 self.identical(fromHex('-0Xdp-1076'), -3*TINY)
1167 self.identical(fromHex('-0xep-1076'), -4*TINY)
1168 self.identical(fromHex('-0Xfp-1076'), -4*TINY)
1169 self.identical(fromHex('-0X10p-1076'), -4*TINY)
1170
1171 # ... and near MIN ...
1172 self.identical(fromHex('0x0.ffffffffffffd6p-1022'), MIN-3*TINY)
1173 self.identical(fromHex('0x0.ffffffffffffd8p-1022'), MIN-2*TINY)
1174 self.identical(fromHex('0x0.ffffffffffffdap-1022'), MIN-2*TINY)
1175 self.identical(fromHex('0x0.ffffffffffffdcp-1022'), MIN-2*TINY)
1176 self.identical(fromHex('0x0.ffffffffffffdep-1022'), MIN-2*TINY)
1177 self.identical(fromHex('0x0.ffffffffffffe0p-1022'), MIN-2*TINY)
1178 self.identical(fromHex('0x0.ffffffffffffe2p-1022'), MIN-2*TINY)
1179 self.identical(fromHex('0x0.ffffffffffffe4p-1022'), MIN-2*TINY)
1180 self.identical(fromHex('0x0.ffffffffffffe6p-1022'), MIN-2*TINY)
1181 self.identical(fromHex('0x0.ffffffffffffe8p-1022'), MIN-2*TINY)
1182 self.identical(fromHex('0x0.ffffffffffffeap-1022'), MIN-TINY)
1183 self.identical(fromHex('0x0.ffffffffffffecp-1022'), MIN-TINY)
1184 self.identical(fromHex('0x0.ffffffffffffeep-1022'), MIN-TINY)
1185 self.identical(fromHex('0x0.fffffffffffff0p-1022'), MIN-TINY)
1186 self.identical(fromHex('0x0.fffffffffffff2p-1022'), MIN-TINY)
1187 self.identical(fromHex('0x0.fffffffffffff4p-1022'), MIN-TINY)
1188 self.identical(fromHex('0x0.fffffffffffff6p-1022'), MIN-TINY)
1189 self.identical(fromHex('0x0.fffffffffffff8p-1022'), MIN)
1190 self.identical(fromHex('0x0.fffffffffffffap-1022'), MIN)
1191 self.identical(fromHex('0x0.fffffffffffffcp-1022'), MIN)
1192 self.identical(fromHex('0x0.fffffffffffffep-1022'), MIN)
1193 self.identical(fromHex('0x1.00000000000000p-1022'), MIN)
1194 self.identical(fromHex('0x1.00000000000002p-1022'), MIN)
1195 self.identical(fromHex('0x1.00000000000004p-1022'), MIN)
1196 self.identical(fromHex('0x1.00000000000006p-1022'), MIN)
1197 self.identical(fromHex('0x1.00000000000008p-1022'), MIN)
1198 self.identical(fromHex('0x1.0000000000000ap-1022'), MIN+TINY)
1199 self.identical(fromHex('0x1.0000000000000cp-1022'), MIN+TINY)
1200 self.identical(fromHex('0x1.0000000000000ep-1022'), MIN+TINY)
1201 self.identical(fromHex('0x1.00000000000010p-1022'), MIN+TINY)
1202 self.identical(fromHex('0x1.00000000000012p-1022'), MIN+TINY)
1203 self.identical(fromHex('0x1.00000000000014p-1022'), MIN+TINY)
1204 self.identical(fromHex('0x1.00000000000016p-1022'), MIN+TINY)
1205 self.identical(fromHex('0x1.00000000000018p-1022'), MIN+2*TINY)
1206
1207 # ... and near 1.0.
1208 self.identical(fromHex('0x0.fffffffffffff0p0'), 1.0-EPS)
1209 self.identical(fromHex('0x0.fffffffffffff1p0'), 1.0-EPS)
1210 self.identical(fromHex('0X0.fffffffffffff2p0'), 1.0-EPS)
1211 self.identical(fromHex('0x0.fffffffffffff3p0'), 1.0-EPS)
1212 self.identical(fromHex('0X0.fffffffffffff4p0'), 1.0-EPS)
1213 self.identical(fromHex('0X0.fffffffffffff5p0'), 1.0-EPS/2)
1214 self.identical(fromHex('0X0.fffffffffffff6p0'), 1.0-EPS/2)
1215 self.identical(fromHex('0x0.fffffffffffff7p0'), 1.0-EPS/2)
1216 self.identical(fromHex('0x0.fffffffffffff8p0'), 1.0-EPS/2)
1217 self.identical(fromHex('0X0.fffffffffffff9p0'), 1.0-EPS/2)
1218 self.identical(fromHex('0X0.fffffffffffffap0'), 1.0-EPS/2)
1219 self.identical(fromHex('0x0.fffffffffffffbp0'), 1.0-EPS/2)
1220 self.identical(fromHex('0X0.fffffffffffffcp0'), 1.0)
1221 self.identical(fromHex('0x0.fffffffffffffdp0'), 1.0)
1222 self.identical(fromHex('0X0.fffffffffffffep0'), 1.0)
1223 self.identical(fromHex('0x0.ffffffffffffffp0'), 1.0)
1224 self.identical(fromHex('0X1.00000000000000p0'), 1.0)
1225 self.identical(fromHex('0X1.00000000000001p0'), 1.0)
1226 self.identical(fromHex('0x1.00000000000002p0'), 1.0)
1227 self.identical(fromHex('0X1.00000000000003p0'), 1.0)
1228 self.identical(fromHex('0x1.00000000000004p0'), 1.0)
1229 self.identical(fromHex('0X1.00000000000005p0'), 1.0)
1230 self.identical(fromHex('0X1.00000000000006p0'), 1.0)
1231 self.identical(fromHex('0X1.00000000000007p0'), 1.0)
1232 self.identical(fromHex('0x1.00000000000007ffffffffffffffffffffp0'),
1233 1.0)
1234 self.identical(fromHex('0x1.00000000000008p0'), 1.0)
1235 self.identical(fromHex('0x1.00000000000008000000000000000001p0'),
1236 1+EPS)
1237 self.identical(fromHex('0X1.00000000000009p0'), 1.0+EPS)
1238 self.identical(fromHex('0x1.0000000000000ap0'), 1.0+EPS)
1239 self.identical(fromHex('0x1.0000000000000bp0'), 1.0+EPS)
1240 self.identical(fromHex('0X1.0000000000000cp0'), 1.0+EPS)
1241 self.identical(fromHex('0x1.0000000000000dp0'), 1.0+EPS)
1242 self.identical(fromHex('0x1.0000000000000ep0'), 1.0+EPS)
1243 self.identical(fromHex('0X1.0000000000000fp0'), 1.0+EPS)
1244 self.identical(fromHex('0x1.00000000000010p0'), 1.0+EPS)
1245 self.identical(fromHex('0X1.00000000000011p0'), 1.0+EPS)
1246 self.identical(fromHex('0x1.00000000000012p0'), 1.0+EPS)
1247 self.identical(fromHex('0X1.00000000000013p0'), 1.0+EPS)
1248 self.identical(fromHex('0X1.00000000000014p0'), 1.0+EPS)
1249 self.identical(fromHex('0x1.00000000000015p0'), 1.0+EPS)
1250 self.identical(fromHex('0x1.00000000000016p0'), 1.0+EPS)
1251 self.identical(fromHex('0X1.00000000000017p0'), 1.0+EPS)
1252 self.identical(fromHex('0x1.00000000000017ffffffffffffffffffffp0'),
1253 1.0+EPS)
1254 self.identical(fromHex('0x1.00000000000018p0'), 1.0+2*EPS)
1255 self.identical(fromHex('0X1.00000000000018000000000000000001p0'),
1256 1.0+2*EPS)
1257 self.identical(fromHex('0x1.00000000000019p0'), 1.0+2*EPS)
1258 self.identical(fromHex('0X1.0000000000001ap0'), 1.0+2*EPS)
1259 self.identical(fromHex('0X1.0000000000001bp0'), 1.0+2*EPS)
1260 self.identical(fromHex('0x1.0000000000001cp0'), 1.0+2*EPS)
1261 self.identical(fromHex('0x1.0000000000001dp0'), 1.0+2*EPS)
1262 self.identical(fromHex('0x1.0000000000001ep0'), 1.0+2*EPS)
1263 self.identical(fromHex('0X1.0000000000001fp0'), 1.0+2*EPS)
1264 self.identical(fromHex('0x1.00000000000020p0'), 1.0+2*EPS)
1265
1266 def test_roundtrip(self):
1267 def roundtrip(x):
1268 return fromHex(toHex(x))
1269
1270 for x in [NAN, INF, self.MAX, self.MIN, self.MIN-self.TINY, self.TINY, 0.0]:
1271 self.identical(x, roundtrip(x))
1272 self.identical(-x, roundtrip(-x))
1273
1274 # fromHex(toHex(x)) should exactly recover x, for any non-NaN float x.
1275 import random
1276 for i in range(10000):
1277 e = random.randrange(-1200, 1200)
1278 m = random.random()
1279 s = random.choice([1.0, -1.0])
1280 try:
1281 x = s*ldexp(m, e)
1282 except OverflowError:
1283 pass
1284 else:
1285 self.identical(x, fromHex(toHex(x)))
1286
Christian Heimes53876d92008-04-19 00:31:39 +00001287
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001288def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001289 support.run_unittest(
Amaury Forgeot d'Arc7e958d12008-09-06 21:03:22 +00001290 GeneralFloatCases,
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001291 FormatFunctionsTestCase,
1292 UnknownFormatTestCase,
Eric Smith8c663262007-08-25 02:26:07 +00001293 IEEEFormatTestCase,
Christian Heimes827b35c2007-12-10 22:19:17 +00001294 FormatTestCase,
Christian Heimes99170a52007-12-19 02:07:34 +00001295 ReprTestCase,
Mark Dickinsone6a076d2009-04-18 11:48:33 +00001296 RoundTestCase,
Christian Heimes99170a52007-12-19 02:07:34 +00001297 InfNanTest,
Mark Dickinson65fe25e2008-07-16 11:30:51 +00001298 HexFloatTestCase,
Christian Heimesb76922a2007-12-11 01:06:40 +00001299 )
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001300
1301if __name__ == '__main__':
1302 test_main()