3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes

Download as pdf or txt
Download as pdf or txt
You are on page 1of 18

3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes

NICOLAS MOENNE-LOCCOZ∗ , NVIDIA, Canada


ASHKAN MIRZAEI∗ , NVIDIA, Canada
OR PEREL, NVIDIA, Israel
RICCARDO DE LUTIO, NVIDIA, USA
JANICK MARTINEZ ESTURO, NVIDIA, Germany
GAVRIEL STATE, NVIDIA, Canada
SANJA FIDLER, NVIDIA, University of Toronto, Vector Institute, Canada
NICHOLAS SHARP† , NVIDIA, USA
ZAN GOJCIC† , NVIDIA, Switzerland
arXiv:2407.07090v1 [cs.GR] 9 Jul 2024

depth of field
mirrors
encapsulating acceleration
refraction primitives structure

inserted objects

Fig. 1. We propose a method for fast forward and inverse ray tracing of particle-based scene representations such as Gaussians. The main idea is to construct
encapsulating primitives around each particle, and insert them into a BVH to be rendered by a ray tracer specially adapted to the high density of overlapping
particles. Efficient ray tracing opens the door to many advanced techniques in computer graphics and vision, including secondary ray effects like mirrors,
refractions and shadows, as well as highly-distorted cameras with rolling shutter effects and even stochastic sampling of rays.
Project page: GaussianTracer.github.io

Particle-based representations of radiance fields such as 3D Gaussian Splat- CCS Concepts: • Computing methodologies → Rendering; Reconstruc-
ting, have found great success for reconstructing and re-rendering of complex tion.
scenes. Most existing methods render particles via rasterization, projecting
them to screen space tiles for processing in a sorted order. This work instead Additional Key Words and Phrases: Radiance Fields, Gaussian Splats, Ray
considers ray tracing the particles, building a bounding volume hierarchy Tracing
and casting a ray for each pixel using high-performance GPU ray tracing
hardware. To efficiently handle large numbers of semi-transparent particles, 1 INTRODUCTION
we describe a specialized rendering algorithm which encapsulates parti-
cles with bounding meshes to leverage fast ray-triangle intersections, and Multiview 3D reconstruction and novel-view synthesis are a classic
shades batches of intersections in depth-order. The benefits of ray tracing challenge in visual computing, key to applications across robotics,
are well-known in computer graphics: processing incoherent rays for sec- telepresence, AR/VR, and beyond. Many approaches have been
ondary lighting effects such as shadows and reflections, rendering from proposed, but most recently particle-based representations have
highly-distorted cameras common in robotics, stochastically sampling rays, shown incredible success, ignited by 3D Gaussian Splatting [Kerbl
and more. With our renderer, this flexibility comes at little cost compared et al. 2023] (3DGS)—the basic idea is to represent a scene as a large
to rasterization. Experiments demonstrate the speed and accuracy of our unstructured collection of fuzzy particles which can be differentiably
approach, as well as several applications in computer graphics and vision. rendered by splatting to a camera view with a tile-based rasterizer.
We further propose related improvements to basic Gaussian representation,
The location, shape, and appearance of the particles are optimized
including a simple use of generalized kernel functions which significantly
using a re-rendering loss.
reduces particle hit counts.
Meanwhile, more broadly in computer graphics, rendering has
∗ Authors contributed equally. long been a duality between rasterization and ray tracing. Tradition-
† Authors contributed equally. ally, rasterization supported real-time performance at the expense
2 • Moenne-Loccoz, Mirzaei et al.

of approximating image formation, while ray tracing enabled fully In summary, the contributions of this work are:
general high-fidelity rendering in the expensive offline setting. How- • A GPU-accelerated ray tracing algorithm for semi-transparent
ever, the introduction of specialized GPU ray tracing hardware and particles.
real-time renderers has moved ray tracing into the realm of real-time • An improved optimization pipeline for ray-traced, particle-
performance. based radiance fields.
This work is motivated by the observation that 3DGS is limited • Generalized Gaussian particle formulations that reduce the
by the classic tradeoffs of rasterization. The tile-based rasterizer is number of intersections and lead to improved rendering effi-
ill-suited to rendering from highly-distorted cameras with rolling ciency.
shutter effects, which are important in robotics and simulation. It • Applications demonstrating the utility of ray tracing, includ-
also cannot efficiently simulate secondary rays needed to handle ing: depth of field, shadows, mirrors, highly-distorted cameras,
phenomena like reflection, refraction, and shadows. Likewise, ras- rolling shutter, incoherent rays, and instancing.
terization cannot sample rays stochastically, a common practice for
training in computer vision. Indeed, prior work has already encoun- 2 RELATED WORK
tered the need for these capabilities, but was limited to rendering 2.1 Novel-View Synthesis and Neural Radiance Fields
with restrictive tricks or workarounds [Niemeyer et al. 2024; Seiskari
et al. 2024]. We instead aim to address these limitations by making Classical approaches to novel-view synthesis can be roughly cat-
the ray traced Gaussian particles efficient, with a tailored imple- egorized based on the sparsity of the input views. In the case of
mentation for specialized GPU ray tracing. To be clear, goal of this sparse views, most methods first construct a proxy geometry us-
work is not to offer an end-to-end solution to unsolved problems ing multi-view stereo [Schönberger and Frahm 2016; Schönberger
like global illumination or inverse lighting on particle scenes, but et al. 2016] and point cloud reconstruction methods [Kazhdan et al.
rather to provide a key algorithmic ingredient to future research on 2006; Kazhdan and Hoppe 2013] and then unproject the images
these problems: a fast differentiable ray tracer. onto this geometry either directly in terms of RGB colors [Buehler
Efficiently ray tracing Gaussian scenes (and more generally semi- et al. 2001; Debevec et al. 1996; Wood et al. 2000] or extracted la-
transparent surfaces) is not a solved problem [“Tanki” Zhang 2021]. tent features [Riegler and Koltun 2020, 2021]. The novel views are
We find that even past algorithms that were specially designed for rendered by projecting the color or features from the geometry to
ray tracing semi-transparent particles [Brüll and Grosch 2020; Knoll the camera plane. In the case of densely sampled input views, the
et al. 2019; Münstermann et al. 2018] are ineffective on these scene novel-view synthesis can instead be formulated directly as light
reconstructions, due to the huge numbers of non-uniformly dis- field interpolation problem [Davis et al. 2012; Gortler et al. 1996;
tributed and densely-overlapping particles. Accordingly, we design Levoy and Hanrahan 1996].
a customized GPU-accelerated ray tracer for Gaussian particles with Neural Radiance Fields (NeRFs) [Mildenhall et al. 2020] have
a 𝑘-buffer [Bavoil et al. 2007] hits-based marching to gather ordered revolutionized the field of novel-view synthesis by representing
intersections, bounding mesh proxies to leverage fast ray-triangle the scenes in terms of a volumetric radiance field encoded in a
intersections, and a backward pass to enable optimization. Each coordinate-based neural network. This network can be queried at
of these components is carefully tested for speed and quality on a any location to return the volumetric density and view-dependent
variety of benchmarks. We found it crucial to tune the details of color. The photo-realistic quality of NeRFs has made them the stan-
the algorithm to the task at hand. Our final proposed algorithm dard representation for novel-view synthesis. Follow-up works have
is almost 25x faster than our first naive implementation, due to a focused on improving the speed [Müller et al. 2022; Reiser et al.
wide range of algorithmic and numerical factors. We hope that these 2021], quality [Barron et al. 2021, 2022, 2023], and surface represen-
learnings will be of value to the community leveraging raytracing tation [Li et al. 2023; Wang et al. 2021, 2023a; Yariv et al. 2021]. NeRF
on particle representations. has also been extended to large-scale scenes [Li et al. 2024a; Turki
The fundamental approach of representing a scene with parti- et al. 2022], sparse inputs views [Niemeyer et al. 2022] and in-the-
cles is not limited to the Gaussian kernel; and recent work has wild image collections [Martin-Brualla et al. 2021]. Finally, several
already shown several natural generalizations [Huang et al. 2024]. works investigated ways to speed up the inference by baking the
Our ray tracing scheme, as well as the benefits and applications neural fields to more performant representations [Duckworth et al.
above, likewise generalizes more broadly to particle-based scene 2023; Reiser et al. 2024, 2023; Wang et al. 2023b]. While achieving
representations, as we show in section Section 4.5. high quality and fast rendering speeds, these methods often employ
We evaluate this approach on a wide variety of benchmarks and compute-expensive multi-stage training procedures.
applications. On standard multiview benchmarks, ray tracing nearly
matches or exceeds the quality of the 3DGS rasterizer of Kerbl et al. 2.2 Point-Based and Particle Rasterization
[2023], while still achieving real-time rendering framerates. More Grossman and Dally [1998] defined point-based rendering as a sim-
importantly, we demonstrate a variety of new techniques made ple rasterization of object surface points along with their color and
easy and efficient by ray tracing, including secondary ray effects normals. However, due to the infinitesimal size of the points, such
like shadows and reflections, rendering from cameras with high simple rasterization inevitably led to holes and aliasing. To address
distortion and rolling shutter, training with stochastically sampled these limitations, later work converted points to particles with a
rays and more. spatial extent, such as surfels, circular discs, or ellipsoids [Pfister
et al. 2000; Ren et al. 2002; Zwicker et al. 2001]. More recently, points
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 3

Fig. 2. Ray Tracing Effects: The ray based nature of our pipeline makes it easily compatible with conventional ray based visual effects at test-time, including
reflections (top left), depth of field (top middle), refractions (bottom left), hard-shadows cast by meshes (bottom middle) and combinations thereof (right).

