small vipsprofile cleanups
This commit is contained in:
parent
7f63ecdeb6
commit
d263c4d9c4
@ -47,10 +47,10 @@ class Thread:
|
|||||||
|
|
||||||
self.thread_name = thread_name
|
self.thread_name = thread_name
|
||||||
self.thread_number = Thread.thread_number
|
self.thread_number = Thread.thread_number
|
||||||
self.events = []
|
self.all_events = []
|
||||||
self.workwait = []
|
self.workwait_events = []
|
||||||
self.memory = []
|
self.memory_events = []
|
||||||
self.other = []
|
self.other_events = []
|
||||||
Thread.thread_number += 1
|
Thread.thread_number += 1
|
||||||
|
|
||||||
all_events = []
|
all_events = []
|
||||||
@ -79,14 +79,14 @@ class Event:
|
|||||||
self.start = start
|
self.start = start
|
||||||
self.stop = stop
|
self.stop = stop
|
||||||
|
|
||||||
thread.events.append(self)
|
thread.all_events.append(self)
|
||||||
all_events.append(self)
|
all_events.append(self)
|
||||||
if self.wait or self.work:
|
if self.wait or self.work:
|
||||||
thread.workwait.append(self)
|
thread.workwait_events.append(self)
|
||||||
elif self.memory:
|
elif self.memory:
|
||||||
thread.memory.append(self)
|
thread.memory_events.append(self)
|
||||||
else:
|
else:
|
||||||
thread.other.append(self)
|
thread.other_events.append(self)
|
||||||
|
|
||||||
input_filename = 'vips-profile.txt'
|
input_filename = 'vips-profile.txt'
|
||||||
|
|
||||||
@ -142,10 +142,10 @@ with ReadFile(input_filename) as rf:
|
|||||||
n_events += 1
|
n_events += 1
|
||||||
|
|
||||||
for thread in threads:
|
for thread in threads:
|
||||||
thread.events.sort(lambda x, y: cmp(x.start, y.start))
|
thread.all_events.sort(lambda x, y: cmp(x.start, y.start))
|
||||||
thread.workwait.sort(lambda x, y: cmp(x.start, y.start))
|
thread.workwait_events.sort(lambda x, y: cmp(x.start, y.start))
|
||||||
thread.memory.sort(lambda x, y: cmp(x.start, y.start))
|
thread.memory_events.sort(lambda x, y: cmp(x.start, y.start))
|
||||||
thread.other.sort(lambda x, y: cmp(x.start, y.start))
|
thread.other_events.sort(lambda x, y: cmp(x.start, y.start))
|
||||||
|
|
||||||
all_events.sort(lambda x, y: cmp(x.start, y.start))
|
all_events.sort(lambda x, y: cmp(x.start, y.start))
|
||||||
|
|
||||||
@ -168,7 +168,7 @@ for event in all_events:
|
|||||||
last_time = (last_time - first_time) / ticks_per_sec
|
last_time = (last_time - first_time) / ticks_per_sec
|
||||||
first_time = 0
|
first_time = 0
|
||||||
|
|
||||||
print 'last time =', last_time
|
print 'total time =', last_time
|
||||||
|
|
||||||
# calculate some simple stats
|
# calculate some simple stats
|
||||||
for thread in threads:
|
for thread in threads:
|
||||||
@ -178,7 +178,7 @@ for thread in threads:
|
|||||||
thread.work = 0
|
thread.work = 0
|
||||||
thread.mem = 0
|
thread.mem = 0
|
||||||
thread.peak_mem = 0
|
thread.peak_mem = 0
|
||||||
for event in thread.events:
|
for event in thread.all_events:
|
||||||
if event.start < thread.start:
|
if event.start < thread.start:
|
||||||
thread.start = event.start
|
thread.start = event.start
|
||||||
if event.stop > thread.stop:
|
if event.stop > thread.stop:
|
||||||
@ -227,12 +227,13 @@ if mem != 0:
|
|||||||
# assume the list of events has been sorted by start time
|
# assume the list of events has been sorted by start time
|
||||||
def events_overlap(events):
|
def events_overlap(events):
|
||||||
for i in range(0, len(events) - 1):
|
for i in range(0, len(events) - 1):
|
||||||
# a length 0 event can't overlap with anything
|
# we can't just test for stop1 > start2 since one (or both) events
|
||||||
if events[i].stop - events[i].start == 0:
|
# might have duration zero
|
||||||
continue
|
event1 = events[i]
|
||||||
if events[i + 1].stop - events[i + 1].start == 0:
|
event2 = events[i + 1]
|
||||||
continue
|
overlap_start = max(event1.start, event2.start)
|
||||||
if events[i].stop > events[i + 1].start:
|
overlap_stop = min(event1.stop, event2.stop)
|
||||||
|
if overlap_stop - overlap_start > 0:
|
||||||
return True
|
return True
|
||||||
|
|
||||||
return False
|
return False
|
||||||
@ -260,31 +261,33 @@ for thread in threads:
|
|||||||
gate_positions = {}
|
gate_positions = {}
|
||||||
|
|
||||||
# first pass .. move work and wait events to y == 0
|
# first pass .. move work and wait events to y == 0
|
||||||
if events_overlap(thread.workwait):
|
if events_overlap(thread.workwait_events):
|
||||||
print 'gate overlap on thread', thread.thread_name
|
print 'gate overlap on thread', thread.thread_name
|
||||||
for i in range(0, len(thread.workwait) - 1):
|
for i in range(0, len(thread.workwait_events) - 1):
|
||||||
event1 = thread.workwait[i]
|
event1 = thread.workwait_events[i]
|
||||||
event2 = thread.workwait[i + 1]
|
event2 = thread.workwait_events[i + 1]
|
||||||
if event1.stop > event2.start:
|
overlap_start = max(event1.start, event2.start)
|
||||||
|
overlap_stop = min(event1.stop, event2.stop)
|
||||||
|
if overlap_stop - overlap_start > 0:
|
||||||
print 'overlap:'
|
print 'overlap:'
|
||||||
print 'event', event1.gate_location, event1.gate_name,
|
print 'event', event1.gate_location, event1.gate_name,
|
||||||
print 'starts at', event1.start, 'stops at', event1.stop
|
print 'starts at', event1.start, 'stops at', event1.stop
|
||||||
print 'event', event2.gate_location, event2.gate_name,
|
print 'event', event2.gate_location, event2.gate_name,
|
||||||
print 'starts at', event2.start, 'stops at', event2.stop
|
print 'starts at', event2.start, 'stops at', event2.stop
|
||||||
|
|
||||||
for event in thread.workwait:
|
for event in thread.workwait_events:
|
||||||
gate_positions[event.gate_name] = 0
|
gate_positions[event.gate_name] = 0
|
||||||
event.y = 0
|
event.y = 0
|
||||||
event.total_y = total_y
|
event.total_y = total_y
|
||||||
|
|
||||||
for event in thread.memory:
|
for event in thread.memory_events:
|
||||||
gate_positions[event.gate_name] = 0
|
gate_positions[event.gate_name] = 0
|
||||||
event.y = 0
|
event.y = 0
|
||||||
event.total_y = total_y
|
event.total_y = total_y
|
||||||
|
|
||||||
# second pass: move all other events to non-overlapping ys
|
# second pass: move all other events to non-overlapping ys
|
||||||
y = 1
|
y = 1
|
||||||
for event in thread.other:
|
for event in thread.other_events:
|
||||||
if not event.gate_name in gate_positions:
|
if not event.gate_name in gate_positions:
|
||||||
# look at all the ys we've allocated previously and see if we can
|
# look at all the ys we've allocated previously and see if we can
|
||||||
# add this gate to one of them
|
# add this gate to one of them
|
||||||
@ -294,7 +297,7 @@ for thread in threads:
|
|||||||
if gate_positions[gate_name] != gate_y:
|
if gate_positions[gate_name] != gate_y:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
if gates_overlap(thread.other, event.gate_name, gate_name):
|
if gates_overlap(thread.other_events, event.gate_name, gate_name):
|
||||||
found_overlap = True
|
found_overlap = True
|
||||||
break
|
break
|
||||||
|
|
||||||
@ -311,7 +314,7 @@ for thread in threads:
|
|||||||
|
|
||||||
# third pass: flip the order of the ys to get the lowest-level ones at the
|
# third pass: flip the order of the ys to get the lowest-level ones at the
|
||||||
# top, next to the wait/work line
|
# top, next to the wait/work line
|
||||||
for event in thread.other:
|
for event in thread.other_events:
|
||||||
event.y = y - event.y
|
event.y = y - event.y
|
||||||
event.total_y = total_y + event.y
|
event.total_y = total_y + event.y
|
||||||
|
|
||||||
@ -383,7 +386,7 @@ for thread in threads:
|
|||||||
ctx.set_source_rgb(1.00, 1.00, 1.00)
|
ctx.set_source_rgb(1.00, 1.00, 1.00)
|
||||||
ctx.show_text(thread.thread_name)
|
ctx.show_text(thread.thread_name)
|
||||||
|
|
||||||
for event in thread.events:
|
for event in thread.all_events:
|
||||||
draw_event(ctx, event)
|
draw_event(ctx, event)
|
||||||
|
|
||||||
memory_y = total_y * PIXELS_PER_GATE
|
memory_y = total_y * PIXELS_PER_GATE
|
||||||
|
Loading…
Reference in New Issue
Block a user