openpilot tools
============
tools to facilitate development and debugging of openpilot

Table of Contents
============
<!-- ts -->
* [Requirements ](#requirements )
* [Setup ](#setup )
* [Tool examples ](#tool-examples )
* [Replay driving data ](#replay-driving-data )
* [Debug car controls ](#debug-car-controls )
* [Stream replayed CAN messages to EON ](#stream-replayed-can-messages-to-eon )
* [Welcomed contributions ](#welcomed-contributions )
<!-- te -->
Requirements
============
openpilot tools and the following setup steps are developed and tested on Ubuntu 20.04, MacOS 10.14.2 and, Python 3.8.2.
Setup
============
1. Run `ubuntu_setup.sh` or `mac_setup.sh` , and make sure that everything completed correctly
2. Compile openpilot by running ```scons``` in the openpilot directory
or alternatively run ```./openpilot_build.sh``` (uses a pre-configured docker container)
3. Try out some tools!
Tool examples
============
Replay driving data
-------------
**Hardware needed**: none
`unlogger.py` replays data collected with [dashcam ](https://github.com/commaai/openpilot/tree/dashcam ) or [openpilot ](https://github.com/commaai/openpilot ).
Unlogger with remote data:
```
# Log in via browser
python lib/auth.py
# Start unlogger
python replay/unlogger.py < route-name >
#Example:
#python replay/unlogger.py '3533c53bb29502d1|2019-12-10--01-13-27'
# In another terminal you can run a debug visualizer:
python replay/ui.py # Define the environmental variable HORIZONTAL is the ui layout is too tall
```
Unlogger with local data downloaded from device or https://my.comma.ai:
```
python replay/unlogger.py < route-name > < path-to-data-directory >
#Example:
#python replay/unlogger.py '99c94dc769b5d96e|2018-11-14--13-31-42' /home/batman/unlogger_data
#Within /home/batman/unlogger_data:
# 99c94dc769b5d96e|2018-11-14--13-31-42--0--fcamera.hevc
# 99c94dc769b5d96e|2018-11-14--13-31-42--0--rlog.bz2
# ...
```

LogReader with remote data
```python
from tools.lib.logreader import LogReader
from tools.lib.route import Route
route = Route('3533c53bb29502d1|2019-12-10--01-13-27')
log_paths = route.log_paths()
events_seg0 = list(LogReader(log_paths[0]))
print(len(events_seg0), 'events logged in first segment')
```
Debug car controls
-------------
**Hardware needed**: [panda ](panda.comma.ai ), [giraffe ](https://comma.ai/shop/products/giraffe/ ), joystick
Use the panda's OBD-II port to connect with your car and a usb cable to connect the panda to your pc.
Also, connect a joystick to your pc.
`joystickd.py` runs a deamon that reads inputs from a joystick and publishes them over zmq.
`boardd` sends the CAN messages from your pc to the panda.
`debug_controls` is a mocked version of `controlsd.py` and uses input from a joystick to send controls to your car.
Make sure the conditions are met in the panda to allow controls (e.g. cruise control engaged). You can also make a modification to the panda code to always allow controls.
Usage:
```
python carcontrols/joystickd.py
# In another terminal:
BASEDIR=$(pwd) selfdrive/boardd/boardd
# In another terminal:
python carcontrols/debug_controls.py
```

Stream replayed CAN messages to EON
-------------
**Hardware needed**: 2 x [panda ](panda.comma.ai ), [debug board ](https://comma.ai/shop/products/panda-debug-board/ ), [EON ](https://comma.ai/shop/products/eon-gold-dashcam-devkit/ ).
It is possible to replay CAN messages as they were recorded and forward them to a EON.
Connect 2 pandas to the debug board. A panda connects to the PC, the other panda connects to the EON.
Usage:
```
# With MOCK=1 boardd will read logged can messages from a replay and send them to the panda.
MOCK=1 selfdrive/boardd/tests/boardd_old.py
# In another terminal:
python replay/unlogger.py < route-name > < path-to-data-directory >
```

Welcomed contributions
=============
* Documentation: code comments, better tutorials, etc..
* Support for other platforms other than Ubuntu 20.04.
* Performance improvements: the tools have been developed on high-performance workstations (12+ logical cores with 32+ GB of RAM), so they are not optimized for running efficiently. For example, `ui.py` might not be able to run real-time on most PCs.
* More tools: anything that you think might be helpful to others.