summaryrefslogtreecommitdiff
path: root/utils/benchmark/benchmark-parse.py
blob: dd9844931481aa097740e8b6d539a40868fba299 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#-----------------------------------------------------------------
# Benchmarking utility for internal use.
#
# Use with Python 3.6+
#
# Eli Bendersky [https://eli.thegreenplace.net/]
# License: BSD
#-----------------------------------------------------------------
import os
import statistics
import sys
import time

sys.path.extend(['.', '..'])

from pycparser import c_parser, c_ast


def measure_parse(text, n, progress_cb):
    times = []
    for i in range(n):
        parser = c_parser.CParser()
        t1 = time.time()
        ast = parser.parse(text, '')
        elapsed = time.time() - t1
        assert isinstance(ast, c_ast.FileAST)
        times.append(elapsed)
        progress_cb(i)
    return times


def measure_file(filename, n):
    progress_cb = lambda i: print('.', sep='', end='', flush=True)
    with open(filename) as f:
        print('%-25s' % os.path.basename(filename), end='', flush=True)
        text = f.read()
        times = measure_parse(text, n, progress_cb)
    print('    Mean: %.3f  Stddev: %.3f' % (statistics.mean(times),
                                            statistics.stdev(times)))


NUM_RUNS = 5


if __name__ == '__main__':
    if len(sys.argv) < 2:
        print("Usage: %s <dir with input files>")
        sys.exit(1)
    for filename in os.listdir(sys.argv[1]):
        filename = os.path.join(sys.argv[1], filename)
        measure_file(filename, NUM_RUNS)