README.md 11.1 KB
Newer Older
R
Rajeev Rao 已提交
1
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0) [![Documentation](https://img.shields.io/badge/TensorRT-documentation-brightgreen.svg)](https://docs.nvidia.com/deeplearning/sdk/tensorrt-developer-guide/index.html)
R
Rajeev Rao 已提交
2

R
Rajeev Rao 已提交
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17


# TensorRT Open Source Software

This repository contains the Open Source Software (OSS) components of NVIDIA TensorRT. Included are the sources for TensorRT plugins and parsers (Caffe and ONNX), as well as sample applications demonstrating usage and capabilities of the TensorRT platform.


## Prerequisites

To build the TensorRT OSS components, ensure you meet the following package requirements:

**System Packages**

* [CUDA](https://developer.nvidia.com/cuda-toolkit)
  * Recommended versions:
R
Rajeev Rao 已提交
18
  * [cuda-10.2](https://developer.nvidia.com/cuda-10.2-download-archive-base) + cuDNN-7.6
K
Kevin Chen 已提交
19
  * [cuda-10.0](https://developer.nvidia.com/cuda-10.0-download-archive) + cuDNN-7.6
R
Rajeev Rao 已提交
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34

* [GNU Make](https://ftp.gnu.org/gnu/make/) >= v4.1

* [CMake](https://github.com/Kitware/CMake/releases) >= v3.13

* [Python](<https://www.python.org/downloads/>)
  * Recommended versions:
  * [Python2](https://www.python.org/downloads/release/python-2715/) >= v2.7.15
  * [Python3](https://www.python.org/downloads/release/python-365/) >= v3.6.5

* [PIP](https://pypi.org/project/pip/#history) >= v19.0

* Essential libraries and utilities
  * [Git](https://git-scm.com/downloads), [pkg-config](https://www.freedesktop.org/wiki/Software/pkg-config/), [Wget](https://www.gnu.org/software/wget/faq.html#download), [Zlib](https://zlib.net/)

R
Rajeev Rao 已提交
35 36 37
* Cross compilation for Jetson platforms requires JetPack's host component installation
  * [JetPack](https://developer.nvidia.com/embedded/jetpack) >= 4.2

R
Rajeev Rao 已提交
38 39 40 41 42 43 44 45 46 47 48 49
**Optional Packages**

* Containerized builds
  * [Docker](https://docs.docker.com/install/) >= 1.12
  * [NVIDIA Docker](https://github.com/NVIDIA/nvidia-docker) >= 2.0

* Code formatting tools
  * [Clang-format](https://clang.llvm.org/docs/ClangFormat.html)
  * [Git-clang-format](https://github.com/llvm-mirror/clang/blob/master/tools/clang-format/git-clang-format)

**TensorRT Release**

R
Rajeev Rao 已提交
50 51
* [TensorRT](https://developer.nvidia.com/nvidia-tensorrt-download) v7.0

R
Rajeev Rao 已提交
52 53 54

NOTE: Along with the TensorRT OSS components, the following source packages will also be downloaded, and they are not required to be installed on the system.

R
Rajeev Rao 已提交
55
- [ONNX-TensorRT](https://github.com/onnx/onnx-tensorrt) v7.0
R
Rajeev Rao 已提交
56 57 58 59 60 61 62 63 64
- [CUB](http://nvlabs.github.io/cub/) v1.8.0
- [Protobuf](https://github.com/protocolbuffers/protobuf.git) v3.8.x


## Downloading The TensorRT Components

1. #### Download TensorRT OSS sources.

	```bash
R
Rajeev Rao 已提交
65
	git clone -b master https://github.com/nvidia/TensorRT TensorRT -b release/7.0
R
Rajeev Rao 已提交
66 67 68 69 70 71 72
	cd TensorRT
	git submodule update --init --recursive
	export TRT_SOURCE=`pwd`
	```

2. #### Download the TensorRT binary release.

R
Rajeev Rao 已提交
73
	To build the TensorRT OSS, obtain the corresponding TensorRT 7.0 binary release from [NVidia Developer Zone](https://developer.nvidia.com/nvidia-tensorrt-7x-download). For a list of key features, known and fixed issues, refer to the [TensorRT 7.0 Release Notes](https://docs.nvidia.com/deeplearning/sdk/tensorrt-release-notes/tensorrt-7.html#tensorrt-7).
R
Rajeev Rao 已提交
74

R
Rajeev Rao 已提交
75
	**Example: Ubuntu 18.04 with cuda-10.2**
R
Rajeev Rao 已提交
76

R
Rajeev Rao 已提交
77
	Download and extract the latest *TensorRT 7.0 GA package for Ubuntu 18.04 and CUDA 10.2*
R
Rajeev Rao 已提交
78 79
	```bash
	cd ~/Downloads
R
Rajeev Rao 已提交
80 81 82
	# Download TensorRT-7.0.0.11.Ubuntu-18.04.x86_64-gnu.cuda-10.2.cudnn7.6.tar.gz
	tar -xvzf TensorRT-7.0.0.11.Ubuntu-18.04.x86_64-gnu.cuda-10.2.cudnn7.6.tar.gz
	export TRT_RELEASE=`pwd`/TensorRT-7.0.0.11
L
Lei Mao 已提交
83
	export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$TRT_RELEASE/lib
R
Rajeev Rao 已提交
84 85
	```

R
Rajeev Rao 已提交
86
	**Example: CentOS/RedHat 7 with cuda-10.0**
R
Rajeev Rao 已提交
87

R
Rajeev Rao 已提交
88
	Download and extract the *TensorRT 7.0 GA for CentOS/RedHat 7 and CUDA 10.0 tar package*
R
Rajeev Rao 已提交
89 90
	```bash
	cd ~/Downloads
R
Rajeev Rao 已提交
91 92 93
	# Download TensorRT-7.0.0.11.CentOS-7.6.x86_64-gnu.cuda-10.0.cudnn7.6.tar.gz
	tar -xvzf TensorRT-7.0.0.11.CentOS-7.6.x86_64-gnu.cuda-10.0.cudnn7.6.tar.gz
	export TRT_RELEASE=`pwd`/TensorRT-7.0.0.11
L
Lei Mao 已提交
94
	export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$TRT_RELEASE/lib
R
Rajeev Rao 已提交
95 96
	```

R
Rajeev Rao 已提交
97 98 99 100 101 102 103 104 105 106
3. #### Download JetPack packages for cross-compilation.[OPTIONAL]

Using the SDK manager, download the host componets of the PDK version or Jetpack specified in the name of the Dockerfile. To do this:

1. [**SDK Manager Step 01**] Log into the SDK manager
2. [**SDK Manager Step 01**] Select the correct platform and Target OS System  (should be corresponding to the name of the Dockerfile you are building (e.g. Jetson AGX Xavier, `Linux Jetpack 4.2.1`), then click `Continue`
3. [**SDK Manager Step 02**] Under `Download & Install Options` make note of or change the download folder **and Select Download now. Install later.** then agree to the license terms and click `Continue`

You should now have all expected files to build the container. Move these into the `docker/jetpack_files` folder.

R
Rajeev Rao 已提交
107 108 109 110 111 112 113 114
## Setting Up The Build Environment

* Install the *System Packages* list of components in the *Prerequisites* section.

* Alternatively, use the build containers as described below:

1. #### Generate the TensorRT build container.

R
Rajeev Rao 已提交
115
  The docker container can be built using the included Dockerfile. The build container is configured with the environment and packages required for building TensorRT OSS.
R
Rajeev Rao 已提交
116

R
Rajeev Rao 已提交
117
  **Example: Ubuntu 18.04 with cuda-10.2**
R
Rajeev Rao 已提交
118

R
Rajeev Rao 已提交
119 120 121
  ```bash
  docker build -f docker/ubuntu.Dockerfile --build-arg UBUNTU_VERSION=18.04 --build-arg CUDA_VERSION=10.2 --tag=tensorrt-ubuntu .
  ```
R
Rajeev Rao 已提交
122

R
Rajeev Rao 已提交
123
  **Example: CentOS/RedHat 7 with cuda-10.0**
R
Rajeev Rao 已提交
124

R
Rajeev Rao 已提交
125 126 127 128 129 130 131 132 133
  ```bash
  docker build -f docker/centos.Dockerfile --build-arg CENTOS_VERSION=7 --build-arg CUDA_VERSION=10.0 --tag=tensorrt-centos .
  ```

   **Example: Cross compile for JetPack 4.2.1 with cuda-10.0**
   ```bash
   docker build -f docker/ubuntu-cross-aarch64.Dockerfile --build-arg UBUNTU_VERSION=18.04 --build-arg CUDA_VERSION=10.0 --tag tensorrt-ubuntu-aarch64 .
   `
   ```
R
Rajeev Rao 已提交
134 135 136 137

2. #### Launch the TensorRT build container.

	```bash
R
Rajeev Rao 已提交
138
	docker run -v $TRT_RELEASE:/tensorrt -v $TRT_SOURCE:/workspace/TensorRT -it tensorrt-ubuntu:latest
R
Rajeev Rao 已提交
139 140 141 142 143 144 145 146 147 148 149
	```

	> NOTE: To run TensorRT/CUDA programs within the build container, install [nvidia-docker](#prerequisites). Replace the `docker run` command with `nvidia-docker run` or `docker run --runtime=nvidia`.


## Building The TensorRT OSS Components

* Generate Makefiles and build.

	```bash
	cd $TRT_SOURCE
R
Rajeev Rao 已提交
150
	mkdir -p build && cd build
R
Rajeev Rao 已提交
151 152 153 154 155
	cmake .. -DTRT_LIB_DIR=$TRT_RELEASE/lib -DTRT_BIN_DIR=`pwd`/out
	make -j$(nproc)
	```

	> NOTE:
R
Rajeev Rao 已提交
156
	> 1. The default CUDA version used by CMake is 10.2. To override this, for example to 10.0, append `-DCUDA_VERSION=10.0` to the cmake command.
K
Kevin Chen 已提交
157
	> 2. Samples may fail to link on CentOS7. To work around this create the following symbolic link:
R
Rajeev Rao 已提交
158
	> `ln -s $TRT_BIN_DIR/libnvinfer_plugin.so $TRT_BIN_DIR/libnvinfer_plugin.so.7`
R
Rajeev Rao 已提交
159 160 161 162 163 164 165 166 167 168 169

	The required CMake arguments are:

	- `TRT_LIB_DIR`: Path to the TensorRT installation directory containing libraries.

	- `TRT_BIN_DIR`: Output directory where generated build artifacts will be copied.

	The following CMake build parameters are *optional*:

	- `CMAKE_BUILD_TYPE`: Specify if binaries generated are for release or debug (contain debug symbols). Values consists of [`Release`] | `Debug`

R
Rajeev Rao 已提交
170
	- `CUDA_VERISON`: The version of CUDA to target, for example [`10.2`].
R
Rajeev Rao 已提交
171

R
Rajeev Rao 已提交
172
	- `CUDNN_VERSION`: The version of cuDNN to target, for example [`7.6`].
R
Rajeev Rao 已提交
173 174 175 176 177 178 179 180 181 182 183 184 185

	- `PROTOBUF_VERSION`:  The version of Protobuf to use, for example [`3.8.x`]. Note: Changing this will not configure CMake to use a system version of Protobuf, it will configure CMake to download and try building that version.

	- `CMAKE_TOOLCHAIN_FILE`: The path to a toolchain file for cross compilation.

	- `BUILD_PARSERS`: Specify if the parsers should be built, for example [`ON`] | `OFF`.  If turned OFF, CMake will try to find precompiled versions of the parser libraries to use in compiling samples. First in `${TRT_LIB_DIR}`, then on the system. If the build type is Debug, then it will prefer debug builds of the libraries before release versions if available.

	- `BUILD_PLUGINS`: Specify if the plugins should be built, for example [`ON`] | `OFF`. If turned OFF, CMake will try to find a precompiled version of the plugin library to use in compiling samples. First in `${TRT_LIB_DIR}`, then on the system. If the build type is Debug, then it will prefer debug builds of the libraries before release versions if available.

	- `BUILD_SAMPLES`: Specify if the samples should be built, for example [`ON`] | `OFF`.

	Other build options with limited applicability:

K
Kevin Chen 已提交
186 187 188 189
	- `NVINTERNAL`: Used by TensorRT team for internal builds. Values consists of [`OFF`] | `ON`.

	- `PROTOBUF_INTERNAL_VERSION`: The version of protobuf to use, for example [`10.0`].  Only applicable if `NVINTERNAL` is also enabled.

R
Rajeev Rao 已提交
190 191 192 193
	- `NVPARTNER`: For use by NVIDIA partners with exclusive source access.  Values consists of [`OFF`] | `ON`.

	- `CUB_VERSION`: The version of CUB to use, for example [`1.8.0`].

194
	- `GPU_ARCHS`: GPU (SM) architectures to target. By default we generate CUDA code for all major SMs. Specific SM versions can be specified here as a quoted space-separated list to reduce compilation time and binary size. Table of compute capabilities of NVIDIA GPUs can be found [here](https://developer.nvidia.com/cuda-gpus). Examples:
R
Rajeev Rao 已提交
195 196 197 198
	  - Titan V: `-DGPU_ARCHS="70"`
	  - Tesla V100: `-DGPU_ARCHS="70"`
	  - GeForce RTX 2080: `-DGPU_ARCHS="75"`
	  - Tesla T4: `-DGPU_ARCHS="75"`
199
	  - Multiple SMs: `-DGPU_ARCHS="70 75"`
R
Rajeev Rao 已提交
200 201 202 203 204 205

## Install the TensorRT OSS Components [Optional]

* Copy the build artifacts into the TensorRT installation directory, updating the installation.
  * TensorRT installation directory is determined as `$TRT_LIB_DIR/..`
  * Installation might require superuser privileges depending on the path and permissions of files being replaced.
K
Kevin Chen 已提交
206
  * Installation is not supported in cross compilation scenario. Please copy the result files from `build/out` folder into the target device.
R
Rajeev Rao 已提交
207 208 209 210

	```bash
	sudo make install
	```
L
Lei Mao 已提交
211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228
* Verify the TensorRT samples have been installed correctly.

	```bash
	cd $TRT_LIB_DIR/../bin/
	./sample_googlenet
	```

	If the sample was installed correctly, the following information will be printed out in the terminal.

	```bash
	[08/23/2019-22:08:57] [I] Building and running a GPU inference engine for GoogleNet
	[08/23/2019-22:08:59] [I] [TRT] Some tactics do not have sufficient workspace memory to run. Increasing workspace size may increase performance, please check verbose output.
	[08/23/2019-22:09:05] [I] [TRT] Detected 1 inputs and 1 output network tensors.
	[08/23/2019-22:09:05] [I] Ran /tensorrt/bin/sample_googlenet with: 
	[08/23/2019-22:09:05] [I] Input(s): data 
	[08/23/2019-22:09:05] [I] Output(s): prob 
	&&&& PASSED TensorRT.sample_googlenet # /tensorrt/bin/sample_googlenet
	```
R
Rajeev Rao 已提交
229 230 231 232 233 234 235 236 237 238 239 240 241

## Useful Resources

#### TensorRT

* [TensorRT Homepage](https://developer.nvidia.com/tensorrt)
* [TensorRT Developer Guide](https://docs.nvidia.com/deeplearning/sdk/tensorrt-developer-guide/index.html)
* [TensorRT Sample Support Guide](https://docs.nvidia.com/deeplearning/sdk/tensorrt-sample-support-guide/index.html)
* [TensorRT Discussion Forums](https://devtalk.nvidia.com/default/board/304/tensorrt/)


## Known Issues

R
Rajeev Rao 已提交
242 243
#### TensorRT 7.0
* See [Release Notes](https://docs.nvidia.com/deeplearning/sdk/tensorrt-release-notes/tensorrt-7.html#tensorrt-7).