Skip to content

Commit

Permalink
deploy: 53baf97
Browse files Browse the repository at this point in the history
  • Loading branch information
liruilong940607 committed Oct 13, 2023
0 parents commit aa4c5cf
Show file tree
Hide file tree
Showing 54 changed files with 6,355 additions and 0 deletions.
4 changes: 4 additions & 0 deletions .buildinfo
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# Sphinx build info version 1
# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
config: 1053ae44b98182c0879b93dbedb1fcf2
tags: 645f666f9bcd5a90fca523b33c5a78b7
Binary file added .doctrees/apis/proj.doctree
Binary file not shown.
Binary file added .doctrees/apis/rast.doctree
Binary file not shown.
Binary file added .doctrees/apis/utils.doctree
Binary file not shown.
Binary file added .doctrees/conventions/cuda_conventions.doctree
Binary file not shown.
Binary file added .doctrees/conventions/data_conventions.doctree
Binary file not shown.
Binary file added .doctrees/environment.pickle
Binary file not shown.
Binary file added .doctrees/examples/simple_trainer.doctree
Binary file not shown.
Binary file added .doctrees/index.doctree
Binary file not shown.
Binary file added .doctrees/tests/tests.doctree
Binary file not shown.
Empty file added .nojekyll
Empty file.
1 change: 1 addition & 0 deletions CNAME
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
docs.gsplat.studio
Binary file added _images/square.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/training.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
42 changes: 42 additions & 0 deletions _sources/apis/proj.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
ProjectGaussians
===================================

.. currentmodule:: gsplat

Given 3D gaussians parametrized by means :math:`μ`, covariances :math:`Σ`, colors :math:`c`, and opacities :math:`o`, the
ProjectGaussians function computes the projected 2D gaussians in the camera frame with means :math:`μ'`, covariances :math:`Σ'`, and depths :math:`z`
as well as their maximum radii in screen space and conic parameters.

Note, covariances are reparametrized by the eigen decomposition:

.. math::
Σ = RSS^{T}R^{T}
Where rotation matrices :math:`R` are obtained from four dimensional quaternions.

The projection of 3D Gaussians is approximated with the Jacobian of the perspective projection equation
as shown in :cite:p:`zwicker2002ewa`:

.. math::
J = \begin{bmatrix}
f_{x}/t_{z} & 0 & -f_{x} t_{x}/t_{z}^{2} \\
0 & f_{y}/t_{z} & -f_{y} t_{y}/t_{z}^{2} \\
0 & 0 & 0
\end{bmatrix}
Where :math:`t` is the center of a gaussian in camera frame :math:`t = Wμ+p`. The projected 2D covarience is then given by:

.. math::
Σ' = J W Σ W^{⊤} J^{⊤}
Citations
-------------
.. bibliography::
:style: unsrt
:filter: docname in docnames

.. autoclass:: ProjectGaussians
34 changes: 34 additions & 0 deletions _sources/apis/rast.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
RasterizeGaussians
===================================

.. currentmodule:: gsplat

Given 2D gaussians that are parametrized by their means :math:`μ'` and covariances :math:`Σ'` as well as their radii and conic parameters,
the RasterizeGaussians function first sorts each gaussian such that all gaussians within the bounds of a tile are grouped and sorted by increasing depth :math:`z`,
and then renders each pixel within a tile with alpha-compositing.

The discrete rendering equation is given by:

.. math::
\sum_{t=n}^{N}c_{n}·α_{n}·T_{n}
Where

.. math::
T_{n} = \prod_{t=m}^{M}(1-α_{m})
And

.. math::
α_{n} = o_{n} \exp(-σ_{n})
σ_{n} = \frac{1}{2} ∆^{⊤}_{n} Σ'^{−1} ∆_{n}
:math:`σ ∈ R^{2}` is the Mahalanobis distance (here referred to as sigma) which measures how many standard deviations away the center of a gaussian and the rendered pixel center is which is denoted by delta :math:`∆.`


.. autoclass:: RasterizeGaussians
20 changes: 20 additions & 0 deletions _sources/apis/utils.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
Utils
===================================
In addition to the main projection and rasterization functions, a few CUDA kernel and helper functions are exposed to python with the following bindings:


.. currentmodule:: gsplat

.. autoclass:: BinAndSortGaussians

.. autoclass:: ComputeCov2dBounds

.. autoclass:: GetTileBinEdges

.. autoclass:: SphericalHarmonics

.. autoclass:: MapGaussiansToIntersects

.. autoclass:: ComputeCumulativeIntersects

.. autoclass:: RasterizeForwardKernel
44 changes: 44 additions & 0 deletions _sources/conventions/cuda_conventions.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
CUDA Conventions
===================================

.. currentmodule:: diff_rast

Here we explain some conventions used for the implementation of the CUDA backend.

Kernel Launch Conventions
-------------------------

The backend CUDA code consists of several kernel functions that run in parallel for either arbitrary number of gaussians or for arbitrary image dimensions.
Here we explain some of the conventions used for launching these kernel functions using the ``<<<gridDim, blockDim>>>`` notation.


1D Grids
^^^^^^^^

Kernel functions that depend on the number of input gaussians are organized into one dimensional CUDA grids consisting of

.. code-block::
const int gridDim = (num_gaussian_operations + NUM_THREADS - 1) / NUM_THREADS;
1-D blocks containing ``const int blockDim = NUM_THREADS;`` threads each. An example of a kernel function that depends on the number of gaussians (here denoted by the ``num_gaussian_operations`` variable)
is the main `ProjectGaussians` kernel that projects an arbitrary number of 3D gaussians into 2D.


2D Grids
^^^^^^^^

Kernel functions that depend on the rendered output image size are organized into two dimensional CUDA grids. The shape of the grid is determined by

.. code-block::
const dim3 gridDim = {(img_width + NUM_THREADS_X - 1) / NUM_THREADS_X, (img_height + NUM_THREADS_Y - 1) / NUM_THREADS_Y, 1};
where each individual block within the grid contains a layout of threads defined by ``const dim3 blockDim = {NUM_THREADS_X, NUM_THREADS_Y, 1};``.
An example of a kernel function that requires two dimensional grids is the main `RasterizeGaussians` kernel that renders an arbitrary number of pixels in an output image.


Config Constants
----------------

We fix the total number of threads within a block to 256. This means that for 1D blocks the block dimension is given by ``const int blockDim = 256;`` and for 2D blocks ``const dim3 blockDim = {16, 16, 1};``.
41 changes: 41 additions & 0 deletions _sources/conventions/data_conventions.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
Data Conventions
===================================

.. currentmodule:: gsplat

Here we explain the various data conventions used in our repo.

Rotation Convention
-------------------
We represent rotations with four dimensional vectors :math:`q = (w,x,y,z)` such that the 3x3 :math:`SO(3)` rotation matrix is defined by:

.. math::
R = \begin{bmatrix}
1 - 2 \left( y^2 + z^2 \right) & 2 \left( x y - w z \right) & 2 \left( x z + w y \right) \\
2 \left( x y + w z \right) & 1 - 2 \left( x^2 + z^2 \right) & 2 \left( y z - w x \right) \\
2 \left( x z - w y \right) & 2 \left( y z + w x \right) & 1 - 2 \left( x^2 + y^2 \right) \\
\end{bmatrix}
View Matrix and Projection Matrix
---------------------------------
We refer to the `view matrix` :math:`W` as the world to camera frame transformation (referred to as `w2c` in some sources) that maps
3D world points :math:`(x,y,z)_{world}` to 3D camera points :math:`(x,y,z)_{cam}` where :math:`z_{cam}` is the relative depth to the camera center.


The `projection matrix` refers to the full projective transformation that maps 3D points in the world frame to the 2D points in the image/pixel frame.
This transformation is the concatenation of the perspective projection matrix :math:`K` (obtained from camera intrinsics) and the view matrix :math:`W`.
We adopt the `OpenGL <http://www.songho.ca/opengl/gl_projectionmatrix.html>`_ perspective projection convention. The projection matrix :math:`P` is given by:

.. math::
P = K W
.. math::
K = \begin{bmatrix}
\frac{2n}{r - l} & 0.0 & \frac{r + l}{r - l} & 0.0 \\
0.0 & \frac{2n}{t - b} & \frac{t + b}{t - b} & 0.0 \\
0.0 & 0.0 & \frac{f + n}{f - n} & -\frac{f \cdot n}{f - n} \\
0.0 & 0.0 & 1.0 & 0.0 \\
\end{bmatrix}
28 changes: 28 additions & 0 deletions _sources/examples/simple_trainer.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
Simple Trainer
===================================

.. currentmodule:: gsplat

Training on an image
-----------------------------------
The `examples/simple_trainer.py` script allows you to test the basic forward projection and rasterization of random gaussians
and their differentiability on a single training image. This allows you to overfit gaussians on a single view.

Simply run the script with:

.. code-block:: bash
:caption: simple_trainer.py
python examples/simple_trainer.py --height 256 --width 256 --num_points 2000 --save_imgs
to get a result similar to the one below:

.. image:: ../imgs/square.gif
:alt: Gaussians overfit on a single image
:width: 256

You can also provide a path to your own custom image file using the ``--img_path`` flag:

.. code-block:: bash
python examples/simple_trainer.py --img_path PATH_TO_IMG --save_imgs
59 changes: 59 additions & 0 deletions _sources/index.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
gsplat
===================================

.. image:: imgs/training.gif
:width: 800
:alt: Example training image

Overview
--------

*gsplat* is an open-source library for CUDA accelerated rasterization of gaussians with python bindings. It is inspired by the SIGGRAPH paper "3D Gaussian Splatting for Real-Time Rendering of Radiance Fields" :cite:p:`kerbl3Dgaussians`.
This libary contains the neccessary components for efficient 3D to 2D projection, sorting, and alpha compositing of gaussians and their associated backward passes for inverse rendering.

Contributing
------------

This repository was born from the curiosity of people on the Nerfstudio team trying to understand a new rendering technique. We welcome contributions of any kind and are open to feedback, bug-reports, and improvements to help expand the capabilities of this software.


Links
-----

.. toctree::
:glob:
:maxdepth: 1
:caption: Examples

examples/*


.. toctree::
:glob:
:maxdepth: 1
:caption: Conventions

conventions/*


.. toctree::
:glob:
:maxdepth: 1
:caption: Python API

apis/*


.. toctree::
:glob:
:maxdepth: 1
:caption: Tests

tests/*


Citations
-------------
.. bibliography::
:style: unsrt
:filter: docname in docnames
22 changes: 22 additions & 0 deletions _sources/tests/tests.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
Tests
===================================

Testing and verifying CUDA implementations
--------------------------------------------

The `tests/` folder provides automatic test scripts that are ran to verify that the CUDA implementations agree with native PyTorch ones.
They are also ran with any pull-requests into main branch on our github repository.

The tests include:

.. code-block:: bash
:caption: tests/
./test_bin_and_sort_gaussians.py
./test_cov2d_bounds.py
./test_cumulative_intersects.py
./test_get_tile_bin_edges.py
./test_map_gaussians.py
./test_project_gaussians
./test_rasterize_forward_kernel.py
./test_sh.py
Loading

0 comments on commit aa4c5cf

Please sign in to comment.