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.
		
		
		
		
		
			|  | 6 months ago | |
|---|---|---|
| .. | ||
| tests | 1 year ago | |
| README.md | 2 years ago | |
| __init__.py | 6 years ago | |
| api.py | 11 months ago | |
| auth.py | 2 years ago | |
| auth_config.py | 2 years ago | |
| azure_container.py | 1 year ago | |
| bootlog.py | 2 years ago | |
| cache.py | 2 years ago | |
| comma_car_segments.py | 1 year ago | |
| exceptions.py | 6 years ago | |
| filereader.py | 10 months ago | |
| framereader.py | 11 months ago | |
| github_utils.py | 1 year ago | |
| helpers.py | 1 year ago | |
| kbhit.py | 1 year ago | |
| live_logreader.py | 1 year ago | |
| log_time_series.py | 8 months ago | |
| logreader.py | 7 months ago | |
| openpilotci.py | 2 years ago | |
| openpilotcontainers.py | 2 years ago | |
| route.py | 6 months ago | |
| sanitizer.py | 2 years ago | |
| url_file.py | 7 months ago | |
| vidindex.py | 2 years ago | |
		
			
				
				README.md
			
		
		
			
			
		
	
	LogReader
Route is a class for conveniently 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 openpilot.tools.lib.route import Route
from openpilot.tools.lib.logreader import LogReader
r = Route("a2a0ccea32023010|2023-07-27--13-01-19")
# 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)
Segment Ranges
We also support a new format called a "segment range":
344c5c15b34f2d8a   /   2024-01-03--09-37-12   /     2:6    /       q
[   dongle id     ] [       timestamp        ] [ selector ]  [ query type]
you can specify which segments from a route to load
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/4")   # 4th segment
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/4:6") # 4th and 5th segment
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/-1")  # last segment
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/:5")  # first 5 segments
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/1:")  # all except first segment
and can select which type of logs to grab
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/4/q") # get qlogs
lr = LogReader("a2a0ccea32023010|2023-07-27--13-01-19/4/r") # get rlogs (default)