splatviz
splatviz copied to clipboard
Full python interactive 3D Gaussian Splatting viewer for real-time editing and analyzing.
Gaussian Viewer
This interactive viewer allows to display 3D Gaussian Splatting objects stored as .ply files or as compressed objects from Compact 3D Scene Representation via Self-Organizing Gaussian Grids. The viewer is fully written in python, which makes development and debugging very simple.
data:image/s3,"s3://crabby-images/8a6f7/8a6f791b927ee47664aac8af00fbf9fa1315370f" alt=""
Install
Clone repository recursively in order to install glm from the diff_gaussian_rasterization package.
git clone https://github.com/Florian-Barthel/gaussian_viewer --recursive
Create conda environment:
conda env create -f environment.yml
conda activate gs-view
Launch:
python run_main.py --data_path="path/to/directory/with/gaussian/objects"
Current Features
Currently, the viewer is equipped with the following features:
- Edit Widget
- Evaluate Widget
- Video Widget
Edit Widget
The edit widget allows to modify the Gaussian object interactively. The written code is executed just before rendering the Gaussian object. All existing objects at that state can be accessed and modified. An example looks as follows:
mask = torch.linalg.norm(gaussian._scaling, dim=1) < 10
gaussian._xyz = gaussian._xyz[mask, ...]
gaussian._rotation = gaussian._rotation[mask, ...]
gaussian._scaling = gaussian._scaling[mask, ...]
gaussian._opacity = gaussian._opacity[mask, ...]
gaussian._features_dc = gaussian._features_dc[mask, ...]
gaussian._features_rest = gaussian._features_rest[mask, ...]
this removes all gaussian splats with a scale greater than 10.
You can also create slider variables that can be accessed in the code block with slider.varname. Example:
data:image/s3,"s3://crabby-images/1ef87/1ef8708ae8e06d9c4209b5de4e0d5a94bfbaada9" alt=""
Evaluate Widget
The evaluate widget can be used to debug the gaussian splatting object. By typing python code, which is executed after the rendering, you can access any variable from the rendering context.
data:image/s3,"s3://crabby-images/a1bdc/a1bdc973289a9e86bb1cd9b47e63744c533c0c30" alt=""
Video Widget
The video widget creates a video sequence of a full rotation around the current object. Simply define the height of the camera and the rendering resolution. While the video is rendering, the UI is frozen. A loading screen is shown in the terminal output.
Future Plans
- Compare two Gaussian Splatting scenes side by side
- Attach to Gaussian Splatting training for live tracking
- Better visualization for tensors
Recent Updates ⚡
- Improved camera controls
- Orbit Mode: Camera moves on a sphere around a look_at_point
- Free mode: Camera moves free and can be controlled with WASD
- Save screenshots and .ply files of the current scene
Contribute
You are more than welcome to add further functionality to this interactive viewer! The main goal is to create an easy-to-use tool that can be applied for debugging and for understanding 3D Gaussian Splatting objects.
References
This viewer is inspired by the visualizer from Efficient Geometry-aware 3D Generative Adversarial Networks (EG3D).
Compact 3D Scene Representation via Self-Organizing Gaussian Grids