or particles have also been augmented with neural features and ren- 2.3 Differentiable Ray Tracing of Volumetric Particles
dered using rasterization in combination with CNN networks [Aliev Ray tracing became the gold standard for offline rendering of high-
et al. 2020; Kopanas et al. 2021; Rückert et al. 2022] or NeRF-like quality photo-realistic images [Whitted 1979]. The advent of dedi-
volumetric rendering [Ost et al. 2022; Xu et al. 2022]. cated hardware to efficiently compute the intersection of camera
Differentiable rendering through alpha blending was also ex- rays with the scene geometry has also enabled its use for real-time
tended to volumetric particles. Pulsar [Lassner and Zollhöfer 2021] rendering applications such as gaming and the simulation industry.
proposed an efficient sphere-based differentiable rasterization ap- Modern GPUs are exposing ray tracing rendering pipelines, from
proach, which allows for real-time optimization of scenes with the computation of dedicated acceleration structures to a specific
millions of particles. The seminal 3DGS work of Kerbl et al. [2023] programmable interface [Joshi et al. 2007].
instead represented the scenes using fuzzy, anisotropic 3D Gaussian However, these works are highly optimized for rendering opaque
particles. By optimizing the shape, position, and appearance of these surfaces and efficiently handling order independent semi-transparent
Gaussian particles through an efficient tile-based rasterizer, 3DGS surfaces or particles remains challenging [“Tanki” Zhang 2021].
achieves SoTA results in terms of perceptual quality and efficiency. A first class of works [Aizenshtein et al. 2022; Münstermann et al.
3DGS inspired many follow-up works that aim to reduce the render 2018] proposes to first estimate the transmittance function along
time or memory footprint [Fan et al. 2023; Niedermayr et al. 2023; the ray and subsequently to integrate the particles’ radiance based
Papantonakis et al. 2024], improve surface representation [Gué- on this estimate. It assumes the traversal of the full scene to be fast
don and Lepetit 2023; Huang et al. 2024], and support large-scale enough; an assumption that does not hold in Gaussian particles for
scenes [Kerbl et al. 2024; Ren et al. 2024], and more. scene reconstruction.
Jointly, these works have made significant progress, but they A second class of works consists in re-ordering the particles along
still inherit limitations of rasterization. Indeed, they are not able the ray. Knoll et al. [2019] propose a slab-tracing method to trace
to represent highly distorted cameras, model secondary lighting semi-transparent volumetric RBF (radial basis function) particles,
effects, or sensor properties such as rolling shutter or motion blur. which enables real-time ray tracing of scenes consisting of several
Several works have tried to work around these limitations. Niemeyer millions of such particles. However, its efficiency is largely based
et al. [2024] first train a Zip-NeRF [Barron et al. 2023] that can on the assumption of the isotropic shape of the particles and a high
model distorted and rolling shutter cameras and then render perfect level of uniformity in their spatial distribution. In [Brüll and Grosch
pinhole cameras from the neural field and distill them into a 3DGS 2020], the multi-layer alpha blending approach from [Salvi and
representation. This allows for fast inference, but is still limited to Vaidyanathan 2014] is extended to ray tracing. Their multi-layer
perfect pinhole cameras. To model secondary lighting effects Gao alpha tracing supports efficient rendering of any semi-transparent
et al. [2023] combines rasterization with particle-based ray tracing surface but its approximation of the particle’s ordering may produce
for the visibility pass. Finally, Seiskari et al. [2024] model the motion rendering artifacts.
blur and rolling shutter of the camera by approximating them in Our formulation takes root in these precursory works. However
screen space through rasterization with pixel velocities. Unlike these as opposed to [Knoll et al. 2019], it is guaranteed to process every
works, we formulate a principled method for efficient ray tracing particle intersecting the ray. And contrary to [Brüll and Grosch
of volumetric particles, which natively alleviates all the limitations 2020] the hit processing order is consistent, which ensures the dif-
mentioned above and further allows us to simulate effects such as ferentiability of our tracing algorithm.
depth of field and perfect mirrors.
4 • Moenne-Loccoz, Mirzaei et al.

Compared to rasterization, differentiable ray tracing of semi- Considering 𝛼𝑖 = 𝜎𝑖 𝜌𝑖 (x𝑖 ), Equation 4 can be approximated using
transparent particles has seen much less progress in recent years. numerical integration as
Perhaps the most similar rendering formulation to ours was pro- 𝑁 𝑖 −1
∑︁ Ö
posed in Fuzzy Metaballs [Keselman and Hebert 2022, 2023], but it 𝑳(𝒐, 𝒅) = 𝒄𝑖 (𝒅)𝛼𝑖 1 − 𝛼𝑗, (6)
is limited to scenes with a small set of 3D Gaussian particles (several 𝑖=1 𝑗=1
tens) and images with very low resolution. Different to Fuzzy Meta-
balls, our method can easily handle scenes with several millions of where in this linear approximation, x𝑖 is defined as the point along
particles from which it can render full HD images in real-time. the ray 𝒓 with the highest response 𝜌𝑖 of the 𝑖 th Gaussian (see 4.3 for
more details). For derivations of the higher order approximations of
3 BACKGROUND 𝜌𝑖 please refer to [Keselman and Hebert 2022].
We begin with a short review of 3D Gaussian scene representation,
volumetric particle rendering, and hardware-accelerated ray tracing.
3.3 Hardware-Accelerated Ray Tracing
In this work we use NVIDIA RTX hardware through the NVIDIA
3.1 3D Gaussian Parameterization OptiX programming interface [Parker et al. 2010]. Through this in-
Extending Kerbl et al. [2023], our scenes can be represented as a set terface, geometric primitives such as triangle meshes are processed
of differentiable semi-transparent particles defined by their kernel to construct a Bounding Volume Hierarchy (BVH1 ). This acceleration
function. For example, the kernel function of a 3D Gaussian particle structure is optimized for the computation of ray-primitive inter-
𝜌 : R3 → R at a given point 𝒙 ∈ R3 can be expressed as sections by dedicated hardware, the RT cores. The programmable
𝑇 −1
pipeline sends traversal queries to this hardware, freeing the GPU
𝜌 (𝒙) = 𝑒 − (𝒙 −𝝁 ) 𝚺 (𝒙 −𝝁 ) , (1) streaming-multiprocessors (SMs) for the main computational load,
where 𝝁 ∈ R3 represents the particle’s position and 𝚺 ∈ R3×3 the e.g material shading. The interactions of the SMs with the RT cores
covariance matrix. To ensure the positive semi-definiteness of the are done through the following programmable entry points:
covariance matrix 𝚺 when optimizing it using gradient descent, we • ray-gen program (ray generation) is where the SMs may initi-
represent it as ate a scene traversal for a given ray.
𝚺 = 𝑹𝑇 𝑺𝑇 𝑺𝑹 (2) • intersection program is called during the traversal to compute
the precise intersection with potentially hit primitives that are
with 𝑹 ∈ SO(3) a rotation matrix and 𝑺 ∈ R3×3 a scaling matrix.
not directly supported by the hardware.
These are both stored as their equivalent vector representations,
• any-hit program is called during the traversal for every hit
a quaternion 𝒒 ∈ R4 for the rotation and a vector 𝒔 ∈ R3 for the
and may further process or reject the hit.
scale. For other particle variants explored in this work, please refer
• closest-hit program is called at the end of the traversal, for
to Section 4.5.
further processing of the closest accepted hit.
Each particle is further associated with an opacity coefficient
• miss program is called at the end of the traversal for further
𝜎 ∈ R, and a parametric radiance function 𝜙 𝜷 (𝒅) : R3 → R3 ,
processing when no hit has been accepted.
dependent on the view direction 𝒅 ∈ R3 . In practice, following
Kerbl et al. [2023], we use a spherical harmonics functions 𝑌ℓ𝑚 (𝒅) Such a pipeline is highly optimized to render opaque primitives,
of order 𝑚 = 3 defined by the coefficients 𝜷 ∈ R48 . Note that we i.e. the number of expected hits during a traversal is low, with a
𝝁 −𝒐 minimal amount of interactions between the SMs and the RT cores.
are using the ray direction while Kerbl et al. [2023] uses ∥𝝁 −𝒐 ∥ for
Rendering volumes, where the primitives are semi-transparent, re-
performance reason.
quires traversing and processing many hits per ray. To efficiently
Therefore the parametric radiance function can be written as
! trace a volume, specific approaches must be designed, tailored to
ℓ∑︁ ℓ
max ∑︁
𝑚 𝑚 the type of primitives (or particles), their expected size, and distri-
𝜙 𝜷 (𝒅) = 𝑓 𝛽 ℓ 𝑌ℓ (𝒅) (3) bution across the volume (see for example [Knoll et al. 2019]). In
ℓ=0 𝑚=−ℓ
this work we propose an efficient and differentiable algorithm to
where 𝑓 is the sigmoid function to normalize the colors. ray trace a volume made of optimized semi-transparent particles
for high-fidelity novel view rendering.
3.2 Differentiable Rendering of Particle Representations
Given this parametrization, the scene can be rendered along a ray 4 METHOD
𝒓 (𝜏) = 𝒐 + 𝜏𝒅 with origin 𝒐 ∈ R3 and direction 𝒅 ∈ R3 via classical The proposed volumetric particle tracer requires two core com-
volume rendering ponents: a strategy to represent particles in an acceleration struc-
Í 
∫𝜏 ture (BVH) to efficiently test for intersections against them, using
𝑳(𝒐, 𝒅) = 𝜏 𝑓 𝑇 (𝒐, 𝒅) 𝑖 (1 − 𝑒 −𝜎𝑖 𝜌𝑖 (𝒐+𝜏𝒅 ) )𝒄𝑖 (𝒅) 𝑑𝜏 , (4)
𝑛 adaptive bounding mesh primitives (Section 4.1), and a rendering
where 𝒄𝑖 (𝒅) = 𝜙 𝜷𝑖 (𝒅) is the color of the 𝑖 th Gaussian obtained by algorithm which casts rays and gathers batches of intersections,
evaluating its view-dependant radiance function. The transmittance 1 Forclarity, throughout this work we reference BVH as the de-facto hardware accel-
function 𝑇 (𝒐, 𝒅) is defined as eration structure. However, since in practice NVIDIA OptiX’s specification interfaces
∫𝜏 Í the implementation of bottom level acceleration structures, we emphasize our pipeline
− 𝜎𝑖 𝜌𝑖 (𝒐+𝑡 𝒅 )𝑑𝑡
𝑇 (𝒐, 𝒅) = 𝑒 𝜏𝑛 𝑖
. (5) does not depend on a particular implementation.
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 5

Trace Against BVH and Get k-Closest Proxy Hits (§4.1) Evaluate Particle Response (§4.3) Update Radiance Integral
3D Particles Proxy Geometries and BVH (§4.1) Rendering

Repeat Until All Particles Evaluated or Transmiance Theshold

Fig. 3. Overview of the Accelerated Tracing Algorithm: Given a set of 3D particles, we first build the corresponding bounding primitives and insert them
into a BVH. To compute the incoming radiance along each ray, we trace rays against the BVH to get the next k particles. We then compute the intersected
particles’ response and accumulate the radiance according to Equation 6. The process repeats until all particles have been evaluated or the transmittance
meets a predefined threshold and the final rendering is returned.

stretched + adaptive
axis-aligned icosahedron icosahedron clamping
the bounding mesh triggers processing of the corresponding par-
bounding box mesh mesh (ours) ticle, as described later in Section 4.3. We fit the bounding proxy
by specifying a minimum response 𝛼 min which must be captured
(typically 𝛼 min = 0.01), and analytically compute an anisotropic
rescaling of the icosahedron to cover the whole space with at least
𝛼 min response. Precisely, for each particle we construct an icosahe-
dron with a unit inner-sphere, and transform each canonical vertex
𝒗 according to:
false-positive
intersections
√︁
𝒗 ← 𝒗 2 log(𝜎/𝛼 min )𝑺𝑹𝑇 + 𝝁. (7)
Fig. 4. Proxy Geometries: Examples of BVH primitives considered.
Importantly, this scaling incorporates the opacity of the particles, so
that large nearly-transparent particles may have smaller bounding
efficiently scheduled onto the NVIDIA OptiX tracing model (Sec- primitives, resulting in adaptive clamping of the particles.
tion 4.2).
4.2 Ray Tracing Renderer
4.1 Bounding Primitives Motivation. Given the ability to cast rays against particles, volu-
Any ray-tracer must somehow insert the primitive particles into metric rendering as in Equation 6 requires accumulating the con-
a BVH and query the primitives intersected by a ray. The first tribution of particles along the ray in a sorted order. One naive ap-
challenge is then to decide how to insert particles into a BVH and proach within the NVIDIA OptiX programming model (Section 3.3)
conservatively test intersection against them. is to repeatedly cast the ray, process the nearest particle with a
The NVIDIA OptiX programming model supports three primi- closest-hit program, then re-cast the ray to find the next particle.
tive types which can be inserted into the BVH: triangles, spheres, Another is to traverse the scene only twice, once to estimate the
and custom primitives given by their axis-aligned bounding boxes transmittance function, and once to the compute the integral as in
(AABBs). These options admit many possible strategies to build a [Münstermann et al. 2018]. Both of these strategies are prohibitively
BVH over particles, such as constructing naive axis-aligned bounds expensive, due to the cost of traversing the scene.
as AABBs or spheres, or building bounding triangle meshes. These Our renderer builds on past approaches for tracing semi-transparent
strategies have a tradeoff between the cost to test intersection vs. the surfaces or particles: Knoll et al. [2019] repeated gather slabs of
tightness of the bound. For instance, simply intersecting a ray with particles and sort within each slab, while Brüll and Grosch [2020]
the AABB around each particle is fast, but a diagonally-stretched process all semi-transparent surfaces into a 𝑘-buffer, merging adja-
Gaussian particles will cause the traversal to have to evaluate many cent particles when the list overflows. As discussed in 2.3, because of
false-positive intersections which actually contribute almost noth- their approximations, these algorithms do not produce a consistent
ing to the rendering. None of these strategies necessarily affect the rendering, which prevents differentiation and generates artifacts.
appearance of the rendered image, but rather the computation speed
Algorithm. Figure 5, Figure 3, Procedure 1, and Procedure 2 sum-
and number of low-contribution particles needlessly processed. Bill-
marize our approach. To compute incoming radiance along each ray,
board mesh proxies are used elsewhere [Niedermayr et al. 2023],
a ray-gen program traces a ray against the BVH to gather the next
but do not apply in our general setting where rays may come from
𝑘 particles, using an any-hit program to maintain a sorted buffer of
any direction.
their indices. For efficiency, at this stage the particle response is not
Stretched Polyhedron Proxy Geometry. After experimenting with yet evaluated; all primitive hits are treated as intersected particles.
many variants (Section 5.2.1), we find it most effective to encapsulate The ray-gen program then iterates through the sorted array of prim-
particles in a stretched regular icosahedron mesh (Figure 4), which itive hits, retrieves the corresponding particle for each, and renders
tightly bounds the particle and benefits from hardware-optimized them according to Equation 6. The process then repeats, tracing a
ray-triangle intersections. A hit against any front-facing triangle of new ray from the last rendered particle to gather the next 𝑘 particles.
6 • Moenne-Loccoz, Mirzaei et al.

Ray
Ray Chunk Boundaries
Gaussian Center
Max Response Along Ray Procedure 1 Ray-Gen(𝒐, 𝒅,𝑇min, 𝛼 min, 𝑘, 𝜏SceneMin, 𝜏SceneMax )
Input: ray origin 𝒐, ray direction 𝒅, min transmittance 𝑇min , min
particle opacity 𝛼 min , hit buffer size 𝑘, ray scene bounds
𝜏SceneMin and 𝜏SceneMax
Output: ray incoming radiance 𝑳, ray transmittance 𝑇
1: 𝑳 ← (0., 0., 0.) ⊲radiance
2: 𝑇 ← 1. ⊲transmittance
3: 𝜏curr ← 𝜏SceneMin ⊲Minimum distance along the ray
4: while 𝜏curr < 𝜏SceneMax and 𝑇 > 𝑇min do
⊲Cast a ray to the BVH for the next 𝑘 hits, sorted
5: H ← TraceRay(𝒐 + 𝜏curr 𝒅, 𝒅, 𝑘)
6:
7: for (𝜏hit, 𝑖 prim ) in H do ⊲Render this batch of hits
Fig. 5. Rendering: on each round of tracing, the next 𝑘 closest hit particles 8: 𝑖 particle ← GetParticleIndex(𝑖 prim )
are collected and sorted into depth order along the ray, the radiance is 9: 𝛼 hit ← ComputeResponse(𝒐, 𝒅, 𝑖 particle ) ⊲𝜎𝜌 (𝒐 + 𝜏𝒅)
computed in-order, and the ray is cast again to process the next chunk.
10: if 𝛼 hit > 𝛼 min then
11: 𝑳 hit ← ComputeRadiance(𝒐, 𝒅, 𝑖 particle ) ⊲Refer to
The process terminates once all particles intersecting the ray are Equation 3 for SH evaluation
processed, or early-terminates as soon as enough particle density 12: 𝑳 ← 𝑳 + 𝑇 ∗ 𝛼 hit ∗ 𝑳 hit
is intersected to reach a predefined minimum transmittance 𝑇min . 13: 𝑇 ← 𝑇 ∗ (1 − 𝛼 hit )
Compared to past approaches this renderer allows for processing 14: 𝜏curr ← 𝜏hit ⊲Resume tracing from last hit
the intersection in a consistent order, without missing any particle 15: end while
nor approximating the transmittance. 16: return 𝑳, 𝑇
Nonetheless, this proposed algorithm is just one of many possible
variants, chosen for performance after extensive benchmarking.
See Section 5.2 for timings and ablations against a selection of Procedure 2 Any-Hit(𝜏hit, 𝑖 prim, H, 𝑘)
alternatives considered; we find that subtle changes to the algorithm
Input: hit location 𝜏hit , primitive index 𝑖 prim , hit array H , hit buffer
have a dramatic effect of speed and quality on densely-clustered
multi-view scenes. size 𝑘
Output: the hit array H may be updated in-place with a new entry
4.3 Evaluating Particle Response 1: h ← (𝜏hit , 𝑖 prim )
2: for 𝑖 in 0 . . . 𝑘-1 do ⊲insertion sort into hit array
After identifying ray-particle inter- maximum
orthogonal 3: if H [𝑖].𝜏hit < ℎ.𝜏hit then
sections, we must choose how to com- response
projection 4: swap(H [𝑖], ℎ)
pute the contribution of each particle
to the ray. As with prior work, we 5: ⊲ignore 𝑘-closest hits to prevent the traversal from stopping
take a single sample per particle, but 6: if 𝜏hit < H [𝑘 − 1].𝜏hit then
we still must choose at what distance bounding primitive 7: IgnoreHit()
intersection
𝜏 along the ray to evaluate that sam-
ple. Knoll et al. [2019] orthogonally project the center of the particle
on to the ray; this strategy is reasonable for isotropic particles,
but can lead to significant error for stretched anisotropic parti- 4.4 Differentiable Ray Tracing and Optimization
cles. Instead, we analytically compute a sample location 𝜏max =
Differentiable Rendering. Beyond forward-rendering of particle
argmax𝜏 𝜌 (𝒐 + 𝜏𝒅), the point of maximum response from the parti-
scenes, our ray tracing renderer is also differentiable, to support
cle along the ray. For Gaussian particles, this becomes
optimizing particle scenes from observed data. To backpropagate
(𝝁 − 𝒐)𝑇 𝚺 −1 𝒅 −𝒐𝑇𝑔 𝒅𝑔 (i.e., reverse-mode differentiate) through the renderer with respect
𝜏max = = (8)
𝒅𝑇 𝚺 −1 𝒅 𝒅𝑔𝑇 𝒅𝑔 to particle parameters, we first perform an ordinary forward-pass
render and compute the desired objective functions. Then, in the
where 𝒐𝑔 = 𝑺 −1 𝑹𝑇 (𝒐 − 𝝁) and 𝒅𝑔 = 𝑺 −1 𝑹𝑇 𝒅. backward pass we re-cast the same rays to sample the same set of
Note that this strategy incurs a slight approximation in the or- particles in order, computing gradients with respect to each shading
dering: the particle hits are integrated in the order of the bounding expression and accumulating gradients in shared buffers with atomic
primitive intersections instead of the order of the sample locations. scatter-add operations. We implemented all derivative expressions
However, we empirically confirmed that this approximation does by hand in an NVIDIA OptiX ray-gen program which is structurally
not lead to any substantial loss in the quality of the end result. similar to Procedure 1.
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 7

Optimization. To fit particle scenes using our ray tracer, we adopt


the optimization scheme of Kerbl et al. [2023], including pruning,
cloning and splitting operations. One significant change is needed:
Kerbl et al. [2023] track screen-space gradients of particle positions 3D Gaussian Generalized Gaussian (GG2)

as a criteria for cloning and splitting, but in our more-general setting,


screen space gradients are neither available nor meaningful—instead,
Kernelized Surface (SGG2) Cosine Wave Modulation (CSGG2)
we use gradients in 3D world-space for the same purpose. Recent
(a) Particle Kernel Functions (b) Kernelized Surface Particles Reconstruction
work has proposed many promising extensions to the optimization
scheme of Kerbl et al. [2023]. While our ray tracer is generally
compatible with any of these extensions, we stay faithful to the Fig. 6. Particle Kernel Functions: (a) In addition to 3D Gaussians, in this
original approach for the sake of consistent comparisons. It should work we investigated three other particle types: the generalized Gaussian
also be noted that as particles are updated during optimization, the (GG2), kernelized surface (SGG2) and cosine wave modulation (CSGG2)
ray tracing BVH must be regularly rebuilt (see Figure 8, bottom left particles. (b) Shows radiance and normal reconstructions obtained with the
for BVH build time). kernelized surface particles for two scenes.

