File: string_format_modulo2.py

package info (click to toggle)
giac 1.9.0.93%2Bdfsg2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 117,732 kB
  • sloc: cpp: 404,272; ansic: 205,462; python: 30,548; javascript: 28,788; makefile: 17,997; yacc: 2,690; lex: 2,464; sh: 705; perl: 314; lisp: 216; asm: 62; java: 41; xml: 36; sed: 16; csh: 7; pascal: 6
file content (24 lines) | stat: -rw-r--r-- 834 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# test formatting floats with large precision, that it doesn't overflow the buffer

def test(num, num_str):
    if num == float('inf') or num == 0.0 and num_str != '0.0':
        # skip numbers that overflow or underflow the FP precision
        return
    for kind in ('e', 'f', 'g'):
        # check precision either side of the size of the buffer (32 bytes)
        for prec in range(23, 36, 2):
            fmt = '%.' + '%d' % prec + kind
            s = fmt % num
            check = abs(float(s) - num)
            if num > 1:
                check /= num
            if check > 1e-6:
                print('FAIL', num_str, fmt, s, len(s), check)

# check pure zero
test(0.0, '0.0')

# check some powers of 10, making sure to include exponents with 3 digits
for e in range(-8, 8):
    num = pow(10, e)
    test(num, '1e%d' % e)