The easiest way to experiment with self-driving AI
- Linux or Windows
- Python 3.5+ (Recommend Miniconda for Windows)
- 3GB disk space
- 8GB RAM
- CUDA capable GPU (tested and developed on 970, 1070, and 1060's)
- Tensorflow 1.1+ See Tensorflow install tips
git clone https://github.com/deepdrive/deepdrive
cd deepdrive
Optional - Activate the Python / virtualenv where your Tensorflow is installed, then
python install.py
Make sure the Python you want to use is in your PATH, then
Tip: We highly recommend using Conemu for your Windows terminal
python install.py
We've tested on Paperspace's ML-in-a-Box Linux public template which already has Tensorflow installed and just requires
python install.py
If you run into issues, try starting the sim directly as Unreal may need to install some prerequisetes (i.e. DirectX needs to be installed on the Paperspace Parsec Windows box). The default location of the Unreal sim binary is in your user directory under Deepdrive/sim.
Run the baseline agent
python main.py --baseline --experiment-name my-baseline-test
Run in-game path follower
python main.py --path-follower --experiment-name my-path-follower-test
Record training data for imitation learning / behavioral cloning
python main.py --record --record-recovery-from-random-actions
Train on recorded data
python main.py --train
Train on the same dataset we used
Grab the dataset
python main.py --train --recording-dir <the-directory-with-the-dataset>
- Esc - Pause (Quit in Unreal Editor)
- Alt+Tab - Control other windows
- P - Pause in Unreal Editor
- ; - Toggle FPS
- 1 - Chase cam
- 2 - Orbit (side) cam
- 3 - Hood cam
- 4 - Free cam (use WASD to fly)
- WASD or Up, Down, Left Right - steer / throttle
- Space - Handbrake
- Shift - Nitro
- H - Horn
- L - Light
- R - Reset
- E - Gear Up
- Q - Gear down
- Z - Show mouse
</kbd><kbd>
- Unreal console (first press releases game input capture)
Agent | 10 lap avg score | Weights | Deepdrive version |
---|---|---|---|
Baseline agent (trained with imitation learning) | 1691 | baseline_agent_weights.zip | 2.0 |
Path follower | *1069 | N/A (see 3D spline follower) | 2.0 |
*The baseline agent currently outperforms the path follower it was trained on, likely due to the slower speed the at which the baseline agent drives, resulting in lower lane deviation and g-force penalties. Interestingly, reducing the path follower speed causes it to crash at points where it otherwise loses traction and drifts, so the baseline agent has actually learned a more robust turning function than the original hardcoded path follower it was trained on.
100GB (8.2 hours of driving) of camera, depth, steering, throttle, and brake of an 'oracle' path following agent. We rotate between three different cameras: normal, wide, and semi-truck - with random camera intrisic/extrinsic perturbations at the beginning of each episode (lap). This boosted performance on the benchmark by 3x. We also use DAgger to collect course correction data as in previous versions of Deepdrive.
- Get the AWS CLI
- Ensure you have 104GB of free space
- Download our dataset of mixed Windows (Unreal PIE + Unreal packaged) and Linux + variable camera and corrective action recordings
(generated with
--record
)
cd <the-directory-you-want>
aws s3 sync s3://deepdrive/data/baseline .
If you'd like to check out our Tensorboard training session, you can download the 13GB tfevents files here, unzip, and run
tensorboard --logdir <your-unzipped-baseline_tensorflow_train_and_eval>
If you experience low frame rates on Linux, you may need to install NVIDIA’s display drivers including their OpenGL drivers. We recommend installing these with CUDA which bundles the version you will need to run the baseline agent. Also, make sure to plugin your laptop. If CUDA is installed, skip to testing OpenGL.
- Use the Tensorflow instructions on GitHub for the release you wish to install, i.e. here's the latest - which at the time of this writing is v1.5 which stores the docs here.
- Make sure to install the CUDA / cuDNN major and minor version the Tensorflow instructions specify. i.e. CUDA 9.0 / cuDNN 7.0. These will likely be older than the latest version NVIDIA offers. You can see all CUDA releases here.
- Use the packaged install, i.e. deb[local] on Ubuntu, referred to in this guide
- If you are feeling dangerous and use the runfile method, be sure to follow NVIDIA’s instructions on how to disable the Nouveau drivers if you're on Ubuntu.
glxinfo | grep OpenGL
should return something like:
OpenGL vendor string: NVIDIA Corporation
OpenGL renderer string: GeForce GTX 980/PCIe/SSE2
OpenGL core profile version string: 4.5.0 NVIDIA 384.90
OpenGL core profile shading language version string: 4.50 NVIDIA
OpenGL core profile context flags: (none)
OpenGL core profile profile mask: core profile
OpenGL core profile extensions:
OpenGL version string: 4.5.0 NVIDIA 384.90
OpenGL shading language version string: 4.50 NVIDIA
OpenGL context flags: (none)
OpenGL profile mask: (none)
OpenGL extensions:
OpenGL ES profile version string: OpenGL ES 3.2 NVIDIA 384.90
OpenGL ES profile shading language version string: OpenGL ES GLSL ES 3.20
OpenGL ES profile extensions:
You may need to disable secure boot in your BIOS in order for NVIDIA’s OpenGL and tools like nvidia-smi to work. This is not Deepdrive specific, but rather a general requirement of Ubuntu’s NVIDIA drivers.
To run tests in PyCharm, go to File | Settings | Tools | Python Integrated Tools and change the default test runner to py.test.
Special thanks to Rafał Józefowicz for contributing the original training code used for the baseline agent