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

Rename gaussian-splatting to splatfacto for clarity #2796

Merged
merged 33 commits into from
Jan 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
70ade42
fix jittering in markdown in viewer beta
kerrj Oct 11, 2023
622342c
Revert "fix jittering in markdown in viewer beta"
kerrj Oct 11, 2023
072c3ed
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Oct 18, 2023
d68138d
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Oct 19, 2023
e65d14e
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Oct 20, 2023
39637f0
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Oct 21, 2023
c30d0c8
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Oct 23, 2023
5723357
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Oct 29, 2023
8a08740
print correctly formatted url in banner for viewer beta
kerrj Oct 29, 2023
246d731
merge
kerrj Nov 1, 2023
a7b08df
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Nov 29, 2023
fa8909e
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Nov 29, 2023
eab1f7a
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Nov 30, 2023
86ff630
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Dec 13, 2023
cf41e63
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Dec 15, 2023
db13cfa
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 5, 2024
5ca2be0
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 8, 2024
172cf07
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 8, 2024
1559504
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 10, 2024
93436d4
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 17, 2024
91c6b49
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 17, 2024
c012963
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 18, 2024
9620061
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 18, 2024
e5c5601
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 18, 2024
06011f5
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 18, 2024
bf12b3e
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 18, 2024
8dd3123
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 18, 2024
ce39177
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 19, 2024
ce7bb78
Merge branch 'main' of https://github.com/nerfstudio-project/nerfstudio
kerrj Jan 19, 2024
0941850
method name->splatfacto
kerrj Jan 19, 2024
891e365
change file names to splatfacto
kerrj Jan 19, 2024
1eb4bae
lin
kerrj Jan 19, 2024
49af9b2
Merge branch 'main' into splat-name
kerrj Jan 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ This documentation is organized into 3 parts:
- [NeRF](nerfology/methods/nerf.md): OG Neural Radiance Fields
- [Mip-NeRF](nerfology/methods/mipnerf.md): A Multiscale Representation for Anti-Aliasing Neural Radiance Fields
- [TensoRF](nerfology/methods/tensorf.md): Tensorial Radiance Fields
- [Gaussian Splatting](nerfology/methods/splat.md): 3D Gaussian Splatting
- [Splatfacto](nerfology/methods/splat.md): Nerfstudio's Gaussian Splatting implementation

(third_party_methods)=

Expand Down
2 changes: 1 addition & 1 deletion docs/nerfology/methods/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ The following methods are supported in nerfstudio:
```{toctree}
:maxdepth: 1
Instant-NGP<instant_ngp.md>
3D Gaussian Splatting<splat.md>
Splatfacto<splat.md>
Instruct-NeRF2NeRF<in2n.md>
K-Planes<kplanes.md>
LERF<lerf.md>
Expand Down
28 changes: 16 additions & 12 deletions docs/nerfology/methods/splat.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Gaussian Splatting
<h4>Real-Time Radiance Field Rendering</h4>

# Splatfacto
<h4>Nerfstudio's Gaussian Splatting Implementation</h4>
<iframe width="560" height="315" src="https://www.youtube.com/embed/0yueTFx-MdQ?si=GxiYnFAeYVVl-soJ" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe>

```{button-link} https://repo-sam.inria.fr/fungraph/3d-gaussian-splatting/
:color: primary
Expand All @@ -10,6 +10,8 @@ Paper Website

[3D Gaussian Splatting](https://repo-sam.inria.fr/fungraph/3d-gaussian-splatting/) was proposed in SIGGRAPH 2023 from INRIA, and is a completely different method of representing radiance fields by explicitly storing a collection of 3D volumetric gaussians. These can be "splatted", or projected, onto a 2D image provided a camera pose, and rasterized to obtain per-pixel colors. Because rasterization is very fast on GPUs, this method can render much faster than neural representations of radiance fields.

To avoid confusion with the original paper, we refer to nerfstudio's implementation as "Splatfacto", which will drift away from the original as more features are added. Just as Nerfacto is a blend of various different methods, Splatfacto will be a blend of different gaussian splatting methodologies.

### Installation

```{button-link} https://docs.gsplat.studio/
Expand All @@ -18,30 +20,30 @@ Paper Website
GSplat
```

Nerfstudio uses [gsplat](https://github.com/nerfstudio-project/gsplat) as its gaussian rasterization backend, an in-house re-implementation which is designed to be more developer friendly. This can be installed with `pip install gsplat`. The associated CUDA code will be compiled the first time gaussian splatting is executed. Some users with PyTorch 2.0 have experienced issues with this, which can be resolved by either installing gsplat from source, or upgrading torch to 2.1.
Nerfstudio uses [gsplat](https://github.com/nerfstudio-project/gsplat) as its gaussian rasterization backend, an in-house re-implementation which is designed to be more developer friendly. This can be installed with `pip install gsplat`. The associated CUDA code will be compiled the first time gsplat is executed. Some users with PyTorch 2.0 have experienced issues with this, which can be resolved by either installing gsplat from source, or upgrading torch to 2.1.

### Data
Gaussian Splatting works much better if you initialize it from pre-existing geometry, such as SfM points from COLMAP. COLMAP datasets or datasets from `ns-process-data` will automatically save these points and initialize gaussians on them. Other datasets currently do not support initialization, and will initialize gaussians randomly. Initializing from other data inputs (i.e. depth from phone app scanners) may be supported in the future.
Gaussian spltting works much better if you initialize it from pre-existing geometry, such as SfM points from COLMAP. COLMAP datasets or datasets from `ns-process-data` will automatically save these points and initialize gaussians on them. Other datasets currently do not support initialization, and will initialize gaussians randomly. Initializing from other data inputs (i.e. depth from phone app scanners) may be supported in the future.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

spltting

Because gaussian splatting trains on *full images* instead of bundles of rays, there is a new datamanager in `full_images_datamanager.py` which undistorts input images, caches them, and provides single images at each train step.
Because the method trains on *full images* instead of bundles of rays, there is a new datamanager in `full_images_datamanager.py` which undistorts input images, caches them, and provides single images at each train step.


### Running the Method
To run gaussian splatting, run `ns-train gaussian-splatting --data <data>`. Just like NeRF methods, the splat can be interactively viewed in the web-viewer, loaded from a checkpoint, rendered, and exported.
To run splatfacto, run `ns-train splatfacto --data <data>`. Just like NeRF methods, the splat can be interactively viewed in the web-viewer, loaded from a checkpoint, rendered, and exported.

#### Quality and Regularization
The default settings provided maintain a balance between speed, quality, and splat file size, but if you care more about quality than training speed or size, you can decrease the alpha cull threshold
(threshold to delete translucent gaussians) and disable culling after 15k steps like so: `ns-train gaussian-splatting --pipeline.model.cull_scale_thresh=0.005 --pipeline.model.continue_cull_post_densification=False --data <data>`
(threshold to delete translucent gaussians) and disable culling after 15k steps like so: `ns-train splatfacto --pipeline.model.cull_scale_thresh=0.005 --pipeline.model.continue_cull_post_densification=False --data <data>`

A common artifact in splatting is long, spikey gaussians. [PhysGaussian](https://xpandora.github.io/PhysGaussian/) proposes an example of a scale-regularizer that encourages gaussians to be more evenly shaped. To enable this, set the `use_scale_regularization` flag to `True`.
A common artifact in splatting is long, spikey gaussians. [PhysGaussian](https://xpandora.github.io/PhysGaussian/) proposes a scale regularizer that encourages gaussians to be more evenly shaped. To enable this, set the `use_scale_regularization` flag to `True`.

### Details
For more details on the method, see the [original paper](https://arxiv.org/abs/2308.04079). Additionally, for a detailed derivation of the gradients used in the gsplat library, see [here](https://arxiv.org/abs/2312.02121).

### Exporting splats
Gaussian splats can be exported as a `.ply` file which are ingestable by a variety of online web viewers. You can do this via the viewer, or `ns-export gaussian-splat --load-config <config> --output-dir exports/splat`. Currently splats can only be exported from trained splats, not from nerfacto.

Nerfstudio gaussian splat exports currently supports multiple third-party splat viewers:
Nerfstudio's splat export currently supports multiple third-party splat viewers:
- [Polycam Viewer](https://poly.cam/tools/gaussian-splatting)
- [Playcanvas SuperSplat](https://playcanvas.com/super-splat)
- [WebGL Viewer by antimatter15](https://antimatter15.com/splat/)
Expand All @@ -50,6 +52,8 @@ Nerfstudio gaussian splat exports currently supports multiple third-party splat

### FAQ
- Can I export a mesh or pointcloud?
Currently these export options are not supported, but may become in the future. Contributions are always welcome!

Currently these export options are not supported, but may be in the future. Contributions are always welcome!
- Can I render fisheye, equirectangular, orthographic images?
Currently, no. Gaussian splatting assumes a perspective camera for its rasterization pipeline. Implementing other camera models is of interest but not currently planned.

Currently, no. Gaussian rasterization assumes a perspective camera for its rasterization pipeline. Implementing other camera models is of interest but not currently planned.
10 changes: 5 additions & 5 deletions nerfstudio/configs/method_configs.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,14 +51,14 @@
from nerfstudio.field_components.temporal_distortions import TemporalDistortionKind
from nerfstudio.fields.sdf_field import SDFFieldConfig
from nerfstudio.models.depth_nerfacto import DepthNerfactoModelConfig
from nerfstudio.models.gaussian_splatting import GaussianSplattingModelConfig
from nerfstudio.models.generfacto import GenerfactoModelConfig
from nerfstudio.models.instant_ngp import InstantNGPModelConfig
from nerfstudio.models.mipnerf import MipNerfModel
from nerfstudio.models.nerfacto import NerfactoModelConfig
from nerfstudio.models.neus import NeuSModelConfig
from nerfstudio.models.neus_facto import NeuSFactoModelConfig
from nerfstudio.models.semantic_nerfw import SemanticNerfWModelConfig
from nerfstudio.models.splatfacto import SplatfactoModelConfig
from nerfstudio.models.tensorf import TensoRFModelConfig
from nerfstudio.models.vanilla_nerf import NeRFModel, VanillaModelConfig
from nerfstudio.pipelines.base_pipeline import VanillaPipelineConfig
Expand All @@ -80,7 +80,7 @@
"generfacto": "Generative Text to NeRF model",
"neus": "Implementation of NeuS. (slow)",
"neus-facto": "Implementation of NeuS-Facto. (slow)",
"gaussian-splatting": "Gaussian Splatting model",
"splatfacto": "Gaussian Splatting model",
}

method_configs["nerfacto"] = TrainerConfig(
Expand Down Expand Up @@ -588,8 +588,8 @@
vis="viewer",
)

method_configs["gaussian-splatting"] = TrainerConfig(
method_name="gaussian-splatting",
method_configs["splatfacto"] = TrainerConfig(
method_name="splatfacto",
steps_per_eval_image=100,
steps_per_eval_batch=0,
steps_per_save=2000,
Expand All @@ -601,7 +601,7 @@
datamanager=FullImageDatamanagerConfig(
dataparser=NerfstudioDataParserConfig(load_3D_points=True),
),
model=GaussianSplattingModelConfig(),
model=SplatfactoModelConfig(),
),
optimizers={
"xyz": {
Expand Down
2 changes: 1 addition & 1 deletion nerfstudio/data/dataparsers/nerfstudio_dataparser.py
Original file line number Diff line number Diff line change
Expand Up @@ -386,7 +386,7 @@ def _generate_dataparser_outputs(self, split="train"):
else:
if not self.prompted_user:
CONSOLE.print(
"[bold yellow]Warning: load_3D_points set to true but no point cloud found. gaussian-splatting models will use random point cloud initialization."
"[bold yellow]Warning: load_3D_points set to true but no point cloud found. splatfacto will use random point cloud initialization."
)
ply_file_path = None

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -99,10 +99,10 @@ def projection_matrix(znear, zfar, fovx, fovy, device: Union[str, torch.device]


@dataclass
class GaussianSplattingModelConfig(ModelConfig):
"""Gaussian Splatting Model Config"""
class SplatfactoModelConfig(ModelConfig):
"""Splatfacto Model Config, nerfstudio's implementation of Gaussian Splatting"""

_target: Type = field(default_factory=lambda: GaussianSplattingModel)
_target: Type = field(default_factory=lambda: SplatfactoModel)
warmup_length: int = 500
"""period of steps where refinement is turned off"""
refine_every: int = 100
Expand Down Expand Up @@ -149,14 +149,14 @@ class GaussianSplattingModelConfig(ModelConfig):
"""


class GaussianSplattingModel(Model):
"""Gaussian Splatting model
class SplatfactoModel(Model):
"""Nerfstudio's implementation of Gaussian Splatting

Args:
config: Gaussian Splatting configuration to instantiate model
config: Splatfacto configuration to instantiate model
"""

config: GaussianSplattingModelConfig
config: SplatfactoModelConfig

def __init__(
self,
Expand Down
6 changes: 3 additions & 3 deletions nerfstudio/scripts/exporter.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
from nerfstudio.exporter.exporter_utils import collect_camera_poses, generate_point_cloud, get_mesh_from_filename
from nerfstudio.exporter.marching_cubes import generate_mesh_with_multires_marching_cubes
from nerfstudio.fields.sdf_field import SDFField # noqa
from nerfstudio.models.gaussian_splatting import GaussianSplattingModel
from nerfstudio.models.splatfacto import SplatfactoModel
from nerfstudio.pipelines.base_pipeline import Pipeline, VanillaPipeline
from nerfstudio.utils.eval_utils import eval_setup
from nerfstudio.utils.rich_utils import CONSOLE
Expand Down Expand Up @@ -488,9 +488,9 @@ def main(self) -> None:

_, pipeline, _, _ = eval_setup(self.load_config)

assert isinstance(pipeline.model, GaussianSplattingModel)
assert isinstance(pipeline.model, SplatfactoModel)

model: GaussianSplattingModel = pipeline.model
model: SplatfactoModel = pipeline.model

filename = self.output_dir / "splat.ply"

Expand Down
4 changes: 2 additions & 2 deletions nerfstudio/viewer/export_panel.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@

from nerfstudio.data.scene_box import OrientedBox
from nerfstudio.models.base_model import Model
from nerfstudio.models.gaussian_splatting import GaussianSplattingModel
from nerfstudio.models.splatfacto import SplatfactoModel
from nerfstudio.viewer.control_panel import ControlPanel


Expand All @@ -32,7 +32,7 @@ def populate_export_tab(
config_path: Path,
viewer_model: Model,
) -> None:
viewing_gsplat = isinstance(viewer_model, GaussianSplattingModel)
viewing_gsplat = isinstance(viewer_model, SplatfactoModel)
if not viewing_gsplat:
crop_output = server.add_gui_checkbox("Use Crop", False)

Expand Down
6 changes: 3 additions & 3 deletions nerfstudio/viewer/render_state_machine.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@

from nerfstudio.cameras.cameras import Cameras
from nerfstudio.model_components.renderers import background_color_override_context
from nerfstudio.models.gaussian_splatting import GaussianSplattingModel
from nerfstudio.models.splatfacto import SplatfactoModel
from nerfstudio.utils import colormaps, writer
from nerfstudio.utils.writer import GLOBAL_BUFFER, EventName, TimeWriter
from nerfstudio.viewer.utils import CameraState, get_camera
Expand Down Expand Up @@ -136,7 +136,7 @@ def _render_img(self, camera_state: CameraState):

with TimeWriter(None, None, write=False) as vis_t:
with self.viewer.train_lock if self.viewer.train_lock is not None else contextlib.nullcontext():
if isinstance(self.viewer.get_model(), GaussianSplattingModel):
if isinstance(self.viewer.get_model(), SplatfactoModel):
color = self.viewer.control_panel.background_color
background_color = torch.tensor(
[color[0] / 255.0, color[1] / 255.0, color[2] / 255.0],
Expand Down Expand Up @@ -168,7 +168,7 @@ def _render_img(self, camera_state: CameraState):
self.viewer.get_model().train()
num_rays = (camera.height * camera.width).item()
if self.viewer.control_panel.layer_depth:
if isinstance(self.viewer.get_model(), GaussianSplattingModel):
if isinstance(self.viewer.get_model(), SplatfactoModel):
# Gaussians render much faster than we can send depth images, so we do some downsampling.
assert len(outputs["depth"].shape) == 3
assert outputs["depth"].shape[-1] == 1
Expand Down
4 changes: 2 additions & 2 deletions nerfstudio/viewer/viewer.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
from nerfstudio.configs import base_config as cfg
from nerfstudio.data.datasets.base_dataset import InputDataset
from nerfstudio.models.base_model import Model
from nerfstudio.models.gaussian_splatting import GaussianSplattingModel
from nerfstudio.models.splatfacto import SplatfactoModel
from nerfstudio.pipelines.base_pipeline import Pipeline
from nerfstudio.utils.decorators import check_main_thread, decorate_all
from nerfstudio.utils.writer import GLOBAL_BUFFER, EventName
Expand Down Expand Up @@ -250,7 +250,7 @@ def nested_folder_install(folder_labels: List[str], prev_labels: List[str], elem

# Diagnostics for Gaussian Splatting: where the points are at the start of training.
# This is hidden by default, it can be shown from the Viser UI's scene tree table.
if isinstance(pipeline.model, GaussianSplattingModel):
if isinstance(pipeline.model, SplatfactoModel):
self.viser_server.add_point_cloud(
"/gaussian_splatting_initial_points",
points=pipeline.model.means.numpy(force=True) * VISER_NERFSTUDIO_SCALE_RATIO,
Expand Down
4 changes: 2 additions & 2 deletions nerfstudio/viewer_legacy/server/render_state_machine.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@

from nerfstudio.cameras.cameras import Cameras
from nerfstudio.model_components.renderers import background_color_override_context
from nerfstudio.models.gaussian_splatting import GaussianSplattingModel
from nerfstudio.models.splatfacto import SplatfactoModel
from nerfstudio.utils import colormaps, writer
from nerfstudio.utils.writer import GLOBAL_BUFFER, EventName, TimeWriter
from nerfstudio.viewer_legacy.server import viewer_utils
Expand Down Expand Up @@ -130,7 +130,7 @@ def _render_img(self, cam_msg: CameraMessage):
with self.viewer.train_lock if self.viewer.train_lock is not None else contextlib.nullcontext():
# TODO jake-austin: Make this check whether the model inherits from a camera based model or a ray based model
# TODO Zhuoyang: First made some dummy judgements, need to be fixed later
isGaussianSplattingModel = isinstance(self.viewer.get_model(), GaussianSplattingModel)
isGaussianSplattingModel = isinstance(self.viewer.get_model(), SplatfactoModel)
if isGaussianSplattingModel:
# TODO fix me before ship
camera_ray_bundle = camera.generate_rays(camera_indices=0, aabb_box=self.viewer.get_model().render_aabb)
Expand Down
2 changes: 1 addition & 1 deletion tests/test_train.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
"neus",
"generfacto",
"neus-facto",
"gaussian-splatting",
"splatfacto",
]


Expand Down
Loading