Training with Incoherent Rays. Optimization in computer vision


often benefits from stochastic descent, fitting to randomly-sampled 5 EXPERIMENTS AND ABLATIONS
subsets of a problem on each iteration. However, differentiable ras- In this section we evaluate the proposed approach on several stan-
terization can only efficiently render whole images or tiles, and thus dard benchmark datasets for quality and speed, and perform ablation
efficient stochastic optimization over the set of pixels in a scene is studies on key design choices in Section 5.2. Additional details on
not possible. In our ray tracer, we are free to train with stochastically- experiments and implementation can be found in the appendix.
sampled rays, drawn at random or according to some importance
sampling during training, see Section 5.1. Note that when stochastic Method Variants. In the experiments that follow, we will refer
sampling is used, window-based image objectives such as SSIM to two variants of our method. The Ours (reference) variant corre-
cannot be used. sponds to [Kerbl et al. 2023] as closely as possible. It employs regular
3D Gaussian particles, and leaves the optimization hyperparameters
4.5 Particle Kernel Functions unchanged. We treat this as a high-quality configuration. The Ours
variant is adapted based on the experiments that follow, improving
Our formulation does not require the particles to have a Gauss-
runtime speed at a slight expense of quality. It uses degree-2 gen-
ian kernel, enabling the exploration of other particle variants. We
eralized Gaussian particles, a density learning rate to 0.09 during
consider a general particle defined by its kernel function 𝜌ˆ (𝒙). In ad-
optimizing, as well as optimizing with incoherent rays in a batch
dition to the standard Gaussian, we investigate three other variants,
size of 219 starting after 15,000 training iterations.
visualized in Figure 6:
• The standard 3D Gaussian kernel given in Equation 1 as 5.1 Novel View Synthesis Benchmarks
− (𝒙 −𝝁 )𝑇 𝚺−1 (𝒙 −𝝁 ) Baselines. There is a significant amount of recent and ongoing
𝜌ˆ (𝒙) = 𝜎𝑒 , research on scene representation. We include comparisons to several
representative well-known methods, including 3DGS [Kerbl et al.
• Generalized Gaussians of degree 𝑛 (we use 𝑛 = 2):
2023], INGP [Müller et al. 2022], and MipNeRF360 [Barron et al.
𝑇 −1 2022], as a standard for comparison. The latter two are widely-
𝜌ˆ𝑛 (𝒙) = 𝜎𝑒 − ( (𝒙 −𝝁 ) 𝚺 (𝒙 −𝝁 ) ) .
𝑛
(9)
used ray-marching methods that, like this work, do not have the
• Kernelized surfaces: 3D Gaussians with a null 𝒛 scale as in [Huang limitations of rasterization. We additionally compare with the non-
et al. 2024]. neural method of Plenoxels [Sara Fridovich-Keil and Alex Yu et al.
• Cosine wave modulations: 2022].
Evaluation Metrics. We evaluate the perceptual quality of the
𝜌ˆ𝑐 (𝒙) = 𝜌ˆ (𝒙)(0.5 + 0.5𝑐𝑜𝑠 (𝜓 𝑹𝑇 𝑺 −1 (𝒙 − 𝝁))) (10)
novel-views in terms of peak signal-to-noise ratio (PSNR), learned
with 𝜓 an optimizable parameter. perceptual image patch similarity (LPIPS), and structural similarity
(SSIM) metrics. To evaluate the efficiency, we measure GPU time re-
Comparative evaluations with these particles are presented in Ta- quired for rendering a single image without the overhead of storing
ble 3. The generalized Gaussian kernel function defines denser par- the data to a hard drive or visualizing them in a GUI. Specifically,
ticles, reducing the number of intersections and increasing the per- we report the performance numbers in terms of frames-per-second
formance by a factor of 2 compared to standard Gaussians, see measured on a single NVIDIA RTX 6000 Ada. For all evaluations,
Section 5.2.3 for more discussion. The kernelized surface variant we use the dataset-recommended resolution for evaluation.
defines flat particles with well-defined normals, which can be en-
capsulated by a two triangle primitive (Section 4.1) well-adapted to 5.1.1 MipNeRF360. MipNeRF360 [Barron et al. 2022] is a challeng-
our tracing model. Finally, the modulation by a cosine wave aims to ing dataset consisting of large scale outdoor and indoor scenes. In
model a particle with spatially varying radiance. our evaluation, we use the four indoor (room, counter, kitchen,
8 • Moenne-Loccoz, Mirzaei et al.

Ground Truth INGP 3DGS Ours (reference) Ours

Fig. 7. Novel-View Synthesis: Qualitative comparison of our novel-view synthesis results relative to baselines (insets (•) show per-result closeups). For
fairness, this comparison uses the same test views picked by [Kerbl et al. 2023]. Additional comparisons with [Barron et al. 2022] are included in the appendix.
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 9

Table 1. Results for our approach and baselines on a variety of novel view synthesis benchmarks.

MipNeRF360 Tanks & Temples Deep Blending


Method\Metric PSNR↑ SSIM↑ LPIPS↓ Mem. ↓ PSNR↑ SSIM↑ LPIPS↓ Mem. ↑ PSNR↑ SSIM↑ LPIPS↓ Mem. ↓
Plenoxels 23.63 0.670 0.443 2.1GB 21.08 0.719 0.379 2.3GB 23.06 0.795 0.510 2.7GB
INGP-Base 26.43 0.725 0.339 13MB 21.72 0.723 0.330 13MB 23.62 0.797 0.423 13MB
INGP-Big 26.75 0.751 0.299 48MB 21.92 0.745 0.305 48MB 24.96 0.817 0.390 48MB
MipNeRF360 29.23 0.844 0.207 8.6MB 22.22 0.759 0.257 8.6MB 29.40 0.901 0.245 8.6MB
3DGS (paper) 28.69 0.870 0.182 734MB 23.14 0.841 0.183 411MB 29.41 0.903 0.243 676MB
3DGS (checkpoint) 28.83 0.867 0.228 763MB 23.35 0.837 0.222 422MB 29.43 0.898 0.314 704MB
Ours (reference) 28.88 0.871 0.179 387MB 23.03 0.853 0.158 519MB 29.89 0.908 0.234 329MB
Ours 28.71 0.854 0.202 383MB 23.20 0.830 0.186 489MB 29.23 0.900 0.242 287MB

bonsai) and three outdoor (bicycle, garden, stump) scenes with- Table 2. Rendering performance: rasterization v.s. ray tracing.
out licensing issues. In line with prior work, we used images down- FPS↑
sampled by a factor two for the indoor and a factor four for the Method MipNeRF360 Tanks & Temples Deep Blending
outdoor scenes in all our evaluations. 3DGS (checkpoint) 238 319 267
Table 1 shows quantitative results, while novel-views are qual- Ours (reference) 55 143 77
itatively compared in Figure 7. In terms of quality, our method Ours 78 190 119
performs on par or slightly better than 3DGS [Kerbl et al. 2023] and
other state-of-the-art methods.
For this dataset, we also compare our method against the recent Both versions of our method outperform all the baselines in terms
top-tier method of Zip-NeRF [Barron et al. 2023] which achieves of PSNR. In fact, Ours outperforms Ours (reference) on seven out of
30.38 PSNR. In terms of runtime (Table 2), at 78 FPS our efficient eight scenes. We conjecture this is due to the simplicity of scenes
ray tracing implementation is approximately three times slower which are well represented with less hits, and the positive contribu-
than rasterization (238 FPS), while maintaining interactive speeds tion of training with incoherent rays. On these simpler scenes with
compared to high-quality ray-marching based works MipNeRF360 lower resolution images, our method is capable of rendering novel
and Zip-NeRF (<1 FPS). views at 450FPS and is only 50% slower than 3DGS.

5.1.2 Tanks & Temples. Tanks & Temples dataset contains two 5.2 Ray Tracing Analysis and Ablations
large outdoor scenes (Truck and Train) with a prominent object in We evaluate the performance of the proposed ray tracer and com-
the center, around which the camera is rotating. These scenes are pare to alternatives. Experiments are evaluated on the union of all
particularly challenging due to the illumination differences between validation datasets from Section 5.1. We measure forward rendering
individual frames as well as the presence of dynamic objects. time, which we observed to correlate closely with the per-iteration
Similar to the results on MipNeRF360 dataset, our method again time for the backward pass.
performs on par with the state-of-the-art methods in terms of quality,
while the speed is approximately 1.7 times slower than 3DGS at 190 5.2.1 Particle Primitives. We first consider different bounding prim-
FPS. Qualitative results are depicted in Figure 7. On this dataset, itive strategies as discussed in Section 4.1. The primitives evaluated
Ours achieves better PSNR than our Ours (reference), but is still are:
worse in terms of LPIPS and SSIM. We hypothesize that this is due
• Custom primitive AABBs: bounding box primitive, see Fig-
to the lack of SSIM loss supervision when training the model with
ure 4 left.
incoherent rays.
• Octahedron: an eight-faced regular polyhedron mesh.
• Icosahedron: a twenty-faced regular polyhedron mesh.
5.1.3 Deep Blending. Following Kerbl et al. [2023], we use two
• Icosahedron + unclamped: icosahedron without adaptive
indoor scenes Playroom and DrJohnson from the Deep Blending
clamping.
dataset. Table 1 shows that our reference implementation Ours
(reference) outperforms all baselines across all qualitative metrics. Scales are determined as in Equation 7, except the unclamped variant
Different to other datasets, we observe a larger quality drop of Ours. which omits the opacity term in that expression.
This is a result of a quality drop on Playroom where we observed in- Figure 8 (bottom-left) shows the time to build a BVH relative
stability of the training with incoherent rays. We leave more detailed to the number of particles for the different primitives. For simple
investigation and parameter tuning of incoherent rays training for AABBs, the build time is almost constant whereas for the more
future work. complex icosahedron based primitives, the build time is close to
linear with more than 30ms per millions of particles. The same figure
5.1.4 NeRF Synthetic. NeRF Synthetic is a commonly used syn- also gives the framerate vs. the number of particles for different
thetic object-centring dataset introduced by Mildenhall et al. [2020]. primitives. First, the number of particles does not strictly determine
The eight scenes with synthetic objects were rendered in Blender the performance. Second, more complex primitives with tighter
and display strong view-dependent effects and intricate geometry bounding envelopes yield higher framerates, and adaptive clamping
structures. See Table 4 in the appendix for a per-scene breakdown. based on opacity has a large positive effect.
10 • Moenne-Loccoz, Mirzaei et al.

