openpilot is an open source driver assistance system. openpilot performs the functions of Automated Lane Centering and Adaptive Cruise Control for over 200 supported car makes and models.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Willem Melching 194e5fdf1c
make normal logreader more robust (#24577)
3 years ago
..
tests Tools: allow using plotjuggler on local data (#24473) 3 years ago
vidindex Add pre-commit hooks (#1629) 5 years ago
README.md tools: add MultiLogIterator example to readme (#23917) 4 years ago
__init__.py merge in tools 6 years ago
api.py tools: make auth optional for public routes (#22386) 4 years ago
auth.py Mypy fixes for --check-untyped-defs (#24372) 4 years ago
auth_config.py tools: make auth optional for public routes (#22386) 4 years ago
bootlog.py add mypy check for return-any (#24379) 4 years ago
cache.py Less open file permissions (#21922) 4 years ago
exceptions.py merge in tools 6 years ago
filereader.py filereader better name for cd:/ replacement 4 years ago
framereader.py Ignore BrokenPipeError 4 years ago
helpers.py tools: add bootlog helpers (#23504) 4 years ago
kbhit.py mypy: enable --warn-unused-ignores (#24287) 4 years ago
logreader.py make normal logreader more robust (#24577) 3 years ago
route.py Tools: allow using plotjuggler on local data (#24473) 3 years ago
url_file.py URLFile: raise exception if remote URL doesn't exist when using cache (#24432) 4 years ago

README.md

LogReader

Route is a class for conviently accessing all the logs from your routes. The LogReader class reads the non-video logs, i.e. rlog.bz2 and qlog.bz2. There's also a matching FrameReader class for reading the videos.

from tools.lib.route import Route
from tools.lib.logreader import LogReader

r = Route("4cf7a6ad03080c90|2021-09-29--13-46-36")

# get a list of paths for the route's rlog files
print(r.log_paths())

# and road camera (fcamera.hevc) files
print(r.camera_paths())

# setup a LogReader to read the route's first rlog
lr = LogReader(r.log_paths()[0])

# print out all the messages in the log
import codecs
codecs.register_error("strict", codecs.backslashreplace_errors)
for msg in lr:
  print(msg)

# setup a LogReader for the route's second qlog
lr = LogReader(r.log_paths()[1])

# print all the steering angles values from the log
for msg in lr:
  if msg.which() == "carState":
    print(msg.carState.steeringAngleDeg)

MultiLogIterator

MultiLogIterator is similar to LogReader, but reads multiple logs.

from tools.lib.route import Route
from tools.lib.logreader import MultiLogIterator

# setup a MultiLogIterator to read all the logs in the route
r = Route("4cf7a6ad03080c90|2021-09-29--13-46-36")
lr = MultiLogIterator(r.log_paths())

# print all the steering angles values from all the logs in the route
for msg in lr:
  if msg.which() == "carState":
    print(msg.carState.steeringAngleDeg)