Accepted by WACV 2023. Check out our paper on arXiv.
- Python >= 3.8
- PyTorch == 1.9.1
- MinkowskiEngine == 0.5.4
-
Install PyTorch
-
Install PyTorch Scatter
-
Install MinkowskiEngine
-
Install
X-NeRF
pip install -e .
# training for single-scene
CUDA_VISIBLE_DEVICES=0 python scripts/train.py dataset=single_scene
# training for multi-scene
CUDA_VISIBLE_DEVICES=0 python scripts/train.py dataset=multi_scene
# eval
CUDA_VISIBLE_DEVICES=0 python scripts/eval.py dataset=multi_scene
Please refer to ./configs/ for more details.
Note that training X-NeRF may consume much GPU memory. We use an NVIDIA A100 for training. You can reduce the batch size if you meet with OOM. And we have not supported multi-gpu training yet.
You can check our dataset in ./data/. The folder contains 10 scenes, each with 7 views. In our paper, we treat scene 1-6 as seen scenes and treat scene 7-10 as novel scenes to do zero-shot cross-scene evaluation. We use view 6 as novel view in all scenes. For more details about how to load and process the data, please refer to XNeRF_SingleScene.py.
You can download our pre-trained weight from Google Drive or Baidu Pan. To load the weight, you can set ckpt_path={path/to/weight}
in the command.
- Multi-gpu training
- Reduce the memory consumption when training
- More scenes
- More backbones
The CUDA extension for rendering is adapted from DVGO and the SH function is adapted from PlenOctrees.