300 300 10
Table 3. Quality and speed tradeoffs for various particle kernel functions.
250 250 8

Over-traversed hits
Tanks & Temples Deep Blending 200 200
6
PSNR↑ FPS↑ PSNR↑ FPS↑

FPS

FPS
Particle\Metric 150 150
4
Gaussian (reference) 23.03 143 29.89 77 100 100

Generalized Gaussian (𝑛 = 2) 22.68 277 29.74 141 50 50 2

2D Gaussians 22.70 241 29.74 122 0 0 0


Cosine wave modulation 22.77 268 29.79 126 24 25 26 27 28 29 30 31 0 5 10 15 20 25 30
PSNR Hits array size
Baseline SLAB MLAT Performance False-rejected hits
Ours 2x2 Tiles Ours Stoch. Ours False-accepted hits

125 600

BVH build [ms]


100
75 500
5.2.2 Tracing Algorithms. We consider several alternatives of the 50
25
400

FPS
proposed ray tracer from Section 4.2, both comparisons to prior 600 300

work and variants of our method. The evaluated approaches are: 450 200

FPS
300
100
150
• Naive closest-hit tracing: repeated closest-hit ray-tracing to 0 0
1e6
traverse every particle hitting the ray in depth order. 0.0 0.5 1.0 1.5 2.0 2.5 3.0 0 5 10 15 20 25 30 35
Number of particles Mean hits per ray
• Slab tracing [Knoll et al. 2019] (SLAB): tracing one ray Custom Icosahedron
Gaussian Generalized Gaussian
Octahedron Icosahedron Unclamped
per slab, order independent collection of the 𝑘-first hits in
the any-hit program, sorting and integrating the hits in the Fig. 8. Quantitative Ablation. Top left: comparison of the different tracing
ray-gen program. algorithms on the combination of our datasets. Top right: Impact of the hit
• Multi-layer alpha tracing [Brüll and Grosch 2020] (MLAT): payload buffer size on our proposed tracing algorithm. Bottom left: Impact
tracing a single ray with in depth order collection of the hits of the different primitives on both the BVH building time and the FPS.
Bottom right: Mean number of hits vs. mean FPS for every sequence of our
and merging the closest hits when the 𝑘 buffer is full in the
dataset.
any-hit program.
• Our proposed method: tracing a dynamic number of rays
with in-order collection of the hits, stopping to evaluate con-
tributions when the 𝑘 buffer is full in the any-hit program. Figure 8 (bottom-right) shows the mean-hits number versus the
• Ours + tiled tracing: tracing one ray per 𝑁 × 𝑁 tile, but still performance for the Gaussian kernel and the generalized Gaussian
evaluating appearance per pixel, akin to tile-based rasteriza- kernel of degree 2. It reaffirms that the performance depends on the
tion. number of hits rather than the number of particles, as noted previ-
• Ours + stochastic depth sampling: tracing a single ray ously. This explains the source of the speedup for the generalized
with in depth order collection of the 𝑘 first accepted sam- Gaussian kernel, as the sharper extent reduces the number of hits.
ples. Samples are accepted based on the importance sampling See Figure 9 for a visual plot.
𝑞(𝒙) = 𝜌ˆ (𝒙).
5.2.4 Hit Buffer Size. Figure 8 (top-right) measures the effect of
For each algorithms with a choice of parameters (size of the array, the particle buffer size 𝑘, which determines how many particle hits
number of slabs, or number of samples), we perform a parameter are gathered during each raycast before stopping to evaluate their
sweep and present the best-performing setting. response. False rejected hits are hits which are traversed, but not
The performance relative to the accuracy of these implementa- collected into the buffer because it is full with closer hits; these hits
tions are shown in the top-left of Figure 8. Naive closest-hit tracing often must be re-traversed later. False accepted hits are hits which are
is almost twice as slow as our method, due to over-traversal of the gathered into the buffer, but ultimately do not contribute to radiance
BVH. Slab tracing and multi-layer alpha tracing are designed to because the transmittance threshold is already met. Both of these
minimize over-traversal and hence achieve much better runtime false hits harm performance, and choosing the particle batch size is
performance, but this speed comes from approximate image forma-
tion (ordering approximation for MLAT, under-sampling particles
for SLAB), and the accuracy of these methods is substantially lower.
In the differentiable setting, we find that these these approxima-
tions make those methods unusable for optimizing scenes. Adding
tile-based rendering to our approach yields a promising speedup, at
the cost of a small approximation. We do not see immediate benefit
from stochastic depth sampling, because most of the computation
has to be done in the any-hit program, preventing a good balance
of the tracing workload.
0 10 20 30 40 50
ray hit counts
5.2.3 Particle Kernel Function. In Section 4.5 we consider particle
kernel functions beyond Gaussians. Table 3 gives results; notably Fig. 9. Ray Hits for Kernel Functions: Visualization of the number of
generalized Gaussians with 𝑛 = 2 significantly increase ray tracing per-ray particles hits for the Gaussian (left) and for the generalized Gaussian
speed at only a small cost of quality. kernel function of degree 2 (right) (• represents no hits).
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 11

Ground Truth Ours - 0 Iterations (0%) Ours - 600 Iterations (2%) Ours - 2000 Iterations (6.7%) 3DGS
PSNR: 18.67 PSNR: 26.15 PSNR: 26.80 PSNR: 27.41

PSNR: 23.37 PSNR: 30.52 PSNR: 31.19 PSNR: 30.32

PSNR: 18.43 PSNR: 24.54 PSNR: 25.15 PSNR: 25.19

Fig. 10. 3DGS Finetuning: Qualitative results of finetuned models from pretrained 3DGS [Kerbl et al. 2023] checkpoints after different numbers of iterations.

0.5
particles. Precisely, we maintain an extra acceleration structure con-
0.0
sisting only of mesh faces for additional inserted geometry. When
∆ PSNR (ours - 3DGS)

0.5
casting each ray in Procedure 1, we first cast rays against inserted
1.0
meshes; if a mesh is hit, we render all particles only up to the hit, and
1.5
then compute a response based on the material. For refractions and
2.0
reflections, this means continuing tracing along a new redirected
2.5
ray according to the laws of optics. For non-transparent diffused
3.0
0 250 500 750 1000 1250 1500 1750 2000
meshes, we compute the color and blend it with the current ray
Number of iterations radiance, then terminate the ray.
MipNeRF360 Tanks & Temples Deep Blending

Depth of Field. Following [Müller et al. 2022], we simulate depth


Fig. 11. Finetuning Pretrained 3DGS Models: After only 500 iterations of field by progressively tracing multiple independent ray samples
of finetuning, we can recover most of the perceptual quality of 3DGS [Kerbl
per pixel (spp), weighted together with a moving average to denoise
et al. 2023]. After 2k iterations we match or outperform 3DGS across all
datasets.
the output image. The examples in Figures 2 and 12 use 64-256
spp, although convergence is often reached with fewer samples by
selecting subsamples with low discrepancy sequences [Burley 2020].
a tradeoff between them. We find 𝑘 = 16 to offer a good compromise
Artificial Shadows. Even in radiance field scenes with baked-in
and use it in all other experiments.
lighting, simple shadow effects can be emulated by casting a ray
6 APPLICATIONS
towards a point or mesh emitter, and artificially darkening the
contribution from that point if the light is not visible. We adopt
Most importantly, efficient differentiable ray tracing enables new this approach, casting shadow rays after computing the directional
applications and techniques to be applied to particle scene represen- contribution from each particle.
tations.

6.1 Ray-Based Effects 6.2 Instancing


First, we the radiance field rendering pipeline with a variety of visual In rendering, instancing is a technique to render multiple trans-
effects which are naturally compatible with ray tracing (Figure 2 formed copies of an object with greatly reduced cost. Although
and 12). Here we demonstrate only manually-specified forward rendering libraries may support some form of instancing in the
rendering, although inverse rendering in concert with these effects context of rasterization, the technique is particularly effective for
is indeed supported by our approach, and is a promising area for ray tracing. This is because repeated copies of an object can be
ongoing work. stored as linked references in subtrees of the BVH, without actually
duplicating the geometry. This allows for scaling to 100s or 1000s of
Reflections, Refractions and Inserted Meshes. Optical ray effects are instanced objects at little additional cost—the same is not possible
supported by interleaved tracing of triangular faces and Gaussian with rasterization. Our efficient ray tracer enables particle scene
12 • Moenne-Loccoz, Mirzaei et al.

Fig. 12. Rendering Effects: The ray traced nature of our reconstructions allows seamless integration with traditional ray traced operations for reflecting and
refracting rays, as well as casting shadows on nearby particles, as well as applying camera effects.

data to be instanced, as shown in Figure 13 where we crop an object


from a fitted scene and render 1024 copies of it at 25 FPS.

6.3 Denoising and Stochastic Sampling


In ray tracing more broadly, research on stochastic integration tech-
niques is key to highly sample-efficient yet perceptually compelling
renders. As a small demonstration, we show how our approach can
be combined with stochastic sampling and denoising.
As discussed in Section 5.2.2, our approach may be extended to
stochastic-sampling by rejecting the hits received in the any-hit
program based on the importance sampling distribution 𝑞 = 𝜌ˆ (𝒙).
Since traversal stops as soon as the 𝑘-closest accepted samples are
collected, this modification noticeably improves performance (see
Fig. 13. Instancing: 1024 instances of the Tank & Temples Truck, rendered
Figure 8 top-left). This performance comes at a quality cost, but at more than 25 FPS.
as shown in Figure 14, the resulting noise has statistics that an
off-the-shelf denoiser can easily remove.
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 13

correctly reconstructing important geometries, such as the signpost


in Figure 16.

7 DISCUSSION
7.1 Differences Between Ray Tracing and Rasterization
Here, we recap key differences between our ray tracer and the
Gaussian splatting rasterizer proposed by Kerbl et al. [2023].
Generality. Splat rasterization accelerates rendering by process-
ing a screen grid of pixel rays emanating from a single viewpoint in
16𝑥16 tiles, whereas ray tracing uses a BVH and can render along
arbitrary distributions of rays from any direction.
Primary vs. General Rays. As in graphics more broadly, ray tracing
Fig. 14. Stochastic Sampling: Left, scene rendered with our proposed has significant benefits over rasterization to model general lighting
algorithm. Center, rendered with stochastic sampling (4 samples). Right,
and image formation. In this work, we demonstrate a variety of
denoised with the NVIDIA OptiX denoiser.
effects such as reflection, refraction, depth of field, and artificial
shadows enabled by ray tracing (Section 6.1). In addition, we note
that differentiable ray tracing opens the door to further research on
6.4 Complex Cameras and Autonomous Vehicle Scenes
global illumination, inverse lighting, and physical BSDFs.

