summaryrefslogtreecommitdiffstats
path: root/bin/memoicmp.py
blob: 63f6538d4baaa4c9ce479e1d55ed58b5a7459e0f (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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#!/usr/bin/env python
#
# A script to compare the --debug=memoizer output found in
# two different files.

from __future__ import print_function

import sys

def memoize_output(fname):
    mout = {}
    #lines=filter(lambda words:
    #             len(words) == 5 and
    #             words[1] == 'hits' and words[3] == 'misses',
    #             map(string.split, open(fname,'r').readlines()))
    #for line in lines:
    #    mout[line[-1]] = ( int(line[0]), int(line[2]) )
    for line in open(fname,'r').readlines():
        words = line.split()
        if len(words) == 5 and words[1] == 'hits' and words[3] == 'misses':
            mout[words[-1]] = ( int(words[0]), int(words[2]) )
    return mout

def memoize_cmp(filea, fileb):
        ma = memoize_output(filea)
        mb = memoize_output(fileb)

        print('All output: %s / %s [delta]'%(filea, fileb))
        print('----------HITS---------- ---------MISSES---------')
        cfmt='%7d/%-7d [%d]'
        ma_o = []
        mb_o = []
        mab  = []
        for k in list(ma.keys()):
                if k in list(mb.keys()):
                        if k not in mab:
                                mab.append(k)
                else:
                        ma_o.append(k)
        for k in list(mb.keys()):
                if k in list(ma.keys()):
                        if k not in mab:
                                mab.append(k)
                else:
                        mb_o.append(k)

        mab.sort()
        ma_o.sort()
        mb_o.sort()

        for k in mab:
                hits = cfmt%(ma[k][0], mb[k][0], mb[k][0]-ma[k][0])
                miss = cfmt%(ma[k][1], mb[k][1], mb[k][1]-ma[k][1])
                print('%-24s %-24s  %s'%(hits, miss, k))

        for k in ma_o:
                hits = '%7d/ --'%(ma[k][0])
                miss = '%7d/ --'%(ma[k][1])
                print('%-24s %-24s  %s'%(hits, miss, k))

        for k in mb_o:
                hits = '    -- /%-7d'%(mb[k][0])
                miss = '    -- /%-7d'%(mb[k][1])
                print('%-24s %-24s  %s'%(hits, miss, k))

        print('-'*(24+24+1+20))


if __name__ == "__main__":
        if len(sys.argv) != 3:
                print("""Usage: %s file1 file2

Compares --debug=memomize output from file1 against file2."""%sys.argv[0])
                sys.exit(1)

        memoize_cmp(sys.argv[1], sys.argv[2])
        sys.exit(0)

# Local Variables:
# tab-width:4
# indent-tabs-mode:nil
# End:
# vim: set expandtab tabstop=4 shiftwidth=4: