Skip to content

A repository on how to understand the theory of 3D Gaussians Splatting

Notifications You must be signed in to change notification settings

LZL-CS/3d-gaussian-theory

This branch is 3 commits behind chiehwangs/3d-gaussian-theory:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

b2f6b95 · Feb 28, 2024

History

44 Commits
Nov 13, 2023
Feb 28, 2024

Repository files navigation

A repository on how to understand the partial theory of Gaussians

Another comprehensive repository, you might need it:awesome-3D-gaussian-splatting

Coming soon:

📑 A theoretical of 3D Gaussian Splatting Rasterization will be added soon...

Theoretical derivation:

First, let's start by understanding the standard unit Gaussian function, which represents a function with a mean of μ = 0 and a variance of σ equal to 1, where the sum of its probability density is 1: f ( x ) = 1 2 π e x 2 2

Now, we do not constrain the mean and variance and express them in a general form:

(2) f ( x ) = 1 2 π σ e ( x μ ) 2 2 σ 2

Here, σ represents the variance of the Gaussian function, and μ represents the mean. Mathematically, it means shifting the standard Gaussian function to the right by μ units, stretching the function's width by a factor of σ . In order to ensure that the probability density function integrates to 1, the height of f ( x ) decreases, which is reflected in dividing the denominator by σ .

We consider n independent variables, each following a normal distribution and being mutually uncorrelated, represented as :

x = [ x 1 , x 2 , , x n ] T

with a mean of :

E ( x ) = [ μ 1 , μ 2 , , μ n ] T

and a variance of:

σ ( x ) = [ σ 1 , σ 2 , , σ n ] T

In this case, according to the probability density formula in probability theory, we have:

(3) f ( x ) = p ( x 1 , x 2 . . . . x n ) = p ( x 1 ) p ( x 2 ) . . . . p ( x n ) = 1 ( 2 π ) n σ 1 σ 2 σ n e ( x 1 μ 1 ) 2 2 σ 1 2 ( x 2 μ 2 ) 2 2 σ 2 2 ( x n μ n ) 2 2 σ n 2

We let z 2 = ( x 1 μ 1 ) 2 σ 1 2 + ( x 2 μ 2 ) 2 σ 2 2 + ( x n μ n ) 2 σ n 2 σ z = σ 1 σ 2 σ n ,We can simplify the above multivariate normal distribution Gaussian function as: f ( z ) = 1 ( 2 π ) n σ z e z 2 2

And z 2 can be represented as z T z , decomposed into vector notation:

(5) z 2 = z T z = [ x 1 μ 1 x 2 μ 2 x n μ n ] [ 1 σ 1 2 0 0 0 1 σ 2 2 0 0 0 1 σ n 2 ] [ x 1 μ 1   x 2 μ 2     x n μ n ] T

x μ x can be represented as $x - μ_{x} = \left[ \begin{matrix} x_{1} - μ_{1}, x_{2} - μ_{2}, \cdots,x_{n} - μ_{n} \end{matrix}\right]^\mathrm{T}$ , and at this point, z 2 can be represented as:

(6) [ x μ x ] T [ 1 σ 1 2 0 0 0 1 σ 2 2 0 0 0 1 σ n 2 ] [ x μ x ]

Mathematically, the covariance matrix Σ is defined as, with its diagonal elements equal to the covariance between x i and x j :

(7) = [ σ 1 2 0 0 0 σ 2 2 0 0 0 σ n 2 ]

At this point, the variables are independent, so only diagonal elements exist, and these elements represent the covariance between x i and itself, which is also equal to the variance σ 2 . Σ is a diagonal matrix, and its inverse matrix is:

(8) ( ( ) 1 = [ 1 σ 1 2 0 0 0 1 σ 2 2 0 0 0 1 σ n 2 ]

Its determinant is:

(9) | | = σ 1 2 σ 2 2 . . . . . σ n 2

(10) σ z = | | 1 2 = σ 1 σ 2 . . . . . σ n

At this point, we can simplify Equation (5) to:

(11) z T z = ( x μ x ) T 1 ( x μ x )

Substitute this into the multivariate normal Gaussian distribution function (4) with z as the independent variable:

(12) f ( z ) = 1 ( 2 π ) n σ z e z 2 2 = 1 ( 2 π ) n | | 1 2 e ( x     μ x ) T   ( ) 1   ( x     μ x ) 2

The authors use the product of formula (12) (PDF) and o p a c i t y to calculate a l p h a , the variable x represents the pixel position, and u x denotes the 2D Gaussian center position that influences x . The further away from the 2D Gaussian center u x , the smaller the alpha. The alpha of the Gaussian area above pixel x is α 2 , note that the color of pixel x is: C x = c 1 α 1 + c 2 α 2 + . . . , c 1 is the rgb of 2D gaussian which is nearest to pixel x , α 1 is the alpha value of the area above pixel x in 2D Gaussian.

In the 3D Gaussian Splatting paper, the authors define the multivariate Gaussian function in world space using a 3D covariance matrix (refer to Equation 12, where the paper's Equation 4 omits u and the preceding coefficients):

(13) G ( x ) = e ( x     μ ) T   ( ) 1   ( x     μ ) 2

In the context of the 3D Gaussian Splatting paper, this 3D Gaussian is one of the optimization targets (parameters u and Σ ), corresponding to the 3D Gaussian position and anisotropic covariance. It represents a 3D Gaussian function with the center at u and variances in the x, y, and z directions equal to the diagonal elements of Σ . To visually understand this, here we use Python to draw a 2D Gaussian with the center at (1, 2) and a covariance matrix of [[1, 0], [0, 2]] (the vertical axis represents the probability density with u and Σ substituted).

In order to complete the process of rasterization from 3D to 2D images after obtaining the 3D Gaussian, a transformation matrix from world to camera space, denoted as W , and a mapping matrix from camera to screen space, denoted as P , are required. In the paper, the authors use J to represent the Jacobian matrix of the mapping matrix P . At this point, the covariance matrix on the 2D plane for this 3D Gaussian can be represented as:

(14) = J W W T J T

The covariance matrix has several important properties:

  • Symmetry: The covariance matrix is a symmetric matrix, meaning that the elements of the matrix are symmetric with respect to the main diagonal.
  • Non-Negativity: The covariance matrix is a positive semi-definite matrix, which means that its eigenvalues are non-negative.
  • The diagonal elements of the covariance matrix contain the variances of the individual variables.
  • The off-diagonal elements of the covariance matrix represent the covariances between different variables, indicating the degree of correlation between different variables.

Using the full covariance matrix introduces more parameters, and during the gradient descent optimization process, it can lead to situations where the positive semi-definite condition is not satisfied. Because the covariance matrix should be positive semi-definite, it is only necessary to consider its upper diagonal elements. Therefore, the authors decompose Σ into a scaling factor S (1x3) and a rotation quaternion R (1x4), and then combine the scaling factor and the rotation quaternion into the upper triangular matrix of the covariance matrix (a 1x6 vector). By mirroring, a complete and positive definite Σ can be obtained.


The process of decomposing the covariance matrix into scaling factors and a rotation matrix is known as the eigenvalue decomposition. This decomposition can be achieved through the following steps:

  • Calculate the eigenvalues λ 1 , λ 2 , λ 3 and the eigenvectors v 1 , v 2 , v 3 of the covariance matrix .
  • Arrange the eigenvalues in descending order.
  • The scaling factors are constructed from the eigenvalues λ , with S = diag ( λ 1 , λ 2 , λ 3 ) , and the rotation matrix R is constructed from the eigenvectors v , with R = [ v 1 , v 2 , v 3 ] .

An orthogonal rotation matrix can be represented using a rotation quaternion. Assuming a quaternion l = ( w , x , y , z ) , the rotation matrix Q is given by:

(15) Q = [ m 11 m 12 m 13 m 21 m 22 m 23 m 31 m 32 m 33 ]

Reference《Real Time Rendering 3rd edition》:

(16) m 32 m 23 = ( 2 y z + 2 x w ) ( 2 y z 2 x w ) = 4 x w m 13 m 31 = ( 2 x z + 2 y w ) ( 2 x z 2 y w ) = 4 y w m 21 m 12 = ( 2 x y + 2 z w ) ( 2 x y 2 z w ) = 4 z w

The trace of the rotation matrix Q is given by t r ( Q ) = m 11 + m 22 + m 33 , and based on the equation above, it can be derived that t r ( Q ) = 4 w 2 1 , therefore, the quaternion l = ( w , x , y , z ) obtained from the rotation matrix Q is as follows:

(17) w = ( t r ( Q ) + 1 2 x = m 32 m 23 4 w y = m 13 m 31 4 w z = m 21 m 12 4 w


In the 3D Gaussian Splatting paper, the calculation from scaling factors s = ( a , b , c ) and rotation quaternion r = ( w , x , y , z ) to the covariance matrix is defined in the function build_covariance_from_scaling_rotation():

def build_covariance_from_scaling_rotation(scaling, scaling_modifier, rotation):
    L = build_scaling_rotation(scaling_modifier * scaling, rotation)
    actual_covariance = L @ L.transpose(1, 2)
    symm = strip_symmetric(actual_covariance)

    return symm

Using L to represent the scaling factors:

(18) L = [ a 0 0 0 b 0 0 0 c ]

Normalize the quaternion r to represent it as q:

l = w 2 + x 2 + y 2 + z 2 q = r w 2 + x 2 + y 2 + z 2 = ( w , x , y , z )

In a left-handed coordinate system, the quaternion ( w , x , y , z ) representing a rotation around the w axis by a certain angle is transformed into a rotation matrix using the following formula, as referenced in 《3D Math Primer for Graphics and Game Development》

(19) R = [ 1 2 ( y 2 + z 2 ) 2 ( x y w z ) 2 ( x z + w y ) 2 ( x y + w z ) 1 2 ( x 2 + z 2 ) 2 ( y z w x ) 2 ( x z w y ) 2 ( y z + w x ) 1 2 ( x 2 + y 2 ) ]

Covariance matrix

(20) = R L ( R L ) T = R L L T R T

Only the upper six elements of Σ need to be retained.

Up to this point, we have learned about the relationship between the covariance matrix, scaling factors, rotation quaternion, and rotation matrix. This allows us to combine all the information in Σ (with S and R initialized as 0 in the paper and optimized during the iteration process) to complete the rasterization process. The formula provided in the paper is as follows, replacing L in Equation (19) with S

(21) = R S S T R T

During the backpropagation process, it is necessary to obtain the gradients of Σ with respect to the scaling factors and rotation quaternion, which are provided in the appendix of the paper.

Reference:

About

A repository on how to understand the theory of 3D Gaussians Splatting

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published