fix overlap detection

This commit is contained in:
John Cupitt 2013-11-28 10:45:31 +00:00
parent 260cbde58d
commit a83b44b7a4

View File

@ -79,7 +79,6 @@ with ReadFile(input_filename) as rf:
match = re.match('thread: (.*)', rf.line) match = re.match('thread: (.*)', rf.line)
if not match: if not match:
print 'parse error line %d, expected "thread"' % rf.lineno print 'parse error line %d, expected "thread"' % rf.lineno
print rf.line
thread_name = match.group(1) + " " + str(thread_id) thread_name = match.group(1) + " " + str(thread_id)
thread_id += 1 thread_id += 1
thread = Thread(thread_name) thread = Thread(thread_name)
@ -134,7 +133,7 @@ for thread in threads:
print 'last time =', last_time print 'last time =', last_time
# calculate some simple stats # calculate some simple stats
print 'name\t\t\t\talive\twait%\twork%\tunk%' print 'name\t\t\t\talive\twait%\twork%\tunknown%'
for thread in threads: for thread in threads:
start = last_time start = last_time
stop = 0 stop = 0
@ -153,7 +152,7 @@ for thread in threads:
alive = stop - start alive = stop - start
wait_percent = 100 * wait / alive wait_percent = 100 * wait / alive
work_percent = 100 * work / alive work_percent = 100 * work / alive
unkn_percent = 100 - (wait_percent + work_percent) unkn_percent = 100 - 100 * (work + wait) / alive
print '%30s\t%6.2g\t%.3g\t%.3g\t%.3g' % (thread.thread_name, alive, wait_percent, work_percent, unkn_percent) print '%30s\t%6.2g\t%.3g\t%.3g\t%.3g' % (thread.thread_name, alive, wait_percent, work_percent, unkn_percent)
# do two gates overlap? # do two gates overlap?
@ -204,18 +203,36 @@ for thread in threads:
continue continue
if not event.gate_name in gate_positions: if not event.gate_name in gate_positions:
no_overlap = False # look at all the ys we've allocated previously and see if we can
# add this gate to one of them
for gate_y in range(1, y):
found_overlap = False
for gate_name in gate_positions: for gate_name in gate_positions:
if not is_overlap(thread.events, gate_name, event.gate_name): if gate_positions[gate_name] != gate_y:
gate_positions[event.gate_name] = gate_positions[gate_name] continue
no_overlap = True
if is_overlap(thread.events, event.gate_name, gate_name):
found_overlap = True
break break
if not no_overlap: if not found_overlap:
gate_positions[event.gate_name] = gate_y
break
# failure? add a new y
if not event.gate_name in gate_positions:
gate_positions[event.gate_name] = y gate_positions[event.gate_name] = y
y += 1 y += 1
event.y = gate_positions[event.gate_name] event.y = gate_positions[event.gate_name]
# third pass: flip the order of the ys to get the lowest-level ones at the
# top, next to the wait/work line
for event in thread.events:
if event.work or event.wait:
continue
event.y = y - event.y
event.total_y = total_y + event.y event.total_y = total_y + event.y
total_y += y total_y += y