blob: dc0c2912be22be9aa61651316f0be02d68b0d3ae [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
Benjamin Petersonb3b8ba62011-10-28 19:42:48 -0400131 def test_is_integer(self):
132 self.assertFalse((1.1).is_integer())
133 self.assertTrue((1.).is_integer())
134 self.assertFalse(float("nan").is_integer())
135 self.assertFalse(float("inf").is_integer())
136
Christian Heimes81ee3ef2008-05-04 22:42:01 +0000137 def test_floatasratio(self):
138 for f, ratio in [
139 (0.875, (7, 8)),
140 (-0.875, (-7, 8)),
141 (0.0, (0, 1)),
142 (11.5, (23, 2)),
143 ]:
144 self.assertEqual(f.as_integer_ratio(), ratio)
145
146 for i in range(10000):
147 f = random.random()
148 f *= 10 ** random.randint(-100, 100)
149 n, d = f.as_integer_ratio()
150 self.assertEqual(float(n).__truediv__(d), f)
151
152 R = fractions.Fraction
153 self.assertEqual(R(0, 1),
154 R(*float(0.0).as_integer_ratio()))
155 self.assertEqual(R(5, 2),
156 R(*float(2.5).as_integer_ratio()))
157 self.assertEqual(R(1, 2),
158 R(*float(0.5).as_integer_ratio()))
159 self.assertEqual(R(4728779608739021, 2251799813685248),
160 R(*float(2.1).as_integer_ratio()))
161 self.assertEqual(R(-4728779608739021, 2251799813685248),
162 R(*float(-2.1).as_integer_ratio()))
163 self.assertEqual(R(-2100, 1),
164 R(*float(-2100.0).as_integer_ratio()))
165
166 self.assertRaises(OverflowError, float('inf').as_integer_ratio)
167 self.assertRaises(OverflowError, float('-inf').as_integer_ratio)
168 self.assertRaises(ValueError, float('nan').as_integer_ratio)
169
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000170 def test_float_containment(self):
171 floats = (INF, -INF, 0.0, 1.0, NAN)
172 for f in floats:
Benjamin Peterson577473f2010-01-19 00:09:57 +0000173 self.assertIn(f, [f])
Benjamin Peterson577473f2010-01-19 00:09:57 +0000174 self.assertIn(f, (f,))
Benjamin Peterson577473f2010-01-19 00:09:57 +0000175 self.assertIn(f, {f})
Benjamin Peterson577473f2010-01-19 00:09:57 +0000176 self.assertIn(f, {f: None})
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000177 self.assertEqual([f].count(f), 1, "[].count('%r') != 1" % f)
Benjamin Peterson577473f2010-01-19 00:09:57 +0000178 self.assertIn(f, floats)
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000179
180 for f in floats:
181 # nonidentical containers, same type, same contents
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000182 self.assertTrue([f] == [f], "[%r] != [%r]" % (f, f))
183 self.assertTrue((f,) == (f,), "(%r,) != (%r,)" % (f, f))
184 self.assertTrue({f} == {f}, "{%r} != {%r}" % (f, f))
185 self.assertTrue({f : None} == {f: None}, "{%r : None} != "
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000186 "{%r : None}" % (f, f))
187
188 # identical containers
189 l, t, s, d = [f], (f,), {f}, {f: None}
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000190 self.assertTrue(l == l, "[%r] not equal to itself" % f)
191 self.assertTrue(t == t, "(%r,) not equal to itself" % f)
192 self.assertTrue(s == s, "{%r} not equal to itself" % f)
193 self.assertTrue(d == d, "{%r : None} not equal to itself" % f)
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000194
Mark Dickinson9ab44b52009-12-30 16:22:49 +0000195 def assertEqualAndEqualSign(self, a, b):
196 # fail unless a == b and a and b have the same sign bit;
197 # the only difference from assertEqual is that this test
Ezio Melotti13925002011-03-16 11:05:33 +0200198 # distinguishes -0.0 and 0.0.
Mark Dickinson9ab44b52009-12-30 16:22:49 +0000199 self.assertEqual((a, copysign(1.0, a)), (b, copysign(1.0, b)))
200
Eric Smith3ab08ca2010-12-04 15:17:38 +0000201 @support.requires_IEEE_754
Mark Dickinsond2a9b202010-12-04 12:25:30 +0000202 def test_float_mod(self):
203 # Check behaviour of % operator for IEEE 754 special cases.
204 # In particular, check signs of zeros.
205 mod = operator.mod
206
207 self.assertEqualAndEqualSign(mod(-1.0, 1.0), 0.0)
208 self.assertEqualAndEqualSign(mod(-1e-100, 1.0), 1.0)
209 self.assertEqualAndEqualSign(mod(-0.0, 1.0), 0.0)
210 self.assertEqualAndEqualSign(mod(0.0, 1.0), 0.0)
211 self.assertEqualAndEqualSign(mod(1e-100, 1.0), 1e-100)
212 self.assertEqualAndEqualSign(mod(1.0, 1.0), 0.0)
213
214 self.assertEqualAndEqualSign(mod(-1.0, -1.0), -0.0)
215 self.assertEqualAndEqualSign(mod(-1e-100, -1.0), -1e-100)
216 self.assertEqualAndEqualSign(mod(-0.0, -1.0), -0.0)
217 self.assertEqualAndEqualSign(mod(0.0, -1.0), -0.0)
218 self.assertEqualAndEqualSign(mod(1e-100, -1.0), -1.0)
219 self.assertEqualAndEqualSign(mod(1.0, -1.0), -0.0)
220
Eric Smith3ab08ca2010-12-04 15:17:38 +0000221 @support.requires_IEEE_754
Mark Dickinson9ab44b52009-12-30 16:22:49 +0000222 def test_float_pow(self):
223 # test builtin pow and ** operator for IEEE 754 special cases.
224 # Special cases taken from section F.9.4.4 of the C99 specification
225
226 for pow_op in pow, operator.pow:
227 # x**NAN is NAN for any x except 1
228 self.assertTrue(isnan(pow_op(-INF, NAN)))
229 self.assertTrue(isnan(pow_op(-2.0, NAN)))
230 self.assertTrue(isnan(pow_op(-1.0, NAN)))
231 self.assertTrue(isnan(pow_op(-0.5, NAN)))
232 self.assertTrue(isnan(pow_op(-0.0, NAN)))
233 self.assertTrue(isnan(pow_op(0.0, NAN)))
234 self.assertTrue(isnan(pow_op(0.5, NAN)))
235 self.assertTrue(isnan(pow_op(2.0, NAN)))
236 self.assertTrue(isnan(pow_op(INF, NAN)))
237 self.assertTrue(isnan(pow_op(NAN, NAN)))
238
239 # NAN**y is NAN for any y except +-0
240 self.assertTrue(isnan(pow_op(NAN, -INF)))
241 self.assertTrue(isnan(pow_op(NAN, -2.0)))
242 self.assertTrue(isnan(pow_op(NAN, -1.0)))
243 self.assertTrue(isnan(pow_op(NAN, -0.5)))
244 self.assertTrue(isnan(pow_op(NAN, 0.5)))
245 self.assertTrue(isnan(pow_op(NAN, 1.0)))
246 self.assertTrue(isnan(pow_op(NAN, 2.0)))
247 self.assertTrue(isnan(pow_op(NAN, INF)))
248
249 # (+-0)**y raises ZeroDivisionError for y a negative odd integer
250 self.assertRaises(ZeroDivisionError, pow_op, -0.0, -1.0)
251 self.assertRaises(ZeroDivisionError, pow_op, 0.0, -1.0)
252
253 # (+-0)**y raises ZeroDivisionError for y finite and negative
254 # but not an odd integer
255 self.assertRaises(ZeroDivisionError, pow_op, -0.0, -2.0)
256 self.assertRaises(ZeroDivisionError, pow_op, -0.0, -0.5)
257 self.assertRaises(ZeroDivisionError, pow_op, 0.0, -2.0)
258 self.assertRaises(ZeroDivisionError, pow_op, 0.0, -0.5)
259
260 # (+-0)**y is +-0 for y a positive odd integer
261 self.assertEqualAndEqualSign(pow_op(-0.0, 1.0), -0.0)
262 self.assertEqualAndEqualSign(pow_op(0.0, 1.0), 0.0)
263
264 # (+-0)**y is 0 for y finite and positive but not an odd integer
265 self.assertEqualAndEqualSign(pow_op(-0.0, 0.5), 0.0)
266 self.assertEqualAndEqualSign(pow_op(-0.0, 2.0), 0.0)
267 self.assertEqualAndEqualSign(pow_op(0.0, 0.5), 0.0)
268 self.assertEqualAndEqualSign(pow_op(0.0, 2.0), 0.0)
269
270 # (-1)**+-inf is 1
271 self.assertEqualAndEqualSign(pow_op(-1.0, -INF), 1.0)
272 self.assertEqualAndEqualSign(pow_op(-1.0, INF), 1.0)
273
274 # 1**y is 1 for any y, even if y is an infinity or nan
275 self.assertEqualAndEqualSign(pow_op(1.0, -INF), 1.0)
276 self.assertEqualAndEqualSign(pow_op(1.0, -2.0), 1.0)
277 self.assertEqualAndEqualSign(pow_op(1.0, -1.0), 1.0)
278 self.assertEqualAndEqualSign(pow_op(1.0, -0.5), 1.0)
279 self.assertEqualAndEqualSign(pow_op(1.0, -0.0), 1.0)
280 self.assertEqualAndEqualSign(pow_op(1.0, 0.0), 1.0)
281 self.assertEqualAndEqualSign(pow_op(1.0, 0.5), 1.0)
282 self.assertEqualAndEqualSign(pow_op(1.0, 1.0), 1.0)
283 self.assertEqualAndEqualSign(pow_op(1.0, 2.0), 1.0)
284 self.assertEqualAndEqualSign(pow_op(1.0, INF), 1.0)
285 self.assertEqualAndEqualSign(pow_op(1.0, NAN), 1.0)
286
287 # x**+-0 is 1 for any x, even if x is a zero, infinity, or nan
288 self.assertEqualAndEqualSign(pow_op(-INF, 0.0), 1.0)
289 self.assertEqualAndEqualSign(pow_op(-2.0, 0.0), 1.0)
290 self.assertEqualAndEqualSign(pow_op(-1.0, 0.0), 1.0)
291 self.assertEqualAndEqualSign(pow_op(-0.5, 0.0), 1.0)
292 self.assertEqualAndEqualSign(pow_op(-0.0, 0.0), 1.0)
293 self.assertEqualAndEqualSign(pow_op(0.0, 0.0), 1.0)
294 self.assertEqualAndEqualSign(pow_op(0.5, 0.0), 1.0)
295 self.assertEqualAndEqualSign(pow_op(1.0, 0.0), 1.0)
296 self.assertEqualAndEqualSign(pow_op(2.0, 0.0), 1.0)
297 self.assertEqualAndEqualSign(pow_op(INF, 0.0), 1.0)
298 self.assertEqualAndEqualSign(pow_op(NAN, 0.0), 1.0)
299 self.assertEqualAndEqualSign(pow_op(-INF, -0.0), 1.0)
300 self.assertEqualAndEqualSign(pow_op(-2.0, -0.0), 1.0)
301 self.assertEqualAndEqualSign(pow_op(-1.0, -0.0), 1.0)
302 self.assertEqualAndEqualSign(pow_op(-0.5, -0.0), 1.0)
303 self.assertEqualAndEqualSign(pow_op(-0.0, -0.0), 1.0)
304 self.assertEqualAndEqualSign(pow_op(0.0, -0.0), 1.0)
305 self.assertEqualAndEqualSign(pow_op(0.5, -0.0), 1.0)
306 self.assertEqualAndEqualSign(pow_op(1.0, -0.0), 1.0)
307 self.assertEqualAndEqualSign(pow_op(2.0, -0.0), 1.0)
308 self.assertEqualAndEqualSign(pow_op(INF, -0.0), 1.0)
309 self.assertEqualAndEqualSign(pow_op(NAN, -0.0), 1.0)
310
311 # x**y defers to complex pow for finite negative x and
312 # non-integral y.
313 self.assertEqual(type(pow_op(-2.0, -0.5)), complex)
314 self.assertEqual(type(pow_op(-2.0, 0.5)), complex)
315 self.assertEqual(type(pow_op(-1.0, -0.5)), complex)
316 self.assertEqual(type(pow_op(-1.0, 0.5)), complex)
317 self.assertEqual(type(pow_op(-0.5, -0.5)), complex)
318 self.assertEqual(type(pow_op(-0.5, 0.5)), complex)
319
320 # x**-INF is INF for abs(x) < 1
321 self.assertEqualAndEqualSign(pow_op(-0.5, -INF), INF)
322 self.assertEqualAndEqualSign(pow_op(-0.0, -INF), INF)
323 self.assertEqualAndEqualSign(pow_op(0.0, -INF), INF)
324 self.assertEqualAndEqualSign(pow_op(0.5, -INF), INF)
325
326 # x**-INF is 0 for abs(x) > 1
327 self.assertEqualAndEqualSign(pow_op(-INF, -INF), 0.0)
328 self.assertEqualAndEqualSign(pow_op(-2.0, -INF), 0.0)
329 self.assertEqualAndEqualSign(pow_op(2.0, -INF), 0.0)
330 self.assertEqualAndEqualSign(pow_op(INF, -INF), 0.0)
331
332 # x**INF is 0 for abs(x) < 1
333 self.assertEqualAndEqualSign(pow_op(-0.5, INF), 0.0)
334 self.assertEqualAndEqualSign(pow_op(-0.0, INF), 0.0)
335 self.assertEqualAndEqualSign(pow_op(0.0, INF), 0.0)
336 self.assertEqualAndEqualSign(pow_op(0.5, INF), 0.0)
337
338 # x**INF is INF for abs(x) > 1
339 self.assertEqualAndEqualSign(pow_op(-INF, INF), INF)
340 self.assertEqualAndEqualSign(pow_op(-2.0, INF), INF)
341 self.assertEqualAndEqualSign(pow_op(2.0, INF), INF)
342 self.assertEqualAndEqualSign(pow_op(INF, INF), INF)
343
344 # (-INF)**y is -0.0 for y a negative odd integer
345 self.assertEqualAndEqualSign(pow_op(-INF, -1.0), -0.0)
346
347 # (-INF)**y is 0.0 for y negative but not an odd integer
348 self.assertEqualAndEqualSign(pow_op(-INF, -0.5), 0.0)
349 self.assertEqualAndEqualSign(pow_op(-INF, -2.0), 0.0)
350
351 # (-INF)**y is -INF for y a positive odd integer
352 self.assertEqualAndEqualSign(pow_op(-INF, 1.0), -INF)
353
354 # (-INF)**y is INF for y positive but not an odd integer
355 self.assertEqualAndEqualSign(pow_op(-INF, 0.5), INF)
356 self.assertEqualAndEqualSign(pow_op(-INF, 2.0), INF)
357
358 # INF**y is INF for y positive
359 self.assertEqualAndEqualSign(pow_op(INF, 0.5), INF)
360 self.assertEqualAndEqualSign(pow_op(INF, 1.0), INF)
361 self.assertEqualAndEqualSign(pow_op(INF, 2.0), INF)
362
363 # INF**y is 0.0 for y negative
364 self.assertEqualAndEqualSign(pow_op(INF, -2.0), 0.0)
365 self.assertEqualAndEqualSign(pow_op(INF, -1.0), 0.0)
366 self.assertEqualAndEqualSign(pow_op(INF, -0.5), 0.0)
367
368 # basic checks not covered by the special cases above
369 self.assertEqualAndEqualSign(pow_op(-2.0, -2.0), 0.25)
370 self.assertEqualAndEqualSign(pow_op(-2.0, -1.0), -0.5)
371 self.assertEqualAndEqualSign(pow_op(-2.0, -0.0), 1.0)
372 self.assertEqualAndEqualSign(pow_op(-2.0, 0.0), 1.0)
373 self.assertEqualAndEqualSign(pow_op(-2.0, 1.0), -2.0)
374 self.assertEqualAndEqualSign(pow_op(-2.0, 2.0), 4.0)
375 self.assertEqualAndEqualSign(pow_op(-1.0, -2.0), 1.0)
376 self.assertEqualAndEqualSign(pow_op(-1.0, -1.0), -1.0)
377 self.assertEqualAndEqualSign(pow_op(-1.0, -0.0), 1.0)
378 self.assertEqualAndEqualSign(pow_op(-1.0, 0.0), 1.0)
379 self.assertEqualAndEqualSign(pow_op(-1.0, 1.0), -1.0)
380 self.assertEqualAndEqualSign(pow_op(-1.0, 2.0), 1.0)
381 self.assertEqualAndEqualSign(pow_op(2.0, -2.0), 0.25)
382 self.assertEqualAndEqualSign(pow_op(2.0, -1.0), 0.5)
383 self.assertEqualAndEqualSign(pow_op(2.0, -0.0), 1.0)
384 self.assertEqualAndEqualSign(pow_op(2.0, 0.0), 1.0)
385 self.assertEqualAndEqualSign(pow_op(2.0, 1.0), 2.0)
386 self.assertEqualAndEqualSign(pow_op(2.0, 2.0), 4.0)
387
388 # 1 ** large and -1 ** large; some libms apparently
389 # have problems with these
390 self.assertEqualAndEqualSign(pow_op(1.0, -1e100), 1.0)
391 self.assertEqualAndEqualSign(pow_op(1.0, 1e100), 1.0)
392 self.assertEqualAndEqualSign(pow_op(-1.0, -1e100), 1.0)
393 self.assertEqualAndEqualSign(pow_op(-1.0, 1e100), 1.0)
394
395 # check sign for results that underflow to 0
396 self.assertEqualAndEqualSign(pow_op(-2.0, -2000.0), 0.0)
397 self.assertEqual(type(pow_op(-2.0, -2000.5)), complex)
398 self.assertEqualAndEqualSign(pow_op(-2.0, -2001.0), -0.0)
399 self.assertEqualAndEqualSign(pow_op(2.0, -2000.0), 0.0)
400 self.assertEqualAndEqualSign(pow_op(2.0, -2000.5), 0.0)
401 self.assertEqualAndEqualSign(pow_op(2.0, -2001.0), 0.0)
402 self.assertEqualAndEqualSign(pow_op(-0.5, 2000.0), 0.0)
403 self.assertEqual(type(pow_op(-0.5, 2000.5)), complex)
404 self.assertEqualAndEqualSign(pow_op(-0.5, 2001.0), -0.0)
405 self.assertEqualAndEqualSign(pow_op(0.5, 2000.0), 0.0)
406 self.assertEqualAndEqualSign(pow_op(0.5, 2000.5), 0.0)
407 self.assertEqualAndEqualSign(pow_op(0.5, 2001.0), 0.0)
408
409 # check we don't raise an exception for subnormal results,
410 # and validate signs. Tests currently disabled, since
411 # they fail on systems where a subnormal result from pow
412 # is flushed to zero (e.g. Debian/ia64.)
413 #self.assertTrue(0.0 < pow_op(0.5, 1048) < 1e-315)
414 #self.assertTrue(0.0 < pow_op(-0.5, 1048) < 1e-315)
415 #self.assertTrue(0.0 < pow_op(0.5, 1047) < 1e-315)
416 #self.assertTrue(0.0 > pow_op(-0.5, 1047) > -1e-315)
417 #self.assertTrue(0.0 < pow_op(2.0, -1048) < 1e-315)
418 #self.assertTrue(0.0 < pow_op(-2.0, -1048) < 1e-315)
419 #self.assertTrue(0.0 < pow_op(2.0, -1047) < 1e-315)
420 #self.assertTrue(0.0 > pow_op(-2.0, -1047) > -1e-315)
Mark Dickinson4a1f5932008-11-12 23:23:36 +0000421
422
Benjamin Petersone401c682010-07-02 23:25:44 +0000423@requires_setformat
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000424class FormatFunctionsTestCase(unittest.TestCase):
425
426 def setUp(self):
427 self.save_formats = {'double':float.__getformat__('double'),
428 'float':float.__getformat__('float')}
429
430 def tearDown(self):
431 float.__setformat__('double', self.save_formats['double'])
432 float.__setformat__('float', self.save_formats['float'])
433
434 def test_getformat(self):
Ezio Melottib58e0bd2010-01-23 15:40:09 +0000435 self.assertIn(float.__getformat__('double'),
436 ['unknown', 'IEEE, big-endian', 'IEEE, little-endian'])
437 self.assertIn(float.__getformat__('float'),
438 ['unknown', 'IEEE, big-endian', 'IEEE, little-endian'])
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000439 self.assertRaises(ValueError, float.__getformat__, 'chicken')
440 self.assertRaises(TypeError, float.__getformat__, 1)
441
442 def test_setformat(self):
443 for t in 'double', 'float':
444 float.__setformat__(t, 'unknown')
445 if self.save_formats[t] == 'IEEE, big-endian':
446 self.assertRaises(ValueError, float.__setformat__,
447 t, 'IEEE, little-endian')
448 elif self.save_formats[t] == 'IEEE, little-endian':
449 self.assertRaises(ValueError, float.__setformat__,
450 t, 'IEEE, big-endian')
451 else:
452 self.assertRaises(ValueError, float.__setformat__,
453 t, 'IEEE, big-endian')
454 self.assertRaises(ValueError, float.__setformat__,
455 t, 'IEEE, little-endian')
456 self.assertRaises(ValueError, float.__setformat__,
457 t, 'chicken')
458 self.assertRaises(ValueError, float.__setformat__,
459 'chicken', 'unknown')
460
Guido van Rossum2be161d2007-05-15 20:43:51 +0000461BE_DOUBLE_INF = b'\x7f\xf0\x00\x00\x00\x00\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000462LE_DOUBLE_INF = bytes(reversed(BE_DOUBLE_INF))
Guido van Rossum2be161d2007-05-15 20:43:51 +0000463BE_DOUBLE_NAN = b'\x7f\xf8\x00\x00\x00\x00\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000464LE_DOUBLE_NAN = bytes(reversed(BE_DOUBLE_NAN))
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000465
Guido van Rossum2be161d2007-05-15 20:43:51 +0000466BE_FLOAT_INF = b'\x7f\x80\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000467LE_FLOAT_INF = bytes(reversed(BE_FLOAT_INF))
Guido van Rossum2be161d2007-05-15 20:43:51 +0000468BE_FLOAT_NAN = b'\x7f\xc0\x00\x00'
Guido van Rossum254348e2007-11-21 19:29:53 +0000469LE_FLOAT_NAN = bytes(reversed(BE_FLOAT_NAN))
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000470
471# on non-IEEE platforms, attempting to unpack a bit pattern
472# representing an infinity or a NaN should raise an exception.
473
Benjamin Petersone401c682010-07-02 23:25:44 +0000474@requires_setformat
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000475class UnknownFormatTestCase(unittest.TestCase):
476 def setUp(self):
477 self.save_formats = {'double':float.__getformat__('double'),
478 'float':float.__getformat__('float')}
479 float.__setformat__('double', 'unknown')
480 float.__setformat__('float', 'unknown')
Tim Peters5d36a552005-06-03 22:40:27 +0000481
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000482 def tearDown(self):
483 float.__setformat__('double', self.save_formats['double'])
484 float.__setformat__('float', self.save_formats['float'])
485
486 def test_double_specials_dont_unpack(self):
487 for fmt, data in [('>d', BE_DOUBLE_INF),
488 ('>d', BE_DOUBLE_NAN),
489 ('<d', LE_DOUBLE_INF),
490 ('<d', LE_DOUBLE_NAN)]:
491 self.assertRaises(ValueError, struct.unpack, fmt, data)
492
493 def test_float_specials_dont_unpack(self):
494 for fmt, data in [('>f', BE_FLOAT_INF),
495 ('>f', BE_FLOAT_NAN),
496 ('<f', LE_FLOAT_INF),
497 ('<f', LE_FLOAT_NAN)]:
498 self.assertRaises(ValueError, struct.unpack, fmt, data)
499
500
501# on an IEEE platform, all we guarantee is that bit patterns
502# representing infinities or NaNs do not raise an exception; all else
503# is accident (today).
Guido van Rossum04110fb2007-08-24 16:32:05 +0000504# let's also try to guarantee that -0.0 and 0.0 don't get confused.
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000505
506class IEEEFormatTestCase(unittest.TestCase):
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000507
Eric Smith3ab08ca2010-12-04 15:17:38 +0000508 @support.requires_IEEE_754
Benjamin Petersone401c682010-07-02 23:25:44 +0000509 def test_double_specials_do_unpack(self):
510 for fmt, data in [('>d', BE_DOUBLE_INF),
511 ('>d', BE_DOUBLE_NAN),
512 ('<d', LE_DOUBLE_INF),
513 ('<d', LE_DOUBLE_NAN)]:
514 struct.unpack(fmt, data)
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000515
Eric Smith3ab08ca2010-12-04 15:17:38 +0000516 @support.requires_IEEE_754
Benjamin Petersone401c682010-07-02 23:25:44 +0000517 def test_float_specials_do_unpack(self):
518 for fmt, data in [('>f', BE_FLOAT_INF),
519 ('>f', BE_FLOAT_NAN),
520 ('<f', LE_FLOAT_INF),
521 ('<f', LE_FLOAT_NAN)]:
522 struct.unpack(fmt, data)
Guido van Rossum04110fb2007-08-24 16:32:05 +0000523
Eric Smith8c663262007-08-25 02:26:07 +0000524class FormatTestCase(unittest.TestCase):
Benjamin Petersone401c682010-07-02 23:25:44 +0000525
Eric Smith11fe3e02007-08-31 01:33:06 +0000526 def test_format(self):
Eric Smith8c663262007-08-25 02:26:07 +0000527 # these should be rewritten to use both format(x, spec) and
528 # x.__format__(spec)
529
530 self.assertEqual(format(0.0, 'f'), '0.000000')
531
532 # the default is 'g', except for empty format spec
533 self.assertEqual(format(0.0, ''), '0.0')
534 self.assertEqual(format(0.01, ''), '0.01')
535 self.assertEqual(format(0.01, 'g'), '0.01')
536
Eric Smith63376222009-05-05 14:04:18 +0000537 # empty presentation type should format in the same way as str
538 # (issue 5920)
539 x = 100/7.
540 self.assertEqual(format(x, ''), str(x))
541 self.assertEqual(format(x, '-'), str(x))
542 self.assertEqual(format(x, '>'), str(x))
543 self.assertEqual(format(x, '2'), str(x))
Eric Smith8c663262007-08-25 02:26:07 +0000544
545 self.assertEqual(format(1.0, 'f'), '1.000000')
Eric Smith8c663262007-08-25 02:26:07 +0000546
547 self.assertEqual(format(-1.0, 'f'), '-1.000000')
Eric Smith8c663262007-08-25 02:26:07 +0000548
549 self.assertEqual(format( 1.0, ' f'), ' 1.000000')
550 self.assertEqual(format(-1.0, ' f'), '-1.000000')
551 self.assertEqual(format( 1.0, '+f'), '+1.000000')
552 self.assertEqual(format(-1.0, '+f'), '-1.000000')
553
554 # % formatting
555 self.assertEqual(format(-1.0, '%'), '-100.000000%')
556
557 # conversion to string should fail
558 self.assertRaises(ValueError, format, 3.0, "s")
559
Eric Smith7b69c6c2008-01-27 21:07:59 +0000560 # other format specifiers shouldn't work on floats,
561 # in particular int specifiers
562 for format_spec in ([chr(x) for x in range(ord('a'), ord('z')+1)] +
563 [chr(x) for x in range(ord('A'), ord('Z')+1)]):
564 if not format_spec in 'eEfFgGn%':
565 self.assertRaises(ValueError, format, 0.0, format_spec)
566 self.assertRaises(ValueError, format, 1.0, format_spec)
567 self.assertRaises(ValueError, format, -1.0, format_spec)
568 self.assertRaises(ValueError, format, 1e100, format_spec)
569 self.assertRaises(ValueError, format, -1e100, format_spec)
570 self.assertRaises(ValueError, format, 1e-100, format_spec)
571 self.assertRaises(ValueError, format, -1e-100, format_spec)
Michael W. Hudsonba283e22005-05-27 15:23:20 +0000572
Eric Smith741191f2009-05-06 13:08:15 +0000573 # issue 3382
574 self.assertEqual(format(NAN, 'f'), 'nan')
575 self.assertEqual(format(NAN, 'F'), 'NAN')
576 self.assertEqual(format(INF, 'f'), 'inf')
577 self.assertEqual(format(INF, 'F'), 'INF')
578
Eric Smith3ab08ca2010-12-04 15:17:38 +0000579 @support.requires_IEEE_754
Eric Smith0923d1d2009-04-16 20:16:10 +0000580 def test_format_testfile(self):
Brian Curtin076623b2010-10-31 00:03:45 +0000581 with open(format_testfile) as testfile:
582 for line in testfile:
583 if line.startswith('--'):
584 continue
585 line = line.strip()
586 if not line:
587 continue
Eric Smith0923d1d2009-04-16 20:16:10 +0000588
Brian Curtin076623b2010-10-31 00:03:45 +0000589 lhs, rhs = map(str.strip, line.split('->'))
590 fmt, arg = lhs.split()
591 self.assertEqual(fmt % float(arg), rhs)
592 self.assertEqual(fmt % -float(arg), '-' + rhs)
Eric Smith0923d1d2009-04-16 20:16:10 +0000593
Mark Dickinsond3ca5572009-04-29 18:47:07 +0000594 def test_issue5864(self):
Ezio Melottib3aedd42010-11-20 19:04:17 +0000595 self.assertEqual(format(123.456, '.4'), '123.5')
596 self.assertEqual(format(1234.56, '.4'), '1.235e+03')
597 self.assertEqual(format(12345.6, '.4'), '1.235e+04')
Mark Dickinsond3ca5572009-04-29 18:47:07 +0000598
Mark Dickinson7efad9e2009-04-17 20:59:58 +0000599class ReprTestCase(unittest.TestCase):
600 def test_repr(self):
601 floats_file = open(os.path.join(os.path.split(__file__)[0],
602 'floating_points.txt'))
603 for line in floats_file:
604 line = line.strip()
605 if not line or line.startswith('#'):
606 continue
607 v = eval(line)
608 self.assertEqual(v, eval(repr(v)))
609 floats_file.close()
610
Eric Smith0923d1d2009-04-16 20:16:10 +0000611 @unittest.skipUnless(getattr(sys, 'float_repr_style', '') == 'short',
612 "applies only when using short float repr style")
613 def test_short_repr(self):
614 # test short float repr introduced in Python 3.1. One aspect
615 # of this repr is that we get some degree of str -> float ->
616 # str roundtripping. In particular, for any numeric string
617 # containing 15 or fewer significant digits, those exact same
618 # digits (modulo trailing zeros) should appear in the output.
619 # No more repr(0.03) -> "0.029999999999999999"!
620
621 test_strings = [
622 # output always includes *either* a decimal point and at
623 # least one digit after that point, or an exponent.
624 '0.0',
625 '1.0',
626 '0.01',
627 '0.02',
628 '0.03',
629 '0.04',
630 '0.05',
631 '1.23456789',
632 '10.0',
633 '100.0',
634 # values >= 1e16 get an exponent...
635 '1000000000000000.0',
636 '9999999999999990.0',
637 '1e+16',
638 '1e+17',
639 # ... and so do values < 1e-4
640 '0.001',
641 '0.001001',
642 '0.00010000000000001',
643 '0.0001',
644 '9.999999999999e-05',
645 '1e-05',
646 # values designed to provoke failure if the FPU rounding
647 # precision isn't set correctly
648 '8.72293771110361e+25',
649 '7.47005307342313e+26',
650 '2.86438000439698e+28',
651 '8.89142905246179e+28',
652 '3.08578087079232e+35',
653 ]
654
655 for s in test_strings:
656 negs = '-'+s
657 self.assertEqual(s, repr(float(s)))
658 self.assertEqual(negs, repr(float(negs)))
Mark Dickinson388122d2010-08-04 20:56:28 +0000659 # Since Python 3.2, repr and str are identical
660 self.assertEqual(repr(float(s)), str(float(s)))
661 self.assertEqual(repr(float(negs)), str(float(negs)))
Benjamin Petersone401c682010-07-02 23:25:44 +0000662
Eric Smith3ab08ca2010-12-04 15:17:38 +0000663@support.requires_IEEE_754
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000664class RoundTestCase(unittest.TestCase):
Benjamin Petersone401c682010-07-02 23:25:44 +0000665
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000666 def test_inf_nan(self):
667 self.assertRaises(OverflowError, round, INF)
668 self.assertRaises(OverflowError, round, -INF)
669 self.assertRaises(ValueError, round, NAN)
Mark Dickinson4ca33d12009-11-24 10:59:34 +0000670 self.assertRaises(TypeError, round, INF, 0.0)
671 self.assertRaises(TypeError, round, -INF, 1.0)
672 self.assertRaises(TypeError, round, NAN, "ceci n'est pas un integer")
673 self.assertRaises(TypeError, round, -0.0, 1j)
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000674
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000675 def test_large_n(self):
676 for n in [324, 325, 400, 2**31-1, 2**31, 2**32, 2**100]:
677 self.assertEqual(round(123.456, n), 123.456)
678 self.assertEqual(round(-123.456, n), -123.456)
679 self.assertEqual(round(1e300, n), 1e300)
680 self.assertEqual(round(1e-320, n), 1e-320)
681 self.assertEqual(round(1e150, 300), 1e150)
682 self.assertEqual(round(1e300, 307), 1e300)
683 self.assertEqual(round(-3.1415, 308), -3.1415)
684 self.assertEqual(round(1e150, 309), 1e150)
685 self.assertEqual(round(1.4e-315, 315), 1e-315)
686
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000687 def test_small_n(self):
688 for n in [-308, -309, -400, 1-2**31, -2**31, -2**31-1, -2**100]:
689 self.assertEqual(round(123.456, n), 0.0)
690 self.assertEqual(round(-123.456, n), -0.0)
691 self.assertEqual(round(1e300, n), 0.0)
692 self.assertEqual(round(1e-320, n), 0.0)
693
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000694 def test_overflow(self):
695 self.assertRaises(OverflowError, round, 1.6e308, -308)
696 self.assertRaises(OverflowError, round, -1.7e308, -308)
697
698 @unittest.skipUnless(getattr(sys, 'float_repr_style', '') == 'short',
699 "applies only when using short float repr style")
700 def test_previous_round_bugs(self):
701 # particular cases that have occurred in bug reports
702 self.assertEqual(round(562949953421312.5, 1),
703 562949953421312.5)
704 self.assertEqual(round(56294995342131.5, 3),
705 56294995342131.5)
706 # round-half-even
707 self.assertEqual(round(25.0, -1), 20.0)
708 self.assertEqual(round(35.0, -1), 40.0)
709 self.assertEqual(round(45.0, -1), 40.0)
710 self.assertEqual(round(55.0, -1), 60.0)
711 self.assertEqual(round(65.0, -1), 60.0)
712 self.assertEqual(round(75.0, -1), 80.0)
713 self.assertEqual(round(85.0, -1), 80.0)
714 self.assertEqual(round(95.0, -1), 100.0)
715
716 @unittest.skipUnless(getattr(sys, 'float_repr_style', '') == 'short',
717 "applies only when using short float repr style")
718 def test_matches_float_format(self):
719 # round should give the same results as float formatting
720 for i in range(500):
721 x = i/1000.
722 self.assertEqual(float(format(x, '.0f')), round(x, 0))
723 self.assertEqual(float(format(x, '.1f')), round(x, 1))
724 self.assertEqual(float(format(x, '.2f')), round(x, 2))
725 self.assertEqual(float(format(x, '.3f')), round(x, 3))
726
727 for i in range(5, 5000, 10):
728 x = i/1000.
729 self.assertEqual(float(format(x, '.0f')), round(x, 0))
730 self.assertEqual(float(format(x, '.1f')), round(x, 1))
731 self.assertEqual(float(format(x, '.2f')), round(x, 2))
732 self.assertEqual(float(format(x, '.3f')), round(x, 3))
733
734 for i in range(500):
735 x = random.random()
736 self.assertEqual(float(format(x, '.0f')), round(x, 0))
737 self.assertEqual(float(format(x, '.1f')), round(x, 1))
738 self.assertEqual(float(format(x, '.2f')), round(x, 2))
739 self.assertEqual(float(format(x, '.3f')), round(x, 3))
740
Eric Smith8a10ecc2009-12-02 17:58:24 +0000741 def test_format_specials(self):
742 # Test formatting of nans and infs.
743
744 def test(fmt, value, expected):
745 # Test with both % and format().
746 self.assertEqual(fmt % value, expected, fmt)
Eric Smith984bb582010-11-25 16:08:06 +0000747 fmt = fmt[1:] # strip off the %
748 self.assertEqual(format(value, fmt), expected, fmt)
Eric Smith8a10ecc2009-12-02 17:58:24 +0000749
750 for fmt in ['%e', '%f', '%g', '%.0e', '%.6f', '%.20g',
751 '%#e', '%#f', '%#g', '%#.20e', '%#.15f', '%#.3g']:
752 pfmt = '%+' + fmt[1:]
753 sfmt = '% ' + fmt[1:]
754 test(fmt, INF, 'inf')
755 test(fmt, -INF, '-inf')
756 test(fmt, NAN, 'nan')
757 test(fmt, -NAN, 'nan')
758 # When asking for a sign, it's always provided. nans are
759 # always positive.
760 test(pfmt, INF, '+inf')
761 test(pfmt, -INF, '-inf')
762 test(pfmt, NAN, '+nan')
763 test(pfmt, -NAN, '+nan')
764 # When using ' ' for a sign code, only infs can be negative.
765 # Others have a space.
766 test(sfmt, INF, ' inf')
767 test(sfmt, -INF, '-inf')
768 test(sfmt, NAN, ' nan')
769 test(sfmt, -NAN, ' nan')
770
Mark Dickinsone6a076d2009-04-18 11:48:33 +0000771
Christian Heimes99170a52007-12-19 02:07:34 +0000772# Beginning with Python 2.6 float has cross platform compatible
Georg Brandl2ee470f2008-07-16 12:55:28 +0000773# ways to create and represent inf and nan
Christian Heimes99170a52007-12-19 02:07:34 +0000774class InfNanTest(unittest.TestCase):
775 def test_inf_from_str(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000776 self.assertTrue(isinf(float("inf")))
777 self.assertTrue(isinf(float("+inf")))
778 self.assertTrue(isinf(float("-inf")))
779 self.assertTrue(isinf(float("infinity")))
780 self.assertTrue(isinf(float("+infinity")))
781 self.assertTrue(isinf(float("-infinity")))
Christian Heimes99170a52007-12-19 02:07:34 +0000782
783 self.assertEqual(repr(float("inf")), "inf")
784 self.assertEqual(repr(float("+inf")), "inf")
785 self.assertEqual(repr(float("-inf")), "-inf")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000786 self.assertEqual(repr(float("infinity")), "inf")
787 self.assertEqual(repr(float("+infinity")), "inf")
788 self.assertEqual(repr(float("-infinity")), "-inf")
Christian Heimes99170a52007-12-19 02:07:34 +0000789
790 self.assertEqual(repr(float("INF")), "inf")
791 self.assertEqual(repr(float("+Inf")), "inf")
792 self.assertEqual(repr(float("-iNF")), "-inf")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000793 self.assertEqual(repr(float("Infinity")), "inf")
794 self.assertEqual(repr(float("+iNfInItY")), "inf")
795 self.assertEqual(repr(float("-INFINITY")), "-inf")
Christian Heimes99170a52007-12-19 02:07:34 +0000796
797 self.assertEqual(str(float("inf")), "inf")
798 self.assertEqual(str(float("+inf")), "inf")
799 self.assertEqual(str(float("-inf")), "-inf")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000800 self.assertEqual(str(float("infinity")), "inf")
801 self.assertEqual(str(float("+infinity")), "inf")
802 self.assertEqual(str(float("-infinity")), "-inf")
Christian Heimes99170a52007-12-19 02:07:34 +0000803
804 self.assertRaises(ValueError, float, "info")
805 self.assertRaises(ValueError, float, "+info")
806 self.assertRaises(ValueError, float, "-info")
807 self.assertRaises(ValueError, float, "in")
808 self.assertRaises(ValueError, float, "+in")
809 self.assertRaises(ValueError, float, "-in")
Georg Brandl2ee470f2008-07-16 12:55:28 +0000810 self.assertRaises(ValueError, float, "infinit")
811 self.assertRaises(ValueError, float, "+Infin")
812 self.assertRaises(ValueError, float, "-INFI")
813 self.assertRaises(ValueError, float, "infinitys")
Christian Heimes99170a52007-12-19 02:07:34 +0000814
Mark Dickinsonbd16edd2009-05-20 22:05:25 +0000815 self.assertRaises(ValueError, float, "++Inf")
816 self.assertRaises(ValueError, float, "-+inf")
817 self.assertRaises(ValueError, float, "+-infinity")
818 self.assertRaises(ValueError, float, "--Infinity")
819
Christian Heimes99170a52007-12-19 02:07:34 +0000820 def test_inf_as_str(self):
821 self.assertEqual(repr(1e300 * 1e300), "inf")
822 self.assertEqual(repr(-1e300 * 1e300), "-inf")
823
824 self.assertEqual(str(1e300 * 1e300), "inf")
825 self.assertEqual(str(-1e300 * 1e300), "-inf")
826
827 def test_nan_from_str(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000828 self.assertTrue(isnan(float("nan")))
829 self.assertTrue(isnan(float("+nan")))
830 self.assertTrue(isnan(float("-nan")))
Christian Heimes99170a52007-12-19 02:07:34 +0000831
832 self.assertEqual(repr(float("nan")), "nan")
833 self.assertEqual(repr(float("+nan")), "nan")
834 self.assertEqual(repr(float("-nan")), "nan")
835
836 self.assertEqual(repr(float("NAN")), "nan")
837 self.assertEqual(repr(float("+NAn")), "nan")
838 self.assertEqual(repr(float("-NaN")), "nan")
839
840 self.assertEqual(str(float("nan")), "nan")
841 self.assertEqual(str(float("+nan")), "nan")
842 self.assertEqual(str(float("-nan")), "nan")
843
844 self.assertRaises(ValueError, float, "nana")
845 self.assertRaises(ValueError, float, "+nana")
846 self.assertRaises(ValueError, float, "-nana")
847 self.assertRaises(ValueError, float, "na")
848 self.assertRaises(ValueError, float, "+na")
849 self.assertRaises(ValueError, float, "-na")
850
Mark Dickinsonbd16edd2009-05-20 22:05:25 +0000851 self.assertRaises(ValueError, float, "++nan")
852 self.assertRaises(ValueError, float, "-+NAN")
853 self.assertRaises(ValueError, float, "+-NaN")
854 self.assertRaises(ValueError, float, "--nAn")
855
Christian Heimes99170a52007-12-19 02:07:34 +0000856 def test_nan_as_str(self):
857 self.assertEqual(repr(1e300 * 1e300 * 0), "nan")
858 self.assertEqual(repr(-1e300 * 1e300 * 0), "nan")
859
860 self.assertEqual(str(1e300 * 1e300 * 0), "nan")
861 self.assertEqual(str(-1e300 * 1e300 * 0), "nan")
Christian Heimes827b35c2007-12-10 22:19:17 +0000862
Christian Heimes53876d92008-04-19 00:31:39 +0000863 def notest_float_nan(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000864 self.assertTrue(NAN.is_nan())
865 self.assertFalse(INF.is_nan())
866 self.assertFalse((0.).is_nan())
Christian Heimes53876d92008-04-19 00:31:39 +0000867
868 def notest_float_inf(self):
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000869 self.assertTrue(INF.is_inf())
870 self.assertFalse(NAN.is_inf())
871 self.assertFalse((0.).is_inf())
Christian Heimes53876d92008-04-19 00:31:39 +0000872
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000873fromHex = float.fromhex
874toHex = float.hex
875class HexFloatTestCase(unittest.TestCase):
876 MAX = fromHex('0x.fffffffffffff8p+1024') # max normal
877 MIN = fromHex('0x1p-1022') # min normal
878 TINY = fromHex('0x0.0000000000001p-1022') # min subnormal
879 EPS = fromHex('0x0.0000000000001p0') # diff between 1.0 and next float up
880
881 def identical(self, x, y):
882 # check that floats x and y are identical, or that both
883 # are NaNs
884 if isnan(x) or isnan(y):
885 if isnan(x) == isnan(y):
886 return
887 elif x == y and (x != 0.0 or copysign(1.0, x) == copysign(1.0, y)):
888 return
889 self.fail('%r not identical to %r' % (x, y))
890
891 def test_ends(self):
Mark Dickinson38bbc482008-07-16 11:32:23 +0000892 self.identical(self.MIN, ldexp(1.0, -1022))
893 self.identical(self.TINY, ldexp(1.0, -1074))
894 self.identical(self.EPS, ldexp(1.0, -52))
895 self.identical(self.MAX, 2.*(ldexp(1.0, 1023) - ldexp(1.0, 970)))
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000896
897 def test_invalid_inputs(self):
898 invalid_inputs = [
899 'infi', # misspelt infinities and nans
900 '-Infinit',
901 '++inf',
902 '-+Inf',
903 '--nan',
904 '+-NaN',
905 'snan',
906 'NaNs',
907 'nna',
Mark Dickinsond1ec8b22009-05-11 15:45:15 +0000908 'an',
909 'nf',
910 'nfinity',
911 'inity',
912 'iinity',
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000913 '0xnan',
914 '',
915 ' ',
916 'x1.0p0',
917 '0xX1.0p0',
918 '+ 0x1.0p0', # internal whitespace
919 '- 0x1.0p0',
920 '0 x1.0p0',
921 '0x 1.0p0',
922 '0x1 2.0p0',
923 '+0x1 .0p0',
924 '0x1. 0p0',
925 '-0x1.0 1p0',
926 '-0x1.0 p0',
927 '+0x1.0p +0',
928 '0x1.0p -0',
929 '0x1.0p 0',
930 '+0x1.0p+ 0',
931 '-0x1.0p- 0',
932 '++0x1.0p-0', # double signs
933 '--0x1.0p0',
934 '+-0x1.0p+0',
935 '-+0x1.0p0',
936 '0x1.0p++0',
937 '+0x1.0p+-0',
938 '-0x1.0p-+0',
939 '0x1.0p--0',
940 '0x1.0.p0',
941 '0x.p0', # no hex digits before or after point
942 '0x1,p0', # wrong decimal point character
943 '0x1pa',
944 '0x1p\uff10', # fullwidth Unicode digits
945 '\uff10x1p0',
946 '0x\uff11p0',
947 '0x1.\uff10p0',
948 '0x1p0 \n 0x2p0',
949 '0x1p0\0 0x1p0', # embedded null byte is not end of string
950 ]
951 for x in invalid_inputs:
Mark Dickinson589b7952008-08-21 20:05:56 +0000952 try:
953 result = fromHex(x)
954 except ValueError:
955 pass
956 else:
957 self.fail('Expected float.fromhex(%r) to raise ValueError; '
958 'got %r instead' % (x, result))
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000959
960
Mark Dickinsond1ec8b22009-05-11 15:45:15 +0000961 def test_whitespace(self):
962 value_pairs = [
963 ('inf', INF),
964 ('-Infinity', -INF),
965 ('nan', NAN),
966 ('1.0', 1.0),
967 ('-0x.2', -0.125),
968 ('-0.0', -0.0)
969 ]
970 whitespace = [
971 '',
972 ' ',
973 '\t',
974 '\n',
975 '\n \t',
976 '\f',
977 '\v',
978 '\r'
979 ]
980 for inp, expected in value_pairs:
981 for lead in whitespace:
982 for trail in whitespace:
983 got = fromHex(lead + inp + trail)
984 self.identical(got, expected)
985
986
Mark Dickinson65fe25e2008-07-16 11:30:51 +0000987 def test_from_hex(self):
988 MIN = self.MIN;
989 MAX = self.MAX;
990 TINY = self.TINY;
991 EPS = self.EPS;
992
993 # two spellings of infinity, with optional signs; case-insensitive
994 self.identical(fromHex('inf'), INF)
995 self.identical(fromHex('+Inf'), INF)
996 self.identical(fromHex('-INF'), -INF)
997 self.identical(fromHex('iNf'), INF)
998 self.identical(fromHex('Infinity'), INF)
999 self.identical(fromHex('+INFINITY'), INF)
1000 self.identical(fromHex('-infinity'), -INF)
1001 self.identical(fromHex('-iNFiNitY'), -INF)
1002
1003 # nans with optional sign; case insensitive
1004 self.identical(fromHex('nan'), NAN)
1005 self.identical(fromHex('+NaN'), NAN)
1006 self.identical(fromHex('-NaN'), NAN)
1007 self.identical(fromHex('-nAN'), NAN)
1008
1009 # variations in input format
1010 self.identical(fromHex('1'), 1.0)
1011 self.identical(fromHex('+1'), 1.0)
1012 self.identical(fromHex('1.'), 1.0)
1013 self.identical(fromHex('1.0'), 1.0)
1014 self.identical(fromHex('1.0p0'), 1.0)
1015 self.identical(fromHex('01'), 1.0)
1016 self.identical(fromHex('01.'), 1.0)
1017 self.identical(fromHex('0x1'), 1.0)
1018 self.identical(fromHex('0x1.'), 1.0)
1019 self.identical(fromHex('0x1.0'), 1.0)
1020 self.identical(fromHex('+0x1.0'), 1.0)
1021 self.identical(fromHex('0x1p0'), 1.0)
1022 self.identical(fromHex('0X1p0'), 1.0)
1023 self.identical(fromHex('0X1P0'), 1.0)
1024 self.identical(fromHex('0x1P0'), 1.0)
1025 self.identical(fromHex('0x1.p0'), 1.0)
1026 self.identical(fromHex('0x1.0p0'), 1.0)
1027 self.identical(fromHex('0x.1p4'), 1.0)
1028 self.identical(fromHex('0x.1p04'), 1.0)
1029 self.identical(fromHex('0x.1p004'), 1.0)
1030 self.identical(fromHex('0x1p+0'), 1.0)
1031 self.identical(fromHex('0x1P-0'), 1.0)
1032 self.identical(fromHex('+0x1p0'), 1.0)
1033 self.identical(fromHex('0x01p0'), 1.0)
1034 self.identical(fromHex('0x1p00'), 1.0)
1035 self.identical(fromHex(' 0x1p0 '), 1.0)
1036 self.identical(fromHex('\n 0x1p0'), 1.0)
1037 self.identical(fromHex('0x1p0 \t'), 1.0)
1038 self.identical(fromHex('0xap0'), 10.0)
1039 self.identical(fromHex('0xAp0'), 10.0)
1040 self.identical(fromHex('0xaP0'), 10.0)
1041 self.identical(fromHex('0xAP0'), 10.0)
1042 self.identical(fromHex('0xbep0'), 190.0)
1043 self.identical(fromHex('0xBep0'), 190.0)
1044 self.identical(fromHex('0xbEp0'), 190.0)
1045 self.identical(fromHex('0XBE0P-4'), 190.0)
1046 self.identical(fromHex('0xBEp0'), 190.0)
1047 self.identical(fromHex('0xB.Ep4'), 190.0)
1048 self.identical(fromHex('0x.BEp8'), 190.0)
1049 self.identical(fromHex('0x.0BEp12'), 190.0)
1050
1051 # moving the point around
1052 pi = fromHex('0x1.921fb54442d18p1')
1053 self.identical(fromHex('0x.006487ed5110b46p11'), pi)
1054 self.identical(fromHex('0x.00c90fdaa22168cp10'), pi)
1055 self.identical(fromHex('0x.01921fb54442d18p9'), pi)
1056 self.identical(fromHex('0x.03243f6a8885a3p8'), pi)
1057 self.identical(fromHex('0x.06487ed5110b46p7'), pi)
1058 self.identical(fromHex('0x.0c90fdaa22168cp6'), pi)
1059 self.identical(fromHex('0x.1921fb54442d18p5'), pi)
1060 self.identical(fromHex('0x.3243f6a8885a3p4'), pi)
1061 self.identical(fromHex('0x.6487ed5110b46p3'), pi)
1062 self.identical(fromHex('0x.c90fdaa22168cp2'), pi)
1063 self.identical(fromHex('0x1.921fb54442d18p1'), pi)
1064 self.identical(fromHex('0x3.243f6a8885a3p0'), pi)
1065 self.identical(fromHex('0x6.487ed5110b46p-1'), pi)
1066 self.identical(fromHex('0xc.90fdaa22168cp-2'), pi)
1067 self.identical(fromHex('0x19.21fb54442d18p-3'), pi)
1068 self.identical(fromHex('0x32.43f6a8885a3p-4'), pi)
1069 self.identical(fromHex('0x64.87ed5110b46p-5'), pi)
1070 self.identical(fromHex('0xc9.0fdaa22168cp-6'), pi)
1071 self.identical(fromHex('0x192.1fb54442d18p-7'), pi)
1072 self.identical(fromHex('0x324.3f6a8885a3p-8'), pi)
1073 self.identical(fromHex('0x648.7ed5110b46p-9'), pi)
1074 self.identical(fromHex('0xc90.fdaa22168cp-10'), pi)
1075 self.identical(fromHex('0x1921.fb54442d18p-11'), pi)
1076 # ...
1077 self.identical(fromHex('0x1921fb54442d1.8p-47'), pi)
1078 self.identical(fromHex('0x3243f6a8885a3p-48'), pi)
1079 self.identical(fromHex('0x6487ed5110b46p-49'), pi)
1080 self.identical(fromHex('0xc90fdaa22168cp-50'), pi)
1081 self.identical(fromHex('0x1921fb54442d18p-51'), pi)
1082 self.identical(fromHex('0x3243f6a8885a30p-52'), pi)
1083 self.identical(fromHex('0x6487ed5110b460p-53'), pi)
1084 self.identical(fromHex('0xc90fdaa22168c0p-54'), pi)
1085 self.identical(fromHex('0x1921fb54442d180p-55'), pi)
1086
1087
1088 # results that should overflow...
1089 self.assertRaises(OverflowError, fromHex, '-0x1p1024')
1090 self.assertRaises(OverflowError, fromHex, '0x1p+1025')
1091 self.assertRaises(OverflowError, fromHex, '+0X1p1030')
1092 self.assertRaises(OverflowError, fromHex, '-0x1p+1100')
1093 self.assertRaises(OverflowError, fromHex, '0X1p123456789123456789')
1094 self.assertRaises(OverflowError, fromHex, '+0X.8p+1025')
1095 self.assertRaises(OverflowError, fromHex, '+0x0.8p1025')
1096 self.assertRaises(OverflowError, fromHex, '-0x0.4p1026')
1097 self.assertRaises(OverflowError, fromHex, '0X2p+1023')
1098 self.assertRaises(OverflowError, fromHex, '0x2.p1023')
1099 self.assertRaises(OverflowError, fromHex, '-0x2.0p+1023')
1100 self.assertRaises(OverflowError, fromHex, '+0X4p+1022')
1101 self.assertRaises(OverflowError, fromHex, '0x1.ffffffffffffffp+1023')
1102 self.assertRaises(OverflowError, fromHex, '-0X1.fffffffffffff9p1023')
1103 self.assertRaises(OverflowError, fromHex, '0X1.fffffffffffff8p1023')
1104 self.assertRaises(OverflowError, fromHex, '+0x3.fffffffffffffp1022')
1105 self.assertRaises(OverflowError, fromHex, '0x3fffffffffffffp+970')
1106 self.assertRaises(OverflowError, fromHex, '0x10000000000000000p960')
1107 self.assertRaises(OverflowError, fromHex, '-0Xffffffffffffffffp960')
1108
1109 # ...and those that round to +-max float
1110 self.identical(fromHex('+0x1.fffffffffffffp+1023'), MAX)
1111 self.identical(fromHex('-0X1.fffffffffffff7p1023'), -MAX)
1112 self.identical(fromHex('0X1.fffffffffffff7fffffffffffffp1023'), MAX)
1113
1114 # zeros
1115 self.identical(fromHex('0x0p0'), 0.0)
1116 self.identical(fromHex('0x0p1000'), 0.0)
1117 self.identical(fromHex('-0x0p1023'), -0.0)
1118 self.identical(fromHex('0X0p1024'), 0.0)
1119 self.identical(fromHex('-0x0p1025'), -0.0)
1120 self.identical(fromHex('0X0p2000'), 0.0)
1121 self.identical(fromHex('0x0p123456789123456789'), 0.0)
1122 self.identical(fromHex('-0X0p-0'), -0.0)
1123 self.identical(fromHex('-0X0p-1000'), -0.0)
1124 self.identical(fromHex('0x0p-1023'), 0.0)
1125 self.identical(fromHex('-0X0p-1024'), -0.0)
1126 self.identical(fromHex('-0x0p-1025'), -0.0)
1127 self.identical(fromHex('-0x0p-1072'), -0.0)
1128 self.identical(fromHex('0X0p-1073'), 0.0)
1129 self.identical(fromHex('-0x0p-1074'), -0.0)
1130 self.identical(fromHex('0x0p-1075'), 0.0)
1131 self.identical(fromHex('0X0p-1076'), 0.0)
1132 self.identical(fromHex('-0X0p-2000'), -0.0)
1133 self.identical(fromHex('-0x0p-123456789123456789'), -0.0)
1134
1135 # values that should underflow to 0
1136 self.identical(fromHex('0X1p-1075'), 0.0)
1137 self.identical(fromHex('-0X1p-1075'), -0.0)
1138 self.identical(fromHex('-0x1p-123456789123456789'), -0.0)
1139 self.identical(fromHex('0x1.00000000000000001p-1075'), TINY)
1140 self.identical(fromHex('-0x1.1p-1075'), -TINY)
1141 self.identical(fromHex('0x1.fffffffffffffffffp-1075'), TINY)
1142
1143 # check round-half-even is working correctly near 0 ...
1144 self.identical(fromHex('0x1p-1076'), 0.0)
1145 self.identical(fromHex('0X2p-1076'), 0.0)
1146 self.identical(fromHex('0X3p-1076'), TINY)
1147 self.identical(fromHex('0x4p-1076'), TINY)
1148 self.identical(fromHex('0X5p-1076'), TINY)
1149 self.identical(fromHex('0X6p-1076'), 2*TINY)
1150 self.identical(fromHex('0x7p-1076'), 2*TINY)
1151 self.identical(fromHex('0X8p-1076'), 2*TINY)
1152 self.identical(fromHex('0X9p-1076'), 2*TINY)
1153 self.identical(fromHex('0xap-1076'), 2*TINY)
1154 self.identical(fromHex('0Xbp-1076'), 3*TINY)
1155 self.identical(fromHex('0xcp-1076'), 3*TINY)
1156 self.identical(fromHex('0Xdp-1076'), 3*TINY)
1157 self.identical(fromHex('0Xep-1076'), 4*TINY)
1158 self.identical(fromHex('0xfp-1076'), 4*TINY)
1159 self.identical(fromHex('0x10p-1076'), 4*TINY)
1160 self.identical(fromHex('-0x1p-1076'), -0.0)
1161 self.identical(fromHex('-0X2p-1076'), -0.0)
1162 self.identical(fromHex('-0x3p-1076'), -TINY)
1163 self.identical(fromHex('-0X4p-1076'), -TINY)
1164 self.identical(fromHex('-0x5p-1076'), -TINY)
1165 self.identical(fromHex('-0x6p-1076'), -2*TINY)
1166 self.identical(fromHex('-0X7p-1076'), -2*TINY)
1167 self.identical(fromHex('-0X8p-1076'), -2*TINY)
1168 self.identical(fromHex('-0X9p-1076'), -2*TINY)
1169 self.identical(fromHex('-0Xap-1076'), -2*TINY)
1170 self.identical(fromHex('-0xbp-1076'), -3*TINY)
1171 self.identical(fromHex('-0xcp-1076'), -3*TINY)
1172 self.identical(fromHex('-0Xdp-1076'), -3*TINY)
1173 self.identical(fromHex('-0xep-1076'), -4*TINY)
1174 self.identical(fromHex('-0Xfp-1076'), -4*TINY)
1175 self.identical(fromHex('-0X10p-1076'), -4*TINY)
1176
1177 # ... and near MIN ...
1178 self.identical(fromHex('0x0.ffffffffffffd6p-1022'), MIN-3*TINY)
1179 self.identical(fromHex('0x0.ffffffffffffd8p-1022'), MIN-2*TINY)
1180 self.identical(fromHex('0x0.ffffffffffffdap-1022'), MIN-2*TINY)
1181 self.identical(fromHex('0x0.ffffffffffffdcp-1022'), MIN-2*TINY)
1182 self.identical(fromHex('0x0.ffffffffffffdep-1022'), MIN-2*TINY)
1183 self.identical(fromHex('0x0.ffffffffffffe0p-1022'), MIN-2*TINY)
1184 self.identical(fromHex('0x0.ffffffffffffe2p-1022'), MIN-2*TINY)
1185 self.identical(fromHex('0x0.ffffffffffffe4p-1022'), MIN-2*TINY)
1186 self.identical(fromHex('0x0.ffffffffffffe6p-1022'), MIN-2*TINY)
1187 self.identical(fromHex('0x0.ffffffffffffe8p-1022'), MIN-2*TINY)
1188 self.identical(fromHex('0x0.ffffffffffffeap-1022'), MIN-TINY)
1189 self.identical(fromHex('0x0.ffffffffffffecp-1022'), MIN-TINY)
1190 self.identical(fromHex('0x0.ffffffffffffeep-1022'), MIN-TINY)
1191 self.identical(fromHex('0x0.fffffffffffff0p-1022'), MIN-TINY)
1192 self.identical(fromHex('0x0.fffffffffffff2p-1022'), MIN-TINY)
1193 self.identical(fromHex('0x0.fffffffffffff4p-1022'), MIN-TINY)
1194 self.identical(fromHex('0x0.fffffffffffff6p-1022'), MIN-TINY)
1195 self.identical(fromHex('0x0.fffffffffffff8p-1022'), MIN)
1196 self.identical(fromHex('0x0.fffffffffffffap-1022'), MIN)
1197 self.identical(fromHex('0x0.fffffffffffffcp-1022'), MIN)
1198 self.identical(fromHex('0x0.fffffffffffffep-1022'), MIN)
1199 self.identical(fromHex('0x1.00000000000000p-1022'), MIN)
1200 self.identical(fromHex('0x1.00000000000002p-1022'), MIN)
1201 self.identical(fromHex('0x1.00000000000004p-1022'), MIN)
1202 self.identical(fromHex('0x1.00000000000006p-1022'), MIN)
1203 self.identical(fromHex('0x1.00000000000008p-1022'), MIN)
1204 self.identical(fromHex('0x1.0000000000000ap-1022'), MIN+TINY)
1205 self.identical(fromHex('0x1.0000000000000cp-1022'), MIN+TINY)
1206 self.identical(fromHex('0x1.0000000000000ep-1022'), MIN+TINY)
1207 self.identical(fromHex('0x1.00000000000010p-1022'), MIN+TINY)
1208 self.identical(fromHex('0x1.00000000000012p-1022'), MIN+TINY)
1209 self.identical(fromHex('0x1.00000000000014p-1022'), MIN+TINY)
1210 self.identical(fromHex('0x1.00000000000016p-1022'), MIN+TINY)
1211 self.identical(fromHex('0x1.00000000000018p-1022'), MIN+2*TINY)
1212
1213 # ... and near 1.0.
1214 self.identical(fromHex('0x0.fffffffffffff0p0'), 1.0-EPS)
1215 self.identical(fromHex('0x0.fffffffffffff1p0'), 1.0-EPS)
1216 self.identical(fromHex('0X0.fffffffffffff2p0'), 1.0-EPS)
1217 self.identical(fromHex('0x0.fffffffffffff3p0'), 1.0-EPS)
1218 self.identical(fromHex('0X0.fffffffffffff4p0'), 1.0-EPS)
1219 self.identical(fromHex('0X0.fffffffffffff5p0'), 1.0-EPS/2)
1220 self.identical(fromHex('0X0.fffffffffffff6p0'), 1.0-EPS/2)
1221 self.identical(fromHex('0x0.fffffffffffff7p0'), 1.0-EPS/2)
1222 self.identical(fromHex('0x0.fffffffffffff8p0'), 1.0-EPS/2)
1223 self.identical(fromHex('0X0.fffffffffffff9p0'), 1.0-EPS/2)
1224 self.identical(fromHex('0X0.fffffffffffffap0'), 1.0-EPS/2)
1225 self.identical(fromHex('0x0.fffffffffffffbp0'), 1.0-EPS/2)
1226 self.identical(fromHex('0X0.fffffffffffffcp0'), 1.0)
1227 self.identical(fromHex('0x0.fffffffffffffdp0'), 1.0)
1228 self.identical(fromHex('0X0.fffffffffffffep0'), 1.0)
1229 self.identical(fromHex('0x0.ffffffffffffffp0'), 1.0)
1230 self.identical(fromHex('0X1.00000000000000p0'), 1.0)
1231 self.identical(fromHex('0X1.00000000000001p0'), 1.0)
1232 self.identical(fromHex('0x1.00000000000002p0'), 1.0)
1233 self.identical(fromHex('0X1.00000000000003p0'), 1.0)
1234 self.identical(fromHex('0x1.00000000000004p0'), 1.0)
1235 self.identical(fromHex('0X1.00000000000005p0'), 1.0)
1236 self.identical(fromHex('0X1.00000000000006p0'), 1.0)
1237 self.identical(fromHex('0X1.00000000000007p0'), 1.0)
1238 self.identical(fromHex('0x1.00000000000007ffffffffffffffffffffp0'),
1239 1.0)
1240 self.identical(fromHex('0x1.00000000000008p0'), 1.0)
1241 self.identical(fromHex('0x1.00000000000008000000000000000001p0'),
1242 1+EPS)
1243 self.identical(fromHex('0X1.00000000000009p0'), 1.0+EPS)
1244 self.identical(fromHex('0x1.0000000000000ap0'), 1.0+EPS)
1245 self.identical(fromHex('0x1.0000000000000bp0'), 1.0+EPS)
1246 self.identical(fromHex('0X1.0000000000000cp0'), 1.0+EPS)
1247 self.identical(fromHex('0x1.0000000000000dp0'), 1.0+EPS)
1248 self.identical(fromHex('0x1.0000000000000ep0'), 1.0+EPS)
1249 self.identical(fromHex('0X1.0000000000000fp0'), 1.0+EPS)
1250 self.identical(fromHex('0x1.00000000000010p0'), 1.0+EPS)
1251 self.identical(fromHex('0X1.00000000000011p0'), 1.0+EPS)
1252 self.identical(fromHex('0x1.00000000000012p0'), 1.0+EPS)
1253 self.identical(fromHex('0X1.00000000000013p0'), 1.0+EPS)
1254 self.identical(fromHex('0X1.00000000000014p0'), 1.0+EPS)
1255 self.identical(fromHex('0x1.00000000000015p0'), 1.0+EPS)
1256 self.identical(fromHex('0x1.00000000000016p0'), 1.0+EPS)
1257 self.identical(fromHex('0X1.00000000000017p0'), 1.0+EPS)
1258 self.identical(fromHex('0x1.00000000000017ffffffffffffffffffffp0'),
1259 1.0+EPS)
1260 self.identical(fromHex('0x1.00000000000018p0'), 1.0+2*EPS)
1261 self.identical(fromHex('0X1.00000000000018000000000000000001p0'),
1262 1.0+2*EPS)
1263 self.identical(fromHex('0x1.00000000000019p0'), 1.0+2*EPS)
1264 self.identical(fromHex('0X1.0000000000001ap0'), 1.0+2*EPS)
1265 self.identical(fromHex('0X1.0000000000001bp0'), 1.0+2*EPS)
1266 self.identical(fromHex('0x1.0000000000001cp0'), 1.0+2*EPS)
1267 self.identical(fromHex('0x1.0000000000001dp0'), 1.0+2*EPS)
1268 self.identical(fromHex('0x1.0000000000001ep0'), 1.0+2*EPS)
1269 self.identical(fromHex('0X1.0000000000001fp0'), 1.0+2*EPS)
1270 self.identical(fromHex('0x1.00000000000020p0'), 1.0+2*EPS)
1271
1272 def test_roundtrip(self):
1273 def roundtrip(x):
1274 return fromHex(toHex(x))
1275
1276 for x in [NAN, INF, self.MAX, self.MIN, self.MIN-self.TINY, self.TINY, 0.0]:
1277 self.identical(x, roundtrip(x))
1278 self.identical(-x, roundtrip(-x))
1279
1280 # fromHex(toHex(x)) should exactly recover x, for any non-NaN float x.
1281 import random
1282 for i in range(10000):
1283 e = random.randrange(-1200, 1200)
1284 m = random.random()
1285 s = random.choice([1.0, -1.0])
1286 try:
1287 x = s*ldexp(m, e)
1288 except OverflowError:
1289 pass
1290 else:
1291 self.identical(x, fromHex(toHex(x)))
1292
Christian Heimes53876d92008-04-19 00:31:39 +00001293
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001294def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001295 support.run_unittest(
Amaury Forgeot d'Arc7e958d12008-09-06 21:03:22 +00001296 GeneralFloatCases,
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001297 FormatFunctionsTestCase,
1298 UnknownFormatTestCase,
Eric Smith8c663262007-08-25 02:26:07 +00001299 IEEEFormatTestCase,
Christian Heimes827b35c2007-12-10 22:19:17 +00001300 FormatTestCase,
Christian Heimes99170a52007-12-19 02:07:34 +00001301 ReprTestCase,
Mark Dickinsone6a076d2009-04-18 11:48:33 +00001302 RoundTestCase,
Christian Heimes99170a52007-12-19 02:07:34 +00001303 InfNanTest,
Mark Dickinson65fe25e2008-07-16 11:30:51 +00001304 HexFloatTestCase,
Christian Heimesb76922a2007-12-11 01:06:40 +00001305 )
Michael W. Hudsonba283e22005-05-27 15:23:20 +00001306
1307if __name__ == '__main__':
1308 test_main()