carla/README.md

154 lines
8.0 KiB
Markdown
Raw Normal View History

CARLA Simulator
===============
2017-03-30 01:05:26 +08:00
2018-02-08 03:14:59 +08:00
[![Documentation](https://readthedocs.org/projects/carla/badge/?version=latest)](http://carla.readthedocs.io)
2018-12-12 09:54:31 +08:00
2018-05-14 21:34:32 +08:00
[![carla.org](Docs/img/btn/web.png)](http://carla.org)
2018-07-30 20:10:23 +08:00
[![download](Docs/img/btn/download.png)](https://github.com/carla-simulator/carla/blob/master/Docs/download.md)
2018-05-14 21:34:32 +08:00
[![documentation](Docs/img/btn/docs.png)](http://carla.readthedocs.io)
[![forum](Docs/img/btn/forum.png)](https://github.com/carla-simulator/carla/discussions)
[![discord](Docs/img/btn/chat.png)](https://discord.gg/8kqACuC)
2018-05-14 21:34:32 +08:00
2020-06-12 16:16:35 +08:00
CARLA is an open-source simulator for autonomous driving research. CARLA has been developed from the ground up to support development, training, and
validation of autonomous driving systems. In addition to open-source code and protocols, CARLA provides open digital assets (urban layouts, buildings,
vehicles) that were created for this purpose and can be used freely. The simulation platform supports flexible specification of sensor suites and
2017-11-11 00:54:06 +08:00
environmental conditions.
2017-10-31 00:56:39 +08:00
2020-09-30 15:58:15 +08:00
[![CARLA Video](Docs/img/video_thumbnail_0910.jpg)](https://www.youtube.com/watch?v=7jej46ALVRE)
2017-10-31 00:56:39 +08:00
2018-01-23 20:03:15 +08:00
If you want to benchmark your model in the same conditions as in our CoRL17
paper, check out
2018-12-13 23:39:27 +08:00
[Benchmarking](https://github.com/carla-simulator/driving-benchmarks).
2017-10-31 00:56:39 +08:00
2023-04-14 14:41:52 +08:00
Linux:
2020-08-01 09:34:43 +08:00
* [**Get CARLA overnight build**](http://carla-releases.s3.amazonaws.com/Linux/Dev/CARLA_Latest.tar.gz)
2023-04-14 14:41:52 +08:00
* [**Get AdditionalMaps overnight build**](http://carla-releases.s3.amazonaws.com/Linux/Dev/AdditionalMaps_Latest.tar.gz)
Windows:
* [**Get CARLA overnight build**](http://carla-releases.s3.amazonaws.com/Windows/Dev/CARLA_Latest.zip)
* [**Get AdditionalMaps overnight build**](http://carla-releases.s3.amazonaws.com/Windows/Dev/AdditionalMaps_Latest.zip)
2018-12-12 09:54:31 +08:00
### Recommended system
* Intel i7 gen 9th - 11th / Intel i9 gen 9th - 11th / AMD ryzen 7 / AMD ryzen 9
* +16 GB RAM memory
2023-11-16 21:47:08 +08:00
* NVIDIA RTX 2070 / NVIDIA RTX 2080 / NVIDIA RTX 3070, NVIDIA RTX 3080 / NVIDIA RTX 4090
* Ubuntu 20.04
2018-12-12 09:54:31 +08:00
## CARLA Ecosystem
Repositories associated to the CARLA simulation platform:
* [**CARLA Autonomous Driving leaderboard**](https://leaderboard.carla.org/): Automatic platform to validate Autonomous Driving stacks
2018-12-12 09:54:31 +08:00
* [**Scenario_Runner**](https://github.com/carla-simulator/scenario_runner): Engine to execute traffic scenarios in CARLA 0.9.X
* [**ROS-bridge**](https://github.com/carla-simulator/ros-bridge): Interface to connect CARLA 0.9.X to ROS
* [**Driving-benchmarks**](https://github.com/carla-simulator/driving-benchmarks): Benchmark tools for Autonomous Driving tasks
2019-03-20 20:20:35 +08:00
* [**Conditional Imitation-Learning**](https://github.com/felipecode/coiltraine): Training and testing Conditional Imitation Learning models in CARLA
2019-02-01 02:07:59 +08:00
* [**AutoWare AV stack**](https://github.com/carla-simulator/carla-autoware): Bridge to connect AutoWare AV stack to CARLA
2018-12-12 09:54:31 +08:00
* [**Reinforcement-Learning**](https://github.com/carla-simulator/reinforcement-learning): Code for running Conditional Reinforcement Learning models in CARLA
2023-11-16 21:47:08 +08:00
* [**RoadRunner**](https://www.mathworks.com/products/roadrunner.html): MATLAB GUI based application to create road networks in OpenDrive format
2019-03-02 05:18:59 +08:00
* [**Map Editor**](https://github.com/carla-simulator/carla-map-editor): Standalone GUI application to enhance RoadRunner maps with traffic lights and traffic signs information
2018-12-12 09:54:31 +08:00
2023-11-16 21:47:08 +08:00
**Like what you see? Star us on GitHub to support the project!**
2017-10-31 00:56:39 +08:00
Paper
-----
If you use CARLA, please cite our CoRL17 paper.
_CARLA: An Open Urban Driving Simulator_<br>Alexey Dosovitskiy, German Ros,
Felipe Codevilla, Antonio Lopez, Vladlen Koltun; PMLR 78:1-16
[[PDF](http://proceedings.mlr.press/v78/dosovitskiy17a/dosovitskiy17a.pdf)]
2018-10-11 16:46:08 +08:00
[[talk](https://www.youtube.com/watch?v=xfyK03MEZ9Q&feature=youtu.be&t=2h44m30s)]
2017-10-31 00:56:39 +08:00
```
@inproceedings{Dosovitskiy17,
title = {{CARLA}: {An} Open Urban Driving Simulator},
author = {Alexey Dosovitskiy and German Ros and Felipe Codevilla and Antonio Lopez and Vladlen Koltun},
booktitle = {Proceedings of the 1st Annual Conference on Robot Learning},
pages = {1--16},
year = {2017}
}
```
2018-01-19 23:10:27 +08:00
Building CARLA
--------------
2023-11-21 21:20:25 +08:00
Clone the repository locally from GitHub:
```sh
git clone https://github.com/carla-simulator/carla.git .
```
Also, clone the [CARLA fork of the Unreal Engine](https://github.com/CarlaUnreal/UnrealEngine) into an appropriate location:
```sh
git clone --depth 1 -b carla https://github.com/CarlaUnreal/UnrealEngine.git .
```
Install the prerequisites (these are for Ubuntu 20.04):
```sh
sudo apt-add-repository "deb http://apt.llvm.org/focal/ llvm-toolchain-focal main"
sudo apt-get update
sudo apt-get install build-essential clang-10 lld-10 g++-7 cmake ninja-build libvulkan1 python python-dev python3-dev python3-pip libpng-dev libtiff5-dev libjpeg-dev tzdata sed curl unzip autoconf libtool rsync libxml2-dev git
sudo update-alternatives --install /usr/bin/clang++ clang++ /usr/lib/llvm-10/bin/clang++ 180 &&
sudo update-alternatives --install /usr/bin/clang clang /usr/lib/llvm-10/bin/clang 180
```
For other versions please consult [the build instructions for Linux][buildlinuxlink] or [for Windows][buildwindowslink]:
Build Unreal Engine first, inside the directory where you cloned UE:
2018-01-19 23:10:27 +08:00
2020-06-12 15:55:13 +08:00
```sh
# Build UE
./Setup.sh && ./GenerateProjectFiles.sh && make
```
2018-01-19 23:10:27 +08:00
2020-06-12 15:55:13 +08:00
Unfortunately we don't have official instructions to build on Mac yet, please check the progress at [issue #150][issue150].
2018-01-19 23:10:27 +08:00
2020-03-13 22:17:56 +08:00
[buildlinuxlink]: https://carla.readthedocs.io/en/latest/build_linux/
[buildwindowslink]: https://carla.readthedocs.io/en/latest/build_windows/
2018-01-19 23:10:27 +08:00
[issue150]: https://github.com/carla-simulator/carla/issues/150
2018-01-15 21:55:26 +08:00
Contributing
------------
Please take a look at our [Contribution guidelines][contriblink].
2020-03-13 22:17:56 +08:00
[contriblink]: https://carla.readthedocs.io/en/latest/cont_contribution_guidelines/
2018-01-15 21:55:26 +08:00
2018-01-18 00:33:17 +08:00
F.A.Q.
------
If you run into problems, check our
2020-03-13 22:27:25 +08:00
[FAQ](https://carla.readthedocs.io/en/latest/build_faq/).
2018-01-18 00:33:17 +08:00
2021-03-11 18:18:42 +08:00
Licenses
2017-10-31 00:56:39 +08:00
-------
2021-04-07 23:46:14 +08:00
#### CARLA licenses
2021-03-11 18:18:42 +08:00
2017-10-31 00:56:39 +08:00
CARLA specific code is distributed under MIT License.
CARLA specific assets are distributed under CC-BY License.
2021-04-07 23:46:14 +08:00
#### CARLA Dependency and Integration licenses
2021-03-11 18:18:42 +08:00
2021-04-07 23:46:14 +08:00
The ad-rss-lib library compiled and linked by the [RSS Integration build variant](Docs/adv_rss.md) introduces [LGPL-2.1-only License](https://opensource.org/licenses/LGPL-2.1).
2021-03-11 18:18:42 +08:00
Unreal Engine 4 follows its [own license terms](https://www.unrealengine.com/en-US/faq).
2021-04-07 23:46:14 +08:00
CARLA uses three dependencies as part of the SUMO integration:
- [PROJ](https://proj.org/), a generic coordinate transformation software which uses the [X/MIT open source license](https://proj.org/about.html#license).
- [SQLite](https://www.sqlite.org), part of the PROJ dependencies, which is [in the public domain](https://www.sqlite.org/purchase/license).
- [Xerces-C](https://xerces.apache.org/xerces-c/), a validating XML parser, which is made available under the [Apache Software License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0.html).
2021-03-09 00:38:41 +08:00
2021-04-07 23:46:14 +08:00
CARLA uses one dependency as part of the Chrono integration:
- [Eigen](https://eigen.tuxfamily.org/index.php?title=Main_Page), a C++ template library for linear algebra which uses the [MPL2 license](https://www.mozilla.org/en-US/MPL/2.0/).
2021-03-09 04:35:31 +08:00
2021-04-07 23:46:14 +08:00
CARLA uses the Autodesk FBX SDK for converting FBX to OBJ in the import process of maps. This step is optional, and the SDK is located [here](https://www.autodesk.com/developer-network/platform-technologies/fbx-sdk-2020-0)
2021-03-09 04:35:31 +08:00
This software contains Autodesk® FBX® code developed by Autodesk, Inc. Copyright 2020 Autodesk, Inc. All rights, reserved. Such code is provided "as is" and Autodesk, Inc. disclaims any and all warranties, whether express or implied, including without limitation the implied warranties of merchantability, fitness for a particular purpose or non-infringement of third party rights. In no event shall Autodesk, Inc. be liable for any direct, indirect, incidental, special, exemplary, or consequential damages (including, but not limited to, procurement of substitute goods or services; loss of use, data, or profits; or business interruption) however caused and on any theory of liability, whether in contract, strict liability, or tort (including negligence or otherwise) arising in any way out of such code."