|  | 3 months ago | |
|---|---|---|
| .. | ||
| lib | 3 months ago | |
| tests | 11 months ago | |
| .gitignore | 3 years ago | |
| README.md | 6 months ago | |
| SConscript | 11 months ago | |
| __init__.py | 6 years ago | |
| api.cc | 11 months ago | |
| api.h | 11 months ago | |
| camera.cc | 1 year ago | |
| camera.h | 1 year ago | |
| can_replay.py | 8 months ago | |
| consoleui.cc | 11 months ago | |
| consoleui.h | 6 months ago | |
| filereader.cc | 2 years ago | |
| filereader.h | 3 years ago | |
| framereader.cc | 3 months ago | |
| framereader.h | 3 months ago | |
| logreader.cc | 1 year ago | |
| logreader.h | 1 year ago | |
| main.cc | 6 months ago | |
| replay.cc | 6 months ago | |
| replay.h | 6 months ago | |
| route.cc | 6 months ago | |
| route.h | 6 months ago | |
| rp_visualization.py | 1 year ago | |
| seg_mgr.cc | 9 months ago | |
| seg_mgr.h | 6 months ago | |
| timeline.cc | 10 months ago | |
| timeline.h | 10 months ago | |
| ui.py | 8 months ago | |
| unlog_ci_segment.py | 3 months ago | |
| util.cc | 11 months ago | |
| util.h | 11 months ago | |
		
			
				
				README.md
			
		
		
			
			
		
	
	Replay
replay allows you to simulate a driving session by replaying all messages logged during the use of openpilot. This provides a way to analyze and visualize system behavior as if it were live.
Setup
Before starting a replay, you need to authenticate with your comma account using auth.py. This will allow you to access your routes from the server.
# Authenticate to access routes from your comma account:
python3 tools/lib/auth.py
Replay a Remote Route
You can replay a route from your comma account by specifying the route name.
# Start a replay with a specific route:
tools/replay/replay <route-name>
# Example:
tools/replay/replay 'a2a0ccea32023010|2023-07-27--13-01-19'
# Replay the default demo route:
tools/replay/replay --demo
Replay a Local Route
To replay a route stored locally on your machine, specify the route name and provide the path to the directory where the route files are stored.
# Replay a local route
tools/replay/replay <route-name> --data_dir="/path_to/route"
# Example:
# If you have a local route stored at /path_to_routes with segments like:
# a2a0ccea32023010|2023-07-27--13-01-19--0
# a2a0ccea32023010|2023-07-27--13-01-19--1
# You can replay it like this:
tools/replay/replay "a2a0ccea32023010|2023-07-27--13-01-19" --data_dir="/path_to_routes"
Send Messages via ZMQ
By default, replay sends messages via MSGQ. To switch to ZMQ, set the ZMQ environment variable.
# Start replay and send messages via ZMQ:
ZMQ=1 tools/replay/replay <route-name>
Usage
For more information on available options and arguments, use the help command:
$ tools/replay/replay -h
Usage: tools/replay/replay [options] route
Mock openpilot components by publishing logged messages.
Options:
  -h, --help             Displays this help.
  -a, --allow <allow>    whitelist of services to send (comma-separated)
  -b, --block <block>    blacklist of services to send (comma-separated)
  -c, --cache <n>        cache <n> segments in memory. default is 5
  -s, --start <seconds>  start from <seconds>
  -x <speed>             playback <speed>. between 0.2 - 3
  --demo                 use a demo route instead of providing your own
  --auto                 Auto load the route from the best available source (no video):
                         internal, openpilotci, comma_api, car_segments, testing_closet
  --data_dir <data_dir>  local directory with routes
  --prefix <prefix>      set OPENPILOT_PREFIX
  --dcam                 load driver camera
  --ecam                 load wide road camera
  --no-loop              stop at the end of the route
  --no-cache             turn off local cache
  --qcam                 load qcamera
  --no-hw-decoder        disable HW video decoding
  --no-vipc              do not output video
  --all                  do output all messages including uiDebug, userFlag.
                         this may causes issues when used along with UI
Arguments:
  route                  the drive to replay. find your drives at
                         connect.comma.ai
Visualize the Replay in the openpilot UI
To visualize the replay within the openpilot UI, run the following commands:
tools/replay/replay <route-name>
cd selfdrive/ui && ./ui
Try Radar Point Visualization with Rerun
To visualize radar points, run rp_visualization.py while tools/replay/replay is active.
tools/replay/replay <route-name>
python3 replay/rp_visualization.py
Work with plotjuggler
If you want to use replay with plotjuggler, you can stream messages by running:
tools/replay/replay <route-name>
tools/plotjuggler/juggle.py --stream
watch3
watch all three cameras simultaneously from your comma three routes with watch3
simply replay a route using the --dcam and --ecam flags:
# start a replay
cd tools/replay && ./replay --demo --dcam --ecam
# then start watch3
cd selfdrive/ui && ./watch3
Stream CAN messages to your device
Replay CAN messages as they were recorded using a panda jungle. The jungle has 6x OBD-C ports for connecting all your comma devices. Check out the jungle repo for more info.
In order to run your device as if it was in a car:
- connect a panda jungle to your PC
- connect a comma device or panda to the jungle via OBD-C
- run can_replay.py
batman:replay$ ./can_replay.py -h
usage: can_replay.py [-h] [route_or_segment_name]
Replay CAN messages from a route to all connected pandas and jungles
in a loop.
positional arguments:
  route_or_segment_name
                        The route or segment name to replay. If not
                        specified, a default public route will be
                        used. (default: None)
optional arguments:
  -h, --help            show this help message and exit