Ray tracing makes it easy, efficient, and accurate to render from Complex Cameras. Using per-pixel rays, ray tracing can easily
exotic cameras which are far from ideal pinholes, such as highly- model more general image formation processes that exhibit non-
distorted fisheye cameras and those with rolling shutter effects linear optical models such as highly-distorted and high-FOV fisheye
(Figure 15). While optical distortions for low-FOV lenses can be lenses, as well as time-dependent effects like rolling shutter dis-
tackled to some extent by image rectification, and rolling shutter tortions, which originate from rows/columns exposed at different
distortions can be approached by associating rasterized tiles to timestamps (cf. [Li et al. 2024b]). These are important for robotics
row/columns with consistent timestamps, both workarounds can’t (Section 6.4), yet difficult or impossible to model with tile-based
be applied simultaneously, as image rectification distorts the sets of rasterization.
concurrently measured pixels in a non-linear way. In ray tracing, Speed. Although our ray tracing render achieves realtime perfor-
handling complex cameras simply means generating each ray with mance, rasterization remains faster than ray tracing for the basic
source and direction which actually correspond to the underlying case of rendering primary rays from pinhole cameras (see Table 2).
camera, even if those rays may be incoherent and lack a shared
origin. Sub-Pixel Behavior. Splat rasterization implicitly applies a pixel-
scale convolution to Gaussians [Zwicker et al. 2001], whereas our
Autonomous Vehicles. The imaging systems used on autonomous ray tracer truly point-samples the rendering function and has no
vehicle (AV) platforms and other robot systems often incorporate such automatic antialiasing. This may lead to differences of ren-
such cameras, and it is very important to reconstruct and render dered appearance for subpixel-skinny Gaussian particles. However,
them accurately in those applications. Figure 16, gives an example point-sampled rendering is well-suited to modern denoisers (see Sec-
of an autonomous driving scene reconstructed from a side-mounted tion 6.3).
camera, which exhibits both apparent intrinsic camera and rolling
Interoperability. It is possible to directly render scenes trained
shutter distortion effects.
with the rasterizer under the ray tracing renderer, however due to
To further highlight the importance of accurately handling these
subtle differences noted above, there will be a noticeable drop in
effects, we perform a quantitative evaluation of our method against
quality when directly switching between renderers. This can be
its rasterization equivalent 3DGS [Kerbl et al. 2023] on autonomous
quickly remedied with fine-tuning (see Figure 11).
driving scenes. We select 9 scenes from the Waymo Open Perception
dataset [Sun et al. 2020] with no dynamic objects to ensure accurate Approximations. Rasterization makes an approximation by eval-
reconstructions. Both methods are trained with the images captured uating directional appearance through the spherical harmonics 𝜷
by the camera mounted on the front of the vehicle to reconstruct from a single ray direction, meaning each particle has constant ap-
the scene. We make several changes to the training protocol to pearance direction in all pixels of an image. To support arbitrary
adapt it to this data, including incorporating lidar depth, see the distributions of rays in our ray tracer, each particle is evaluated
appendix for details. For the case of 3DGS, we rectify the images and exactly with the appropriate incoming ray direction. Additionally,
ignore the rolling shutter effects, while with our tracing algorithm rasterization approximates depth ordering in 16x16 tiles.
we can make use of the full camera model and compensate for
the rolling shutter effect (see Figure 16). Ray tracing achieves a 7.2 Limitations and Future Work
rectified PSNR of 29.99 on this benchmark, compared to 29.83 for Our ray tracer is carefully designed to make use of hardware acceler-
ordinary 3DGS—the improvement is modest, but it corresponds to ation and offers significant speedup over baseline implementations
14 • Moenne-Loccoz, Mirzaei et al.

𝑓4 𝑓3 𝑓2 𝑓1 𝑓0
Perspective GT (Unseen)
Camera Motion Directions

Reconstructions (Novel Views)


PSNR:40.53
Fisheye Inputs Reconstruction
Reconstruction(Perspective View)
(Perspective) Ours PSNR:25.47 𝑓𝑛+1 𝑓𝑛+2 𝑓𝑛+3 𝑓𝑛+4 𝑓𝑛+5

(a) Nonlinear Camera Models (b) Rolling Shutter Motion Compensation


Fig. 15. Complex Cameras: (a) Compared to rasterization-based approaches, our ray tracing-based formulation naturally supports complex camera models
as inputs like distorted fisheye lenses (left), which can be re-rendered using different camera models like regular perspective cameras (right), achieving high
reconstruction quality relative to unseen references (see insets (•) - this synthetic cozyroom scene is by [Ma et al. 2021]). (b) Ray tracing also naturally enables
compensating for time-dependent effects like rolling shutter imagine sensors, which induce distortions due to sensor motion. This effect is illustrated on the
left by multiple different frame tiles 𝑓𝑖 of a single solid box rendered by a left- and right-panning rolling shutter camera with a top-to-bottom shutter direction.
By incorporating time-dependent per-pixel poses in the reconstruction, our method faithfully recuperates the true undistorted geometry (right).

reconstruction from computer vision with the formulations for pho-


Distorted Inputs torealistic rendering from computer graphics.

Reconstruction (Perspective) REFERENCES


Maksim Aizenshtein, Niklas Smal, and Morgan McGuire. 2022. Wavelet Transparency.
CoRR abs/2201.00094 (2022). arXiv:2201.00094 https://arxiv.org/abs/2201.00094
Kara-Ali Aliev, Artem Sevastopolsky, Maria Kolos, Dmitry Ulyanov, and Victor Lem-
pitsky. 2020. Neural point-based graphics. In Computer Vision–ECCV 2020: 16th
European Conference, Glasgow, UK, August 23–28, 2020, Proceedings, Part XXII 16.
Springer, 696–712.
Jonathan T. Barron, Ben Mildenhall, Matthew Tancik, Peter Hedman, Ricardo Martin-
Brualla, and Pratul P. Srinivasan. 2021. Mip-NeRF: A Multiscale Representation for
Reconstruction (Fisheye, Static Pose, PSNR:28.05) Reconstruction Input
Anti-Aliasing Neural Radiance Fields. ICCV (2021).
Fig. 16. AV Scene Reconstruction: Real-world AV and robotics applica-
Jonathan T. Barron, Ben Mildenhall, Dor Verbin, Pratul P. Srinivasan, and Peter Hedman.
2022. Mip-NeRF 360: Unbounded Anti-Aliased Neural Radiance Fields. CVPR (2022).
tions often have to respect both distorted intrinsic camera models and are, Jonathan T. Barron, Ben Mildenhall, Dor Verbin, Pratul P. Srinivasan, and Peter Hedman.
at the same time, affected by time-dependent effects like rolling shutter 2023. Zip-NeRF: Anti-Aliased Grid-Based Neural Radiance Fields. arXiv (2023).
distortions as frames are exposed at high sensor speeds. Our ray tracing- Louis Bavoil, Steven P. Callahan, Aaron Lefohn, João L. D. Comba, and Cláudio T. Silva.
2007. Multi-fragment effects on the GPU using the k-buffer (I3D ’07). Association
based reconstruction is well-suited to handle both challenges simultaneously, for Computing Machinery, New York, NY, USA, 97–104. https://doi.org/10.1145/
which we illustrated by an example of a side-facing top-to-bottom rolling 1230100.1230117
shutter camera on an AV vehicle: the top inset (•) depicts faithful removal Felix Brüll and Thorsten Grosch. 2020. Multi-Layer Alpha Tracing. In Vision, Modeling,
of the intrinsic camera model distortion by rendering with an undistorted and Visualization, Jens Krüger, Matthias Niessner, and Jörg Stückler (Eds.). The
camera, while the bottom inset (•) shows our ability to remove the apparent
Eurographics Association. https://doi.org/10.2312/vmv.20201183
Chris Buehler, Michael Bosse, Leonard McMillan, Steven Gortler, and Michael Cohen.
rolling-shutter distortions of the inputs by rendering from a static camera 2001. Unstructured Lumigraph Rendering. In Proceedings of the 28th Annual Confer-
pose (linear indicators (•) exemplify the complex distortion of the inputs). ence on Computer Graphics and Interactive Techniques (SIGGRAPH ’01). Association
for Computing Machinery, New York, NY, USA, 425–432.
Brent Burley. 2020. Practical Hash-based Owen Scrambling. Journal of Computer Graph-
ics Techniques (JCGT) 10, 4 (29 December 2020), 1–20. http://jcgt.org/published/
(Figure 8), however ray tracing is still slower than rasterization 0009/04/01/
when rendering from a pinhole camera. Additionally, the need to Abe Davis, Marc Levoy, and Fredo Durand. 2012. Unstructured Light Fields. Comput.
Graph. Forum 31, 2pt1 (2012), 305–314.
regularly rebuild the BVH during training incurs additional cost and Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. 1996. Modeling and Rendering
adds overhead to dynamic scenes. Nonetheless, our implementation Architecture from Photographs: A Hybrid Geometry- and Image-Based Approach.
is still fast enough for training and interactive rendering, and more In Proceedings of the 23rd Annual Conference on Computer Graphics and Interactive
Techniques (SIGGRAPH ’96). Association for Computing Machinery, 11–20.
importantly it opens the door to many new capabilities such as Daniel Duckworth, Peter Hedman, Christian Reiser, Peter Zhizhin, Jean-François Thib-
distorted cameras and ray-based visual effects (Section 6). See Sec- ert, Mario Lučić, Richard Szeliski, and Jonathan T. Barron. 2023. SMERF: Stream-
tion 7.1 for an in-depth discussion of the trade-offs of rasterization able Memory Efficient Radiance Fields for Real-Time Large-Scene Exploration.
arXiv:2312.07541 [cs.CV]
vs. ray tracing in this setting. Zhiwen Fan, Kevin Wang, Kairun Wen, Zehao Zhu, Dejia Xu, and Zhangyang Wang.
Looking forward, this work creates great potential for further 2023. LightGaussian: Unbounded 3D Gaussian Compression with 15x Reduction
and 200+ FPS. arXiv:2311.17245 [cs.CV]
research on inverse rendering, relighting, and material decomposi- Jian Gao, Chun Gu, Youtian Lin, Hao Zhu, Xun Cao, Li Zhang, and Yao Yao. 2023. Re-
tion on particle representations. Indeed, recent work in this direc- lightable 3D Gaussian: Real-time Point Cloud Relighting with BRDF Decomposition
tion [Gao et al. 2023; Liang et al. 2023], has relied on approximations and Ray Tracing. arXiv:2311.16043 (2023).
Steven J. Gortler, Radek Grzeszczuk, Richard Szeliski, and Michael F. Cohen. 1996. The
due to the lack of an efficient ray tracer. More broadly, there is Lumigraph. In Proceedings of the 23rd Annual Conference on Computer Graphics
much promising research to be done unifying advances in scene and Interactive Techniques (SIGGRAPH ’96). Association for Computing Machinery,
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 15

