/HIPRT-Path-Tracer

Unbiased & physically-based GPU HIPRT (C++/HIP) interactive path tracing renderer

Primary LanguageC++GNU General Public License v3.0GPL-3.0

HIPRT-Path-Tracer

HIPRT path tracer cover

Physically based unidirectional (backwards) monte carlo path tracer written with the HIPRT and Orochi libraries.

HIPRT is AMD's equivalent to OptiX. It allows the use of the ray tracing accelerators of RDNA2+ AMD GPUs and can run on NVIDIA devices as well (although it wouldn't take advatange of RT cores) as it is not AMD specific.

The Orochi library allows the loading of HIP and CUDA libraries at runtime meaning that the application doesn't have to be recompiled to be used on a GPU from a different vendor (unlike HIP alone which, despite being compatible with NVIDIA and AMD hardware, would require a recompilation).

System requirements

  • AMD RDNA1 GPU or newer (RX 5000 or newer) or NVIDIA Maxwell GPU or newer (GTX 700 & GTX 900 Series or newer)
  • Visual Studio 2022 (only version tested but older versions might work as well) on Windows
  • CMake
  • CUDA for NVIDIA compilation

Features:

Layered Principled BSDF:

  • Coat Microfacet GGX Layer + Anisotropy, Anisotropy Rotation, Medium Absorption & Thickness
  • SGGX Volumetric Sheen Lobe LTC Fit [Zeltner, Burley, Chiang, 2022]
  • Specular Microfacet GGX Layer
  • Oren-Nayar Diffuse BRDF Lobe
  • Metallic Microfacet GGX Layer + Anisotropy & Anisotropy Rotation + Double Roughness [Kulla & Conty, 2017]
  • Specular transmission BTDF + Beer Lambert Volumetric Absorption: [Burley, 2015]
  • Multiple-scattering energy compensation for conductors (double metal layer), dielectrics (tranmission layer) and glossy-diffuse (specular + diffuse layer) materials [Turquin, 2019]

LayeredBSDF

Sampling

Other rendering features:

UI

  • Interactive ImGui interface
    • Asynchronous interface to guarantee smooth UI interactions even with heavy path tracing kernels
  • Interactive first-person camera
  • Different frame-buffer visualization (visualize the adaptive sampling heatmap, the denoiser normals / albedo, ...)

Other features

  • Use of the [ASSIMP] library to support many scene file formats.
  • Multithreaded scene parsing/texture loading/shader compiling/BVH building/envmap processing/... for faster application startup times
  • Background-asynchronous path tracing kernel pre-compilations
  • Shader cache to avoid recompiling kernels unnecessarily

Some of the features are (or will be) presented in more details in my blog posts!

Building

Prerequisites

Windows

- AMD GPUs

Nothing to do, go to the "Compiling" step.

- NVIDIA GPUs

To build the project on NVIDIA hardware, you will need to install the NVIDIA CUDA SDK v12.2. It can be downloaded and installed from here.

The CMake build then expects the CUDA_PATH environment variable to be defined. This should automatically be the case after installing the CUDA Toolkit but just in case, you can define it yourself such that CUDA_PATH/include/cuda.h is a valid file path.

Linux

- AMD GPUs

  1. Install OpenGL, GLFW and glew dependencies:
sudo apt install freeglut3-dev
sudo apt install libglfw3-dev
sudo apt install libglew-dev
  1. Install AMD HIP (if you already have ROCm installed, you should have a /opt/rocm folder on your system and you can skip this step):

Download amdgpu-install package: https://www.amd.com/en/support/linux-drivers Install the package:

sudo apt install ./amdgpu-install_xxxx.deb

Install HIP:

sudo amdgpu-install --usecase=hip
  1. Normally, you would have to run the path tracer as sudo to be able to acces GPGPU compute capabilities. However, you can save yourself the trouble by adding the user to the render group and rebooting your system :
sudo usermod -a -G render $LOGNAME

- NVIDIA GPUs

  1. Install OpenGL, GLFW and glew dependencies:
sudo apt install freeglut3-dev
sudo apt install libglfw3-dev
sudo apt install libglew-dev
  1. Install the NVIDIA CUDA SDK (called "CUDA Toolkit"). It can be downloaded and installed from here.

Compiling

With the pre-requisites fulfilled, you now just have to run the CMake:

git clone https://github.com/TomClabault/HIPRT-Path-Tracer.git --recursive
cd HIPRT-Path-Tracer
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Debug ..

On Windows, a Visual Studio solution will be generated in the build folder that you can open and compile the project with (select HIPRTPathTracer as startup project).

On Linux, the HIPRTPathTracer executable will be generated in the build folder.

Usage

./HIPRT-Path-Tracer

The following arguments are available:

  • <scene file path> an argument of the commandline without prefix will be considered as the scene file. File formats supported.
  • --sky=<path> for the equirectangular skysphere used during rendering (HDR or not)
  • --samples=N for the number of samples to trace*
  • --bounces=N for the maximum number of bounces in the scene*
  • --w=N / --width=N for the width of the rendering*
  • --h=N / --height=N for the height of the rendering*

* CPU only commandline arguments. These parameters are controlled through the UI when running on the GPU.

Gallery

P1 street Contemporary bedroomBlender 4.1 splash Dragon glass Beeple Zero Day Measure Seven Lux Core Orbs Mitsuba Knob Sheen Dust Dragon indirect lighting MIS vs. RIS vs. ReSTIR DI Comparison ImGui Interface Sources of the scenes can be found here.

Live YouTube Demos

Material Editor Demo

Material Editor Demo

OIDN AOVs Quality Comparison

OIDN AOVs Comparison

ReSTIR DI vs. RIS vs. MIS Showcase

ReSTIR DI Showcase

License

GNU General Public License v3.0 or later

See COPYING to see the full text.