Skip to main content

A Taichi Gaussian Splatting library

Project description

Taichi Splatting

Rasterizer for Guassian Splatting using Taichi and PyTorch - embedded in python library. Currently very usable but in active development, so likely will break with new versions!

This work is originally derived off Taichi 3D Gaussian Splatting, with significant re-organisation and changes.

Key differences are the rendering algorithm is decomposed into separate operations (projection, shading functions, tile mapping and rasterization) which can be combined in different ways in order to facilitate a more flexible use, and gradients can be enabled on "all the things" as required for the application (and not when disabled, to save performance).

Using the Taichi autodiff for a simpler implementation where possible (e.g. for projection, but not for the rasterization).

Examples:

  • Projecting features for lifting 2D to 3D
  • Colours via. spherical harmonics
  • Depth covariance without needing to build it into the renderer and remaining differentiable.
  • Fully differentiable camera parameters (and ability to swap in new camera models)

Performance

A document describing some performance benchmarks of taichi-splatting here. Through various optimizations, in particular optimizing the summation of gradients in the backward gradient kernel. Taichi-splatting achieves a very large speedup (often an order of magnitude) over the original taichi_3d_gaussian_splatting, and is faster than the reference diff_guassian_rasterization for a complete optimization pass (forward+backward), in particular much faster at higher resolutions.

Major dependencies

  • taichi-nightly

Some bug fixes which have occurred after the 1.7.0 release: pip install --upgrade -i https://pypi.taichi.graphics/simple/ taichi-nightly

  • torch >= 1.8 (probably works with earlier versions, too)

Installing

  • Install taichi-nightly as above (note that the external repo cannot be listed in the pyproject.toml)
  • Clone down with git clone and install with pip install ./taichi-spatting
  • pip install taichi-splatting

Executables

fit_image_gaussians

There exists a toy optimizer for fitting a set of randomly initialized gaussians to some 2D images fit_image_gaussians - useful for testing rasterization without the rest of the dependencies.

Fitting an image (fixed points):
fit_image_gaussians <image file> --show --n 20000

Fitting an image (split and prune to target):
fit_image_gaussians <image file> --show --n 1000 --target 20000

See --help for other options.

benchmarks

There exist benchmarks to evaluate performance on individual components in isolation under taichi_splatting/benchmarks/

tests

Tests (gradient tests and tests comparing to torch-based reference implementations) can be run with pytest, or individually under taichi_splatting/tests/

splat-viewer

A viewer for reconstructions created with the original gaussian-splatting repository can be found here or installed with pip. Has dependencies on open3d and Qt.

splat-benchmark

A benchmark for a full rendererer (in the same repository as above) with real reconstructions (rendering the original camera viewpoints). Options exist for tweaking all the renderer parameters, benchmarking backward pass etc.

Progress

Done

  • Benchmarks with original + taichi_3dgs rasterizer

  • Simple view culling

  • Projection with autograd

  • Tile mapping (optimized and improved culling)

  • Rasterizer forward pass and optimized backward pass

  • Spherical harmonics with autograd

  • Gradient tests for most parts (float64) - including rasterizer!

  • Fit to image training example/test

  • Depth and depth-covariance rendering

  • Compute point visibility in backward pass (useful for model pruning)

  • Example training on images with split/prune operations

  • Novel heuristics for split and prune operations computed optionally in backward pass

Todo

  • Depth covariance example

  • 3D training code (likely different repository)

  • Backward projection autograd takes a while to compile and is not cached properly

Improvements

  • Exposed all internal constants as parameters
  • Switched to matrices as inputs instead of quaternions
  • Tile mapping tighter culling for tile overlaps (~30% less rendered splats!)
  • All configuration parameters exposed (e.g. tile_size, saturation threshold etc.)
  • Warp reduction based backward pass for rasterizer, a decent boost in performance

Conventions

Transformation matrices

Transformations are notated T_x_y, for example T_camera_world can be used to transform points in the world to points in the local camera by points_camera = T_camera_world @ points_world

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

taichi_splatting-0.12.0.tar.gz (4.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

taichi_splatting-0.12.0-py3-none-any.whl (82.2 kB view details)

Uploaded Python 3

File details

Details for the file taichi_splatting-0.12.0.tar.gz.

File metadata

  • Download URL: taichi_splatting-0.12.0.tar.gz
  • Upload date:
  • Size: 4.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for taichi_splatting-0.12.0.tar.gz
Algorithm Hash digest
SHA256 8be4686e29eaabfeb359da2439a058dd36290370d4fd302dee78f2fe09a71821
MD5 8ae893e63b5c531b52a3e9df80b0567d
BLAKE2b-256 6565e85141cce3ae80015c8a36816ed03435b6cd988b0c8216c07a50db17119f

See more details on using hashes here.

File details

Details for the file taichi_splatting-0.12.0-py3-none-any.whl.

File metadata

File hashes

Hashes for taichi_splatting-0.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bd27a1fc61d74f73182baa6d7648c75e75d517bdd8819f9580109f8cba4192f4
MD5 27860131089f5ad501eeac2e2f10aa2d
BLAKE2b-256 27f6491e639c4d318ba1088b725b6d1fc9cb5cf7791fe7efa13aff73ece62906

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page