43–54. Tombari. 2024. RadSplat: Radiance Field-Informed Gaussian Splatting for Robust
Jeffrey P Grossman and William J Dally. 1998. Point sample rendering. In Rendering Real-Time Rendering with 900+ FPS. arXiv preprint arXiv:2403.13806 (2024).
Techniques’ 98: Proceedings of the Eurographics Workshop in Vienna, Austria, June Julian Ost, Issam Laradji, Alejandro Newell, Yuval Bahat, and Felix Heide. 2022. Neural
29—July 1, 1998 9. Springer, 181–192. point light fields. In Proceedings of the IEEE/CVF Conference on Computer Vision and
Antoine Guédon and Vincent Lepetit. 2023. SuGaR: Surface-Aligned Gaussian Splatting Pattern Recognition. 18419–18429.
for Efficient 3D Mesh Reconstruction and High-Quality Mesh Rendering. arXiv Panagiotis Papantonakis, Georgios Kopanas, Bernhard Kerbl, Alexandre Lanvin, and
preprint arXiv:2311.12775 (2023). George Drettakis. 2024. Reducing the Memory Footprint of 3D Gaussian Splatting.
Binbin Huang, Zehao Yu, Anpei Chen, Andreas Geiger, and Shenghua Gao. 2024. 2D In Proceedings of the ACM on Computer Graphics and Interactive Techniques, Vol. 7.
Gaussian Splatting for Geometrically Accurate Radiance Fields. SIGGRAPH (2024). Steven G. Parker, James Bigler, Andreas Dietrich, Heiko Friedrich, Jared Hoberock,
Pushkar Joshi, Mark Meyer, Tony DeRose, Brian Green, and Tom Sanocki. 2007. Har- David Luebke, David McAllister, Morgan McGuire, Keith Morley, Austin Robison,
monic Coordinates for Character Articulation. ACM Trans. Graph. 26, 3 (jul 2007), and Martin Stich. 2010. OptiX: A General Purpose Ray Tracing Engine. ACM Trans.
71–es. https://doi.org/10.1145/1276377.1276466 Graph. 29, 4, Article 66 (jul 2010), 13 pages. https://doi.org/10.1145/1778765.1778803
Michael M. Kazhdan, Matthew Bolitho, and Hugues Hoppe. 2006. Poisson Surface Hanspeter Pfister, Matthias Zwicker, Jeroen Van Baar, and Markus Gross. 2000. Surfels:
Reconstruction. In Proceedings of the Fourth Eurographics Symposium on Geometry Surface elements as rendering primitives. In Proceedings of the 27th annual conference
Processing (SGP ’06, Vol. 256). Eurographics Association, 61–70. on Computer graphics and interactive techniques. 335–342.
Michael M. Kazhdan and Hugues Hoppe. 2013. Screened poisson surface reconstruction. Christian Reiser, Stephan Garbin, Pratul P. Srinivasan, Dor Verbin, Richard Szeliski, Ben
ACM Trans. Graph. 32, 3 (2013), 29:1–29:13. Mildenhall, Jonathan T. Barron, Peter Hedman, and Andreas Geiger. 2024. Binary
Bernhard Kerbl, Georgios Kopanas, Thomas Leimkühler, and George Drettakis. 2023. Opacity Grids: Capturing Fine Geometric Detail for Mesh-Based View Synthesis.
3D Gaussian Splatting for Real-Time Radiance Field Rendering. ACM Transactions on SIGGRAPH (2024).
Graphics 42, 4 (July 2023). https://repo-sam.inria.fr/fungraph/3d-gaussian-splatting/ Christian Reiser, Songyou Peng, Yiyi Liao, and Andreas Geiger. 2021. KiloNeRF: Speed-
Bernhard Kerbl, Andreas Meuleman, Georgios Kopanas, Michael Wimmer, Alexandre ing up Neural Radiance Fields with Thousands of Tiny MLPs. In International
Lanvin, and George Drettakis. 2024. A Hierarchical 3D Gaussian Representation for Conference on Computer Vision (ICCV).
Real-Time Rendering of Very Large Datasets. ACM Transactions on Graphics 43, 4 Christian Reiser, Richard Szeliski, Dor Verbin, Pratul P Srinivasan, Ben Mildenhall,
(July 2024). https://repo-sam.inria.fr/fungraph/hierarchical-3d-gaussians/ Andreas Geiger, Jonathan T Barron, and Peter Hedman. 2023. Merf: Memory-efficient
Leonid Keselman and Martial Hebert. 2022. Approximate Differentiable Rendering radiance fields for real-time view synthesis in unbounded scenes. arXiv preprint
with Algebraic Surfaces. In European Conference on Computer Vision (ECCV). arXiv:2302.12249 (2023).
Leonid Keselman and Martial Hebert. 2023. Flexible techniques for differentiable Konstantinos Rematas, Andrew Liu, Pratul P. Srinivasan, Jonathan T. Barron, Andrea
rendering with 3d gaussians. arXiv preprint arXiv:2308.14737 (2023). Tagliasacchi, Thomas Funkhouser, and Vittorio Ferrari. 2022. Urban Radiance Fields.
Aaron Knoll, R. Keith Morley, Ingo Wald, Nick Leaf, and Peter Messmer. 2019. Efficient In Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition
Particle Volume Splatting in a Ray Tracer. Apress, Berkeley, CA, 533–541. https: (CVPR). 12932–12942.
//doi.org/10.1007/978-1-4842-4427-2_29 Kerui Ren, Lihan Jiang, Tao Lu, Mulin Yu, Linning Xu, Zhangkai Ni, and Bo Dai.
Georgios Kopanas, Julien Philip, Thomas Leimkühler, and George Drettakis. 2021. 2024. Octree-GS: Towards Consistent Real-time Rendering with LOD-Structured
Point-Based Neural Rendering with Per-View Optimization. Computer Graphics 3D Gaussians. arXiv preprint arXiv:2403.17898 (2024).
Forum (Proceedings of the Eurographics Symposium on Rendering) 40, 4 (June 2021). Liu Ren, Hanspeter Pfister, and Matthias Zwicker. 2002. Object space EWA surface
http://www-sop.inria.fr/reves/Basilic/2021/KPLD21 splatting: A hardware accelerated approach to high quality point rendering. In
Christoph Lassner and Michael Zollhöfer. 2021. Pulsar: Efficient Sphere-based Neural Computer Graphics Forum, Vol. 21. Wiley Online Library, 461–470.
Rendering. 2021 IEEE/CVF Conference on Computer Vision and Pattern Recognition Gernot Riegler and Vladlen Koltun. 2020. Free View Synthesis. In European Conference
(CVPR) (2021), 1440–1449. on Computer Vision.
Marc Levoy and Pat Hanrahan. 1996. Light Field Rendering. In Proceedings of the 23rd Gernot Riegler and Vladlen Koltun. 2021. Stable View Synthesis. In Proceedings of the
Annual Conference on Computer Graphics and Interactive Techniques (SIGGRAPH IEEE Conference on Computer Vision and Pattern Recognition.
’96). Association for Computing Machinery, 31–42. Darius Rückert, Linus Franke, and Marc Stamminger. 2022. Adop: Approximate dif-
Moyang Li, Peng Wang, Lingzhe Zhao, Bangyan Liao, and Peidong Liu. ferentiable one-pixel point rendering. ACM Transactions on Graphics (ToG) 41, 4
2024b. USB-NeRF: Unrolling Shutter Bundle Adjusted Neural Radiance Fields. (2022), 1–14.
arXiv:2310.02687 [cs.CV] Marco Salvi and Karthikeyan Vaidyanathan. 2014. Multi-layer alpha blending. Pro-
Max Zhaoshuo Li, Thomas Müller, Alex Evans, Russell H. Taylor, Mathias Unberath, ceedings of the 18th meeting of the ACM SIGGRAPH Symposium on Interactive 3D
Ming-Yu Liu, and Chen-Hsuan Lin. 2023. Neuralangelo: High-Fidelity Neural Surface Graphics and Games (2014). https://api.semanticscholar.org/CorpusID:18595625
Reconstruction. In Conference on Computer Vision and Pattern Recognition (CVPR). Sara Fridovich-Keil and Alex Yu, Matthew Tancik, Qinhong Chen, Benjamin Recht, and
Ruilong Li, Sanja Fidler, Angjoo Kanazawa, and Francis Williams. 2024a. NeRF-XL: Angjoo Kanazawa. 2022. Plenoxels: Radiance Fields without Neural Networks. In
Scaling NeRFs with Multiple GPUs. arXiv:2404.16221 [cs.CV] CVPR.
Zhihao Liang, Qi Zhang, Ying Feng, Ying Shan, and Kui Jia. 2023. Gs-ir: 3d gaussian Johannes Lutz Schönberger and Jan-Michael Frahm. 2016. Structure-from-Motion
splatting for inverse rendering. arXiv preprint arXiv:2311.16473 (2023). Revisited. In Conference on Computer Vision and Pattern Recognition (CVPR).
Li Ma, Xiaoyu Li, Jing Liao, Qi Zhang, Xuan Wang, Jue Wang, and Pedro V. Sander. Johannes Lutz Schönberger, Enliang Zheng, Marc Pollefeys, and Jan-Michael Frahm.
2021. Deblur-NeRF: Neural Radiance Fields from Blurry Images. arXiv preprint 2016. Pixelwise View Selection for Unstructured Multi-View Stereo. In European
arXiv:2111.14292 (2021). Conference on Computer Vision (ECCV).
Ricardo Martin-Brualla, Noha Radwan, Mehdi S. M. Sajjadi, Jonathan T. Barron, Alexey Otto Seiskari, Jerry Ylilammi, Valtteri Kaatrasalo, Pekka Rantalankila, Matias Turku-
Dosovitskiy, and Daniel Duckworth. 2021. NeRF in the Wild: Neural Radiance Fields lainen, Juho Kannala, Esa Rahtu, and Arno Solin. 2024. Gaussian Splatting on the
for Unconstrained Photo Collections. In CVPR. Move: Blur and Rolling Shutter Compensation for Natural Camera Motion. arXiv
Ben Mildenhall, Pratul P. Srinivasan, Matthew Tancik, Jonathan T. Barron, Ravi Ra- preprint arXiv:2403.13327 (2024).
mamoorthi, and Ren Ng. 2020. NeRF: Representing Scenes as Neural Radiance Fields Pei Sun, Henrik Kretzschmar, Xerxes Dotiwalla, Aurelien Chouard, Vijaysai Patnaik,
for View Synthesis. In ECCV. Paul Tsui, James Guo, Yin Zhou, Yuning Chai, Benjamin Caine, Vijay Vasudevan, Wei
Thomas Müller, Alex Evans, Christoph Schied, and Alexander Keller. 2022. Instant Han, Jiquan Ngiam, Hang Zhao, Aleksei Timofeev, Scott Ettinger, Maxim Krivokon,
Neural Graphics Primitives with a Multiresolution Hash Encoding. ACM Trans. Amy Gao, Aditya Joshi, Yu Zhang, Jonathon Shlens, Zhifeng Chen, and Dragomir
Graph. 41, 4, Article 102 (July 2022), 15 pages. https://doi.org/10.1145/3528223. Anguelov. 2020. Scalability in Perception for Autonomous Driving: Waymo Open
3530127 Dataset. In Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern
Cedrick Münstermann, Stefan Krumpen, Reinhard Klein, and Christoph Peters. 2018. Recognition (CVPR).
Moment-Based Order-Independent Transparency. Proc. ACM Comput. Graph. Inter- Tianyi “Tanki” Zhang. 2021. Handling Translucency with Real-Time Ray Tracing. Apress,
act. Tech. 1, 1, Article 7 (jul 2018), 20 pages. https://doi.org/10.1145/3203206 Berkeley, CA, 127–138. https://doi.org/10.1007/978-1-4842-7185-8_11
Simon Niedermayr, Josef Stumpfegger, and Rüdiger Westermann. 2023. Com- Haithem Turki, Deva Ramanan, and Mahadev Satyanarayanan. 2022. Mega-NERF:
pressed 3d gaussian splatting for accelerated novel view synthesis. arXiv preprint Scalable Construction of Large-Scale NeRFs for Virtual Fly-Throughs. In Proceedings
arXiv:2401.02436 (2023). of the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR).
Michael Niemeyer, Jonathan T. Barron, Ben Mildenhall, Mehdi S. M. Sajjadi, Andreas 12922–12931.
Geiger, and Noha Radwan. 2022. RegNeRF: Regularizing Neural Radiance Fields Peng Wang, Lingjie Liu, Yuan Liu, Christian Theobalt, Taku Komura, and Wenping
for View Synthesis from Sparse Inputs. In Proc. IEEE Conf. on Computer Vision and Wang. 2021. NeuS: Learning Neural Implicit Surfaces by Volume Rendering for
Pattern Recognition (CVPR). Multi-view Reconstruction. NeurIPS (2021).
Michael Niemeyer, Fabian Manhardt, Marie-Julie Rakotosaona, Michael Oechsle, Daniel Zian Wang, Tianchang Shen, Jun Gao, Shengyu Huang, Jacob Munkberg, Jon Hasselgren,
Duckworth, Rama Gosula, Keisuke Tateno, John Bates, Dominik Kaeser, and Federico Zan Gojcic, Wenzheng Chen, and Sanja Fidler. 2023a. Neural Fields meet Explicit
16 • Moenne-Loccoz, Mirzaei et al.

Geometric Representations for Inverse Rendering of Urban Scenes. In The IEEE


Conference on Computer Vision and Pattern Recognition (CVPR).
Zian Wang, Tianchang Shen, Merlin Nimier-David, Nicholas Sharp, Jun Gao, Alexander
Keller, Sanja Fidler, Thomas Müller, and Zan Gojcic. 2023b. Adaptive Shells for
Efficient Neural Radiance Field Rendering. ACM Trans. Graph. 42, 6, Article 259
(2023), 15 pages. https://doi.org/10.1145/3618390
Turner Whitted. 1979. An improved illumination model for shaded display. Seminal
graphics: pioneering efforts that shaped the field (1979). https://api.semanticscholar.
org/CorpusID:9524504
Daniel N. Wood, Daniel I. Azuma, Ken Aldinger, Brian Curless, Tom Duchamp, David H.
Salesin, and Werner Stuetzle. 2000. Surface Light Fields for 3D Photography. In
Proceedings of the 27th Annual Conference on Computer Graphics and Interactive
Techniques (SIGGRAPH ’00). ACM Press/Addison-Wesley Publishing Co., 287–296.
Qiangeng Xu, Zexiang Xu, Julien Philip, Sai Bi, Zhixin Shu, Kalyan Sunkavalli, and
Ulrich Neumann. 2022. Point-nerf: Point-based neural radiance fields. In Proceedings
of the IEEE/CVF conference on computer vision and pattern recognition. 5438–5448.
Lior Yariv, Jiatao Gu, Yoni Kasten, and Yaron Lipman. 2021. Volume rendering of
neural implicit surfaces. In Thirty-Fifth Conference on Neural Information Processing
Systems.
Matthias Zwicker, Hanspeter Pfister, Jeroen Van Baar, and Markus Gross. 2001. Surface
splatting. In Proceedings of the 28th annual conference on Computer graphics and
interactive techniques. 371–378.
3D Gaussian Ray Tracing: Fast Tracing of Particle Scenes • 17

A IMPLEMENTATION AND TRAINING DETAILS Table 4. Quantitative evaluation on the NeRF Synthetic dataset [Milden-
hall et al. 2020]
We wrap the NVIDIA OptiX tracer as a Pytorch extension and
train our representation using Adam optimizer for 30,000 iterations.
NeRF Synthetic
We set the learning rates for rotations, scales, and albedo to 0.001, Method Chair Drum Ficus Hotdog Lego Materials Mic Ship Mean
0.005, and 0.0025, respectively. The learning rate for the remaining NeRF 33.00 25.01 30.13 36.18 32.54 29.62 32.91 28.65 31.10
spherical harmonics coefficients is 20 times smaller than that for MipNeRF 35.14 25.48 33.29 37.48 35.70 30.71 36.51 30.41 33.09
INGP 35.00 26.02 33.51 37.40 36.39 29.78 36.22 31.10 33.18
albedo. Finally, we set the density learning rate to either 0.05 for AdaptiveShells 34.94 25.19 33.63 36.21 33.49 27.82 33.91 29.54 31.84
high-quality settings or 0.09 for fast-inference settings. 3DGS (paper) 35.83 26.15 34.87 37.72 35.78 30.00 35.36 30.80 33.32

After initial 500 iterations, we start the densification and pruning Ours (reference) 35.90 25.77 35.94 37.51 36.01 29.95 35.66 30.71 33.48
Ours 36.02 25.89 36.08 37.63 36.20 30.17 34.27 30.77 33.38
process, which we perform until 15,000 iterations are reached. To
densify the particles, we accumulate 3D positional gradients, scaled
Table 5. Quantitative PSNR ablation on the maximum number of allowed
by half the distance of each particle to the camera, to prevent under-
particles using ours.
densification in distant regions. In line with 3DGS [Kerbl et al. 2023],
we split the particles if their maximum scale is above 1% of the scene
extent and clone them otherwise. Pruning directly removes particles Maximum Allowed Particles
whose opacity is below 0.01. Additionally, we employ a simple Dataset 1 × 106 2 × 106 3 × 106 4 × 106 5 × 106 6 × 106
heuristic to cap the maximum number of particles to 3,000,000. We Tanks & Temples 23.21 23.19 23.20 23.14 23.15 23.20
denote this pruning strategy as visibility pruning. Specifically, if the Deep Blending 29.24 29.17 29.23 29.14 29.24 29.15
densification step results in more particles, we reduce their number
to 2,700,000 by pruning particles with minimum accumulated weight
contribution on the training views. Moreover, while densification that both of our settings achieve comparable or better renderings
and pruning are in effect and similar to 3DGS, we reset the particle with sharp features. The first three rows contain scenes from the
densities to 0.01 every 3000 iterations. During training, we perform MipNeRF360 dataset, while the last two rows feature scenes from
early stopping to terminate the tracing of rays whose accumulated Tanks & Temples.
transmittance falls below 0.001. During inference, we increase this As mentioned in Section A, we propose a simple visibility prun-
threshold to 0.03 for improved efficiency. We begin by solely training ing strategy to prevent the number of particles from exceeding a
albedo colors and progressively increase the spherical harmonics’ certain threshold. Table 5 presents an ablation study on the maxi-
degree every 1000 iterations, up to a maximum of 3. We update mum number of allowed particles for scenes in two datasets: Tanks
the BVH every iteration and reconstruct it after each pruning and & Temples and Deep Blending. When densification causes the
densification. number of particles in the scene to exceed the threshold, we prune
For experiments with random-rays, during the last 15,000 itera- the least visible particles based on their accumulated contribution
tions, we sample random rays across all training views with a batch to the training views, reducing the number of particles to 90% of
size of 219 = 524,288, and only use the 𝐿1 loss to supervise the the threshold. The results show that our visibility pruning strategy,
particles. which filters out particles that contribute the least to the rendered
views, maintains quality even with as few as one million particles.
A.1 Autonomous Vehicles
To fit autonomous vehicle scenes, we modify our training protocol,
including incorporating lidar and depth supervision. To initialize,
we randomly sample 1 million lidar points visible in at least one
training image. These points are assigned an initial color via lookup
projected into a training image, and assigned an initial scale based
on the distance to the closest recorded camera pose. During training,
we use lidar to supervise depth; in our ray tracer depth is computed
by integrating the distance along the ray to each sample as if it were
radiance. Note that in 3DGS, lidar depth must be approximated by
projecting lidar rays onto camera images, yet in ray tracing lidar
rays can be directly cast into the scene. Additionally, we reconstruct
the sky following [Rematas et al. 2022] and employ a directional
MLP which predicts the color of the sky based on the ray direction.
A sky segmentation is included as input, and used to supervise ray
opacities computed from the particle scene.

B ADDITIONAL EXPERIMENTS AND ABLATIONS


Figure 17 shows qualitative comparisons of our method against
MIPNeRF360 [Barron et al. 2022]. The zoomed-in insets demonstrate
18 • Moenne-Loccoz, Mirzaei et al.

Ground Truth MIPNeRF360 Ours (reference) Ours

Fig. 17. Additional Qualitative Comparisons: novel-view synthesis results relative to the MIPNeRF360 baseline (insets (•) show per-result closeups).

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy