more accurate profiling (#2287)

pull/2315/head
Adeeb Shihadeh 5 years ago committed by GitHub
parent 4953fb8668
commit d5796e07e2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 41
      selfdrive/test/profiling/lib.py

@ -29,18 +29,12 @@ class SubSocket():
class PubSocket(): class PubSocket():
def send(self, data): def send(self, data):
if not isinstance(data, bytes): pass
data = data.to_bytes()
class SubMaster(messaging.SubMaster): class SubMaster(messaging.SubMaster):
def __init__(self, msgs, trigger, services): # pylint: disable=super-init-not-called def __init__(self, msgs, trigger, services): # pylint: disable=super-init-not-called
msgs = [m for m in msgs if m.which() in services]
self.max_i = len(msgs) - 1
self.i = 0
self.frame = 0 self.frame = 0
self.trigger = trigger
self.msgs = msgs
self.data = {} self.data = {}
self.ignore_alive = [] self.ignore_alive = []
@ -52,6 +46,16 @@ class SubMaster(messaging.SubMaster):
self.logMonoTime = {} self.logMonoTime = {}
self.sock = {} self.sock = {}
# TODO: specify multiple triggers for service like plannerd that poll on more than one service
cur_msgs = []
self.msgs = []
msgs = [m for m in msgs if m.which() in services]
for msg in msgs:
cur_msgs.append(msg)
if msg.which() == trigger:
self.msgs.append(cur_msgs)
cur_msgs = []
for s in services: for s in services:
try: try:
data = messaging.new_message(s) data = messaging.new_message(s)
@ -64,28 +68,11 @@ class SubMaster(messaging.SubMaster):
self.sock[s] = SubSocket(msgs, s) self.sock[s] = SubSocket(msgs, s)
def update(self, timeout=None): def update(self, timeout=None):
if self.i == self.max_i: if not len(self.msgs):
raise ReplayDone raise ReplayDone
self.updated = dict.fromkeys(self.updated, False) cur_msgs = self.msgs.pop()
self.frame += 1 self.update_msgs(cur_msgs[0].logMonoTime, self.msgs.pop())
while True:
msg = self.msgs[self.i]
w = msg.which()
self.updated[w] = True
self.rcv_time[w] = msg.logMonoTime / 1e9
self.rcv_frame[w] = self.frame
self.data[w] = getattr(msg, w)
self.logMonoTime[w] = msg.logMonoTime
self.i += 1
if self.i == self.max_i:
raise ReplayDone
if w == self.trigger:
break
class PubMaster(messaging.PubMaster): class PubMaster(messaging.PubMaster):

Loading…
Cancel
Save