open source driving agent
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.
 
 
 
 
 
 
Justin Newberry 7fdd9fc37c
CI: Pylint to ruff (#29294)
2 years ago
..
lib radard: no clustering (#29010) 2 years ago
tests replay: new demo route (#29215) 2 years ago
.gitignore move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago
README.md replay: new demo route (#29215) 2 years ago
SConscript build extras together (#26051) 3 years ago
__init__.py merge in tools 6 years ago
camera.cc replay: sync vision buffer (#26904) 3 years ago
camera.h move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago
can_replay.py CI: Pylint to ruff (#29294) 2 years ago
consoleui.cc cabana: improve timeline (#28801) 2 years ago
consoleui.h move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago
filereader.cc move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago
filereader.h move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago
framereader.cc replay framereader: Log in some unlikely failure paths (#27942) 3 years ago
framereader.h framereader.cc: remove nv12toyuv_buffer (#24991) 3 years ago
logreader.cc replay: fix segfault caused by pointer usage after freeing (#28779) 2 years ago
logreader.h canbana: complete basic functions (#25965) 3 years ago
main.cc replay: lock uiDebug and userFlag messages behind all flag (#28349) 2 years ago
replay.cc replay: emit segmentsMerged before updateEvent (#28849) 2 years ago
replay.h replay: new demo route (#29215) 2 years ago
route.cc replay: remove need for fake dongle id (#26899) 3 years ago
route.h replay: show absolute time (#26869) 3 years ago
ui.py Added python VisionBuf class (#29075) 2 years ago
unlog_ci_segment.py Mypy fixes for --check-untyped-defs (#24372) 4 years ago
util.cc move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago
util.h move replay from selfdrive/ui/replay to tools/replay (#24971) 3 years ago

README.md

Replay

Replay driving data

replay replays all the messages logged while running openpilot.

# Log in via browser to have access to routes from your comma account
python tools/lib/auth.py

# Start a replay
tools/replay/replay <route-name>

# Example:
tools/replay/replay 'a2a0ccea32023010|2023-07-27--13-01-19'
# or use --demo to replay the default demo route:
tools/replay/replay --demo

# watch the replay with the normal openpilot UI
cd selfdrive/ui && ./ui

# or try out a debug visualizer:
python replay/ui.py

usage

$ 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
  -b, --block <block>    blacklist of services to send
  -s, --start <seconds>  start from <seconds>
  --demo                 use a demo route instead of providing your own
  --dcam                 load driver camera
  --ecam                 load wide road camera

Arguments:
  route                  the drive to replay. find your drives at
                         connect.comma.ai

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