# Quick start package installation This guide shows how to download and install the packaged version of CARLA. The package includes the CARLA server and two options for the client library. There are additional assets that can be downloaded and imported into the package. Advanced customization and development options that require use of the Unreal Engine editor are not available but these can be accessed by using the build version of CARLA for either [Windows](build_windows.md) or [Linux](build_linux.md). * __[Before you begin](#before-you-begin)__ * __[CARLA installation](#carla-installation)__ * [A. Debian CARLA installation](#a-debian-carla-installation) * [B. Package installation](#b-package-installation) * __[Import additional assets](#import-additional-assets)__ * __[Install client library](#install-client-library)__ * [CARLA versions prior to 0.9.12](#carla-versions-prior-to-0912) * [CARLA 0.9.12+](#carla-0912) * __[Running CARLA](#running-carla)__ * [Command-line options](#command-line-options) * __[Updating CARLA](#updating-carla)__ * __[Follow-up](#follow-up)__ --- ## Before you begin The following requirements should be fulfilled before installing CARLA: * __System requirements.__ CARLA is built for Windows and Linux systems. * __An adequate GPU.__ CARLA aims for realistic simulations, so the server needs at least a 6 GB GPU although we would recommend 8 GB. A dedicated GPU is highly recommended for machine learning. * __Disk space.__ CARLA will use about 20 GB of space. * __Python.__ [Python]((https://www.python.org/downloads/)) is the main scripting language in CARLA. CARLA supports Python 2.7 and Python 3 on Linux, and Python 3 on Windows. * __Pip.__ Some installation methods of the CARLA client library require __pip__ or __pip3__ (depending on your Python version) version 20.3 or higher. To check your __pip__ version: >> # For Python 3 >> pip3 -V >> # For Python 2 >> pip -V >If you need to upgrade: >> # For Python 3 >> pip3 install --upgrade pip >> # For Python 2 >> pip install --upgrade pip * __Two TCP ports and good internet connection.__ 2000 and 2001 by default. Make sure that these ports are not blocked by firewalls or any other applications. * __Other requirements.__ CARLA requires some Python dependencies. Install the dependencies according to your operating system: ### Windows ```sh pip3 install --user pygame numpy ``` ### Linux ```sh pip install --user pygame numpy && pip3 install --user pygame numpy ``` --- ## CARLA installation There are two methods to download and install CARLA as a package: __A)__ [Download the Debian package.](#a-debian-carla-installation) __B)__ [Download the package from GitHub.](#b-package-installation) ### A. Debian CARLA installation The Debain package is available for both Ubuntu 18.04 and Ubuntu 20.04, however __the officially supported platform is Ubuntu 18.04__. __1.__ Set up the Debian repository in the system: ```sh sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 1AF1527DE64CB8D9 sudo add-apt-repository "deb [arch=amd64] http://dist.carla.org/carla $(lsb_release -sc) main" ``` __2.__ Install CARLA and check for the installation in the `/opt/` folder: ```sh sudo apt-get update # Update the Debian package index sudo apt-get install carla-simulator # Install the latest CARLA version, or update the current installation cd /opt/carla-simulator # Open the folder where CARLA is installed ``` This repository contains CARLA 0.9.10 and later versions. To install a specific version add the version tag to the installation command: ```sh apt-cache madison carla-simulator # List the available versions of Carla sudo apt-get install carla-simulator=0.9.10-1 # In this case, "0.9.10" refers to a CARLA version, and "1" to the Debian revision ``` !!! Important To install CARLA versions prior to 0.9.10, change to a previous version of the documentation using the panel in the bottom right corner of the window, and follow the old instructions. ### B. Package installation
This repository contains different versions of CARLA. You will find options to download the __current release__ with all the most recent fixes and features, __previous releases__ and a __nightly build__ with all the developmental fixes and features (the nightly build is the most unstable version of CARLA). The package is a compressed file named __CARLA_version.number__. Download and extract the release file. It contains a precompiled version of the simulator, the Python API module and some scripts to be used as examples. --- ## Import additional assets Each release has it's own additional package of extra assets and maps. This additional package includes the maps __Town06__, __Town07__, and __Town10__. These are stored separately to reduce the size of the build, so they can only be imported after the main package has been installed. __1.__ [Download](https://github.com/carla-simulator/carla/blob/master/Docs/download.md) the appropriate package for your desired version of CARLA. __2.__ Extract the package: - __On Linux__: - move the package to the _Import_ folder and run the following script to extract the contents: ```sh cd path/to/carla/root ./ImportAssets.sh ``` - __On Windows__: - Extract the contents directly in the root folder. --- ## Install client library ### CARLA versions prior to 0.9.12 Previous versions of CARLA did not require the Python library to be installed, they came with an `.egg` file that was ready to use out of the box. __CARLA versions 0.9.12+ change this behavior significantly; there are several options available to install the client library.__ If you are using a version of CARLA prior to 0.9.12, please select that version in the bottom right corner of the screen to see the relevant documentation. Otherwise, read on below about the available options in CARLA 0.9.12+. ### CARLA 0.9.12+ There are several options available to install and use the CARLA client library: - __.egg__ file - __.whl__ file - __Downloadable Python package__ Read more below about the requirements and limitations of each method before deciding which one to use. Please note that mixing the different methods can lead to incompatibilities, so use virtual environments when possible or [uninstall](build_faq.md#how-do-i-uninstall-the-carla-client-library) a previously installed library before using a new one. >__A. .egg files__ >>CARLA provides `.egg` files in `PythonAPI/carla/dist/` for different Python versions that are ready to use out of the box. Each of the example scripts in `PythonAPI/examples` includes a [code snippet](build_system.md#versions-prior-to-0912) that looks for this file automatically. In Linux, you may need to add this file to your `PYTHONPATH`. Read more about `.egg` files in CARLA [here](build_faq.md#importerror-no-module-named-carla). >>__If you have previously installed the client library with `pip`, this will take precedence over the `.egg` file__. You will need to [uninstall](build_faq.md#how-do-i-uninstall-the-carla-client-library) the previous library first. >__B. .whl files__ >>CARLA provides `.whl` files for different Python versions. You will need to install the `.whl` file. The `.whl` file is found in `PythonAPI/carla/dist/`. There is one file per supported Python version, indicated by the file name (e.g., carla-0.9.12-__cp36__-cp36m-manylinux_2_27_x86_64.whl indicates Python 3.6). >>__It is recommended to install the CARLA client library in a virtual environment to avoid conflicts when working with multiple versions.__ >>To install the CARLA client library, run the following command, choosing the file appropriate to your desired Python version. You will need __pip/pip3__ version 20.3 or above. See the [__Before you begin__](#before-you-begin) section for how to check the version and upgrade __pip/pip3__: >> # Python 3 >> pip3 install