/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to tools/time_graph.py

  • Committer: Jelmer Vernooij
  • Date: 2018-05-19 13:16:11 UTC
  • mto: (6968.4.3 git-archive)
  • mto: This revision was merged to the branch mainline in revision 6972.
  • Revision ID: jelmer@jelmer.uk-20180519131611-l9h9ud41j7qg1m03
Move tar/zip to breezy.archive.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/env python
 
2
import random
 
3
import os
 
4
import time
 
5
import sys
 
6
import optparse
 
7
from breezy import (
 
8
    branch,
 
9
    commands,
 
10
    graph,
 
11
    ui,
 
12
    trace,
 
13
    _known_graph_py,
 
14
    _known_graph_pyx,
 
15
    )
 
16
from breezy.ui import text
 
17
 
 
18
p = optparse.OptionParser()
 
19
p.add_option('--quick', default=False, action='store_true')
 
20
p.add_option('--max-combinations', default=500, type=int)
 
21
p.add_option('--lsprof', default=None, type=str)
 
22
opts, args = p.parse_args(sys.argv[1:])
 
23
 
 
24
trace.enable_default_logging()
 
25
ui.ui_factory = text.TextUIFactory()
 
26
 
 
27
begin = time.clock()
 
28
if len(args) >= 1:
 
29
    b = branch.Branch.open(args[0])
 
30
else:
 
31
    b = branch.Branch.open('.')
 
32
with b.lock_read():
 
33
    g = b.repository.get_graph()
 
34
    parent_map = dict(p for p in g.iter_ancestry([b.last_revision()])
 
35
                         if p[1] is not None)
 
36
end = time.clock()
 
37
 
 
38
print('Found %d nodes, loaded in %.3fs' % (len(parent_map), end - begin))
 
39
 
 
40
def all_heads_comp(g, combinations):
 
41
    h = []
 
42
    with ui.ui_factory.nested_progress_bar() as pb:
 
43
        for idx, combo in enumerate(combinations):
 
44
            if idx & 0x1f == 0:
 
45
                pb.update('proc', idx, len(combinations))
 
46
            h.append(g.heads(combo))
 
47
    return h
 
48
 
 
49
combinations = []
 
50
# parents = parent_map.keys()
 
51
# for p1 in parents:
 
52
#     for p2 in random.sample(parents, 10):
 
53
#         combinations.append((p1, p2))
 
54
# Times for random sampling of 10x1150 of bzrtools
 
55
#   Graph        KnownGraph
 
56
#   96.1s   vs   25.7s  :)
 
57
# Times for 500 'merge parents' from bzr.dev
 
58
#   25.6s   vs   45.0s  :(
 
59
 
 
60
for revision_id, parent_ids in parent_map.iteritems():
 
61
    if parent_ids is not None and len(parent_ids) > 1:
 
62
        combinations.append(parent_ids)
 
63
# The largest portion of the graph that has to be walked for a heads() check
 
64
# combinations = [('john@arbash-meinel.com-20090312021943-tu6tcog48aiujx4s',
 
65
#                  'john@arbash-meinel.com-20090312130552-09xa2xsitf6rilzc')]
 
66
if opts.max_combinations > 0 and len(combinations) > opts.max_combinations:
 
67
    combinations = random.sample(combinations, opts.max_combinations)
 
68
 
 
69
print('      %d combinations' % (len(combinations),))
 
70
 
 
71
def combi_graph(graph_klass, comb):
 
72
    # DEBUG
 
73
    graph._counters[1] = 0
 
74
    graph._counters[2] = 0
 
75
 
 
76
    begin = time.clock()
 
77
    g = graph_klass(parent_map)
 
78
    if opts.lsprof is not None:
 
79
        heads = commands.apply_lsprofiled(opts.lsprof, all_heads_comp, g, comb)
 
80
    else:
 
81
        heads = all_heads_comp(g, comb)
 
82
    end = time.clock()
 
83
    return dict(elapsed=(end - begin), graph=g, heads=heads)
 
84
 
 
85
def report(name, g):
 
86
    print('%s: %.3fs' % (name, g['elapsed']))
 
87
    counters_used = False
 
88
    for c in graph._counters:
 
89
        if c:
 
90
            counters_used = True
 
91
    if counters_used:
 
92
        print('  %s' % (graph._counters,))
 
93
 
 
94
known_python = combi_graph(_known_graph_py.KnownGraph, combinations)
 
95
report('Known', known_python)
 
96
 
 
97
known_pyrex = combi_graph(_known_graph_pyx.KnownGraph, combinations)
 
98
report('Known (pyx)', known_pyrex)
 
99
 
 
100
def _simple_graph(parent_map):
 
101
    return graph.Graph(graph.DictParentsProvider(parent_map))
 
102
 
 
103
if opts.quick:
 
104
    if known_python['heads'] != known_pyrex['heads']:
 
105
        import pdb; pdb.set_trace()
 
106
    print('ratio: %.1f:1 faster' % (
 
107
        known_python['elapsed'] / known_pyrex['elapsed'],))
 
108
else:
 
109
    orig = combi_graph(_simple_graph, combinations)
 
110
    report('Orig', orig)
 
111
 
 
112
    if orig['heads'] != known_pyrex['heads']:
 
113
        import pdb; pdb.set_trace()
 
114
 
 
115
    print('ratio: %.1f:1 faster' % (
 
116
        orig['elapsed'] / known_pyrex['elapsed'],))