~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to tools/time_graph.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2009-06-16 19:32:32 UTC
  • mfrom: (4371.3.48 1.16-better_heads)
  • Revision ID: pqm@pqm.ubuntu.com-20090616193232-rorncr6v3z633n9u
(jam) graph.KnownGraph implementation,
        used for optimized heads() lookups during annotate.

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 bzrlib import (
 
8
    branch,
 
9
    commands,
 
10
    graph,
 
11
    ui,
 
12
    trace,
 
13
    _known_graph_py,
 
14
    _known_graph_pyx,
 
15
    )
 
16
from bzrlib.ui import text
 
17
 
 
18
p = optparse.OptionParser()
 
19
p.add_option('--max-combinations', default=500, type=int)
 
20
p.add_option('--lsprof', default=None, type=str)
 
21
opts, args = p.parse_args(sys.argv[1:])
 
22
trace.enable_default_logging()
 
23
ui.ui_factory = text.TextUIFactory()
 
24
 
 
25
if len(args) >= 1:
 
26
    b = branch.Branch.open(args[0])
 
27
else:
 
28
    b = branch.Branch.open('.')
 
29
b.lock_read()
 
30
try:
 
31
    g = b.repository.get_graph()
 
32
    parent_map = dict(p for p in g.iter_ancestry([b.last_revision()])
 
33
                         if p[1] is not None)
 
34
finally:
 
35
    b.unlock()
 
36
 
 
37
print 'Found %d nodes' % (len(parent_map),)
 
38
 
 
39
def all_heads_comp(g, combinations):
 
40
    h = []
 
41
    pb = ui.ui_factory.nested_progress_bar()
 
42
    try:
 
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
    finally:
 
48
        pb.finished()
 
49
    return h
 
50
combinations = []
 
51
# parents = parent_map.keys()
 
52
# for p1 in parents:
 
53
#     for p2 in random.sample(parents, 10):
 
54
#         combinations.append((p1, p2))
 
55
# Times for random sampling of 10x1150 of bzrtools
 
56
#   Graph        KnownGraph
 
57
#   96.1s   vs   25.7s  :)
 
58
# Times for 500 'merge parents' from bzr.dev
 
59
#   25.6s   vs   45.0s  :(
 
60
 
 
61
for revision_id, parent_ids in parent_map.iteritems():
 
62
    if parent_ids is not None and len(parent_ids) > 1:
 
63
        combinations.append(parent_ids)
 
64
if opts.max_combinations > 0 and len(combinations) > opts.max_combinations:
 
65
    combinations = random.sample(combinations, opts.max_combinations)
 
66
 
 
67
print '      %d combinations' % (len(combinations),)
 
68
t1 = time.clock()
 
69
known_g = _known_graph_py.KnownGraph(parent_map)
 
70
if opts.lsprof is not None:
 
71
    h_known = commands.apply_lsprofiled(opts.lsprof,
 
72
        all_heads_comp, known_g, combinations)
 
73
else:
 
74
    h_known = all_heads_comp(known_g, combinations)
 
75
t2 = time.clock()
 
76
print "Known: %.3fs" % (t2-t1,)
 
77
print "  %s" % (graph._counters,)
 
78
t1 = time.clock()
 
79
known_g = _known_graph_pyx.KnownGraph(parent_map)
 
80
if opts.lsprof is not None:
 
81
    h_known = commands.apply_lsprofiled(opts.lsprof,
 
82
        all_heads_comp, known_g, combinations)
 
83
else:
 
84
    h_known = all_heads_comp(known_g, combinations)
 
85
t2 = time.clock()
 
86
print "Known (pyx): %.3fs" % (t2-t1,)
 
87
print "  %s" % (graph._counters,)
 
88
simple_g = graph.Graph(graph.DictParentsProvider(parent_map))
 
89
graph._counters[1] = 0
 
90
graph._counters[2] = 0
 
91
h_simple = all_heads_comp(simple_g, combinations)
 
92
t3 = time.clock()
 
93
print "Orig: %.3fs" % (t3-t2,)
 
94
print "  %s" % (graph._counters,)
 
95
if h_simple != h_known:
 
96
    import pdb; pdb.set_trace()
 
97
print 'ratio: %.3fs' % ((t2-t1) / (t3-t2))