Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(Experimental) Gaussian splatting + WebGL #110

Merged
merged 49 commits into from
Jul 11, 2024
Merged

(Experimental) Gaussian splatting + WebGL #110

merged 49 commits into from
Jul 11, 2024

Conversation

brentyi
Copy link
Collaborator

@brentyi brentyi commented Oct 1, 2023

I spent some time studying + adapting https://github.com/antimatter15/splat/. It's really cool stuff.

splat.mp4

Work in progress: there's a lot of low hanging fruit for optimization, and the current implementation clashes with the <EffectComposer /> we use for outline/hover effects.

@brgrp
Copy link

brgrp commented Oct 4, 2023

Hey, I just tried to run the demo with Chrome and Firefox, but my display is getting incredibly slow. GPU and CPU usage stays low.

Ubuntu 22.04 LTS + GTX3080
Chrome: 117.0.5938.132 (64-bit)
Firefox: 117.0.1 (64-bit)
NVIDIA-SMI 525.125.06 Driver Version: 525.125.06

Does anyone have an idea what the problem could be?

@jkulhanek
Copy link
Contributor

Can you confirm hardware acceleration is enabled (chrome://gpu)?

@brgrp
Copy link

brgrp commented Oct 6, 2023

Can you confirm hardware acceleration is enabled (chrome://gpu)?

Graphics Feature Status

  • Canvas: Hardware accelerated
  • Canvas out-of-process rasterization: Enabled
  • Direct Rendering Display Compositor: Disabled
  • Compositing: Hardware accelerated
  • Multiple Raster Threads: Enabled
  • OpenGL: Enabled
  • Rasterization: Hardware accelerated
  • Raw Draw: Disabled
  • Skia Graphite: Disabled
  • Video Decode: Hardware accelerated
  • Video Encode: Software only. Hardware acceleration disabled
  • Vulkan: Disabled
  • WebGL: Hardware accelerated
  • WebGL2: Hardware accelerated
  • WebGPU: Hardware accelerated

@brentyi
Copy link
Collaborator Author

brentyi commented Oct 6, 2023

Which splat file are you loading? Splats are currently rendering smoothly in Chrome on both my laptop (M1 Mac) and phone (Samsung S21+).

@brentyi
Copy link
Collaborator Author

brentyi commented Oct 10, 2023

sort timing notes:

# Gaussians 270K 1M
Array.sort 79ms 380ms
JS counting sort 25ms 140ms
C++ counting sort 14ms 53ms

@jkulhanek
Copy link
Contributor

What is the current state of things? Is it ready to be merged soon?

@brentyi
Copy link
Collaborator Author

brentyi commented Dec 29, 2023

I'm leaning toward closing the PR; it's working, but:

  • Still clashes with outline effects / EffectComposer.
  • Doesn't sort properly when there are multiple splat files.
  • Can be optimized a lot. (in particular I would want to move more data into textures, as opposed to attributes)

After I implemented this splatting capabilities have also popped up in external libraries (example: https://github.com/pmndrs/drei#Splat); it may make sense to adapt one of these instead.

@brentyi brentyi mentioned this pull request Jan 4, 2024
@beckyfeng08 beckyfeng08 force-pushed the brent/splatting branch 2 times, most recently from d22b548 to 99c3680 Compare July 8, 2024 04:01
@brentyi brentyi changed the title Gaussian splatting + WebGL (Experimental) Gaussian splatting + WebGL Jul 11, 2024
@brentyi brentyi marked this pull request as ready for review July 11, 2024 08:46
@brentyi brentyi merged commit 03ce7f7 into main Jul 11, 2024
9 checks passed
@brentyi brentyi deleted the brent/splatting branch July 11, 2024 08:56
@a1raman
Copy link

a1raman commented Aug 6, 2024

Any progress?

@brentyi
Copy link
Collaborator Author

brentyi commented Aug 6, 2024

This is merged and the majority of kinks are worked out, but it'll be a while before it hits the stable API.

If you want to try it you can install viser from source and call server.scene._add_gaussian_splats() (or run the example in the examples/experimental directory):

def _add_gaussian_splats(
self,
name: str,
centers: onp.ndarray,
covariances: onp.ndarray,
rgbs: onp.ndarray,
opacities: onp.ndarray,
wxyz: Tuple[float, float, float, float] | onp.ndarray = (1.0, 0.0, 0.0, 0.0),
position: Tuple[float, float, float] | onp.ndarray = (0.0, 0.0, 0.0),
visible: bool = True,
) -> GaussianSplatHandle:
"""Add a model to render using Gaussian Splatting.
**Work-in-progress.** This feature is experimental and still under
development. It may be changed or removed.
Arguments:
name: Scene node name.
centers: Centers of Gaussians. (N, 3).
covariances: Second moment for each Gaussian. (N, 3, 3).
rgbs: Color for each Gaussian. (N, 3).
opacities: Opacity for each Gaussian. (N, 1).
wxyz: R_parent_local transformation.
position: t_parent_local transformation.
visibile: Initial visibility of scene node.
Returns:
Scene node handle.
"""

@fantasy-fish
Copy link

fantasy-fish commented Aug 26, 2024

I ran the command python examples/experimental/gaussian_splats.py --splat-paths ~/data/test1-splat/point_cloud/iteration_30000/point_cloud.ply. It successfully loaded the ply file with the message "PLY file with num_gaussians=410549 loaded in 0.6525325775146484 seconds". But when I opened http://0.0.0.0:8080, it shows a blank web page in my browser.

@soumya997
Copy link

Hi @brentyi why am i getting so blured rendering when I use
python examples/experimental/gaussian_splats.py --splat-paths ~/data/test1-splat/point_cloud/iteration_30000/point_cloud.ply command. I tried changing the resolution, which made it much better but its still not good enough, compared to what I get when I use gsplats simple_viewer.py. below is an example.

viser ply

3dgs_msms_ply_viser.mp4

gsplat simple_viewer

3dgs_mcmc_demo1.mp4

below is how i added resolution to the gaussian_splats.py file.

@server.on_client_connect
def _(client: viser.ClientHandle) -> None:
    client.set_viewport_size(width, height)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants