This repository contains the official implementation associated with the paper "Deformable 3D Gaussians for High-Fidelity Monocular Dynamic Scene Reconstruction".
- 23/11/16, full code and real-time viewer released.
- 23/11/4, update the computation of LPIPS in metrics.py. Previously, the
lpipsPyTorch
was unable to execute on CUDA, prompting us to switch to thelpips
library (~20x faster). - 23/10/25, update real-time viewer on project page. Many, many thanks to @yihua7 for implementing the real-time viewer adapted for Deformable-GS. Also, thanks to @ashawkey for releasing the original GUI.
In our paper, we use:
- synthetic dataset from D-NeRF
- real-world dataset from NeRF-DS and Hyper-NeRF .
We organize the datasets as follows:
├── data
│ | D-NeRF
│ ├── hook
│ ├── standup
│ ├── ...
│ | NeRF-DS
│ ├── as
│ ├── basin
│ ├── ...
│ | HyperNeRF
│ ├── interp
│ ├── misc
│ ├── virg
I have identified an inconsistency in the D-NeRF's Lego dataset. Specifically, the scenes corresponding to the training set differ from those in the test set. This discrepancy can be verified by observing the angle of the flipped Lego shovel. To meaningfully evaluate the performance of our method on this dataset, I recommend using the validation set of the Lego dataset as the test set.
git clone https://github.com/ingra14m/Deformable-3D-Gaussians --recursive
cd Deformable-3D-Gaussians
conda create -n deformable_gaussian_env python=3.7
conda activate deformable_gaussian_env
# install pytorch
pip install torch==1.13.1+cu116 torchvision==0.14.1+cu116 torchaudio==0.13.1 --extra-index-url https://download.pytorch.org/whl/cu116
# install dependencies
pip install -r requirements.txt
D-NeRF:
python train.py -s path/to/your/d-nerf/dataset -m output/exp-name --eval --is_blender
NeRF-DS/HyperNeRF:
python train.py -s path/to/your/real-world/dataset -m output/exp-name --eval
6DoF Transformation:
We have also implemented the 6DoF transformation of 3D-GS, which may lead to an improvement in metrics but will reduce the speed of training and inference.
# D-NeRF
python train.py -s path/to/your/d-nerf/dataset -m output/exp-name --eval --is_blender --is_6dof
# NeRF-DS & HyperNeRF
python train.py -s path/to/your/real-world/dataset -m output/exp-name --eval --is_6dof
You can also train with the GUI:
python train_gui.py -s path/to/your/dataset -m output/exp-name --eval --is_blender
- click
start
to start training, and clickstop
to stop training. - The GUI viewer is still under development, many buttons do not have corresponding functions currently. We plan to :
- reload checkpoints from the pre-trained model.
- Complete the functions of the other vacant buttons in the GUI.
python render.py -m output/exp-name
python metrics.py -m output/exp-name
We provide several modes for rendering:
render
: render all the test imagestime
: time interpolation tasks for D-NeRF datasetall
: time and view synthesis tasks for D-NeRF datasetview
: view synthesis tasks for real-world datasetoriginal
: time and view synthesis tasks for real-world dataset
Quantitative Results
Qualitative Results
See more visualization on our project page.
Since the camera pose in HyperNeRF is less precise compared to NeRF-DS, we use HyperNeRF as a reference for partial visualization and the display of Failure Cases, but do not include it in the calculation of quantitative metrics. The results of the HyperNeRF dataset can be viewed on the project page.
viewer.mp4
@article{yang2023deformable3dgs,
title={Deformable 3D Gaussians for High-Fidelity Monocular Dynamic Scene Reconstruction},
author={Yang, Ziyi and Gao, Xinyu and Zhou, Wen and Jiao, Shaohui and Zhang, Yuqing and Jin, Xiaogang},
journal={arXiv preprint arXiv:2309.13101},
year={2023}
}
And thanks to the authors of 3D Gaussians for their excellent code, please consider also cite this repository:
@Article{kerbl3Dgaussians,
author = {Kerbl, Bernhard and Kopanas, Georgios and Leimk{\"u}hler, Thomas and Drettakis, George},
title = {3D Gaussian Splatting for Real-Time Radiance Field Rendering},
journal = {ACM Transactions on Graphics},
number = {4},
volume = {42},
month = {July},
year = {2023},
url = {https://repo-sam.inria.fr/fungraph/3d-gaussian-splatting/}
}