Skip to content

Latest commit

 

History

History
111 lines (88 loc) · 3.2 KB

README.md

File metadata and controls

111 lines (88 loc) · 3.2 KB

OmniSDF: OmniSDF: Scene Reconstruction using Omnidirectional Signed Distance Functions and Adaptive Binoctrees


Hakyeong Kim, Andréas Meuleman, Hyeonjoong Jang, James Tompkin, Min H. Kim

This repository is the official implementation of the paper OmniSDF: OmniSDF: Scene Reconstruction using Omnidirectional Signed Distance Functions and Adaptive Binoctrees presented in CVPR 2024.

teaser

Tested Environments

  • OS : Ubuntu 20.04.5 LTS
  • CPU : Intel(R) Xeon(R) Silver 4214R CPU @ 2.40GHz
  • GPU : NVIDIA RTX A6000
  • CUDA toolkit ver. >=12.0

Dataset convention

We provide synthetic dataset for the demo. Input data are organized as follow;

input_video
|--<scene_name>
   |-- idepth              # Inverse depth extracted from pretrained network
       |-- 0.exr
       |-- 1.exr
       ...
   |-- traj.csv            # Camera-to-world matrix
   |-- video.mp4           # Egocentric RGB video
   |-- mask_img.png        # Mask image to mask out camera stick

Download and unzip files in ./dataset before running the demo.

Installation

Setup environment by building docker image

cd env
docker build --build-arg PHYSICAL_UID=$(id -u) --build-arg PHYSICAL_GID=$(id -g) -t omnisdf:1.0 .
cd ../

Run docker container

docker run -d --gpus '"device=0"' -w /code/src/ \
-v $(pwd)/dataset:/data \
-v $(pwd):/code/src \
--name omnisdf \
-it omnisdf:1.0

Start interacting with the running container

docker exec -it omnisdf /bin/bash

Build custom CUDA library for binoctree by running below code inside the docker container.

cd binoctree/clib
python3 setup.py clean --all install
cd ../../

Demo

To train SDF network, run below:

python3 main.py --mode=train --conf="./confs/sponza_demo.conf"

To extract mesh from trained network, run below:

python3 main.py --mode=validate_mesh --conf="./confs/sponza_demo.conf" --is_continue
  • Note: Set configuration general.debug as False to save memory space. Running as debug mode will save point clouds of binoctree vertices during the training.

Trained model

We provide our trained model of sponza scene.
To extract mesh from trained network, run below:

python3 main.py --mode=validate_mesh --conf="./confs/sponza_release.conf" --is_continue

Acknowledgement

Our code is built upon NeuS. Thanks for all of these great projects.

BibTex

Please cite as;

@InProceedings{Kim_2024_CVPR,
   author = {Hakyeong Kim and Andreas Meuleman and Hyeonjoong Jang and 
   James Tompkin and Min H. Kim},
   title = {OmniSDF: Scene Reconstruction using
   Omnidirectional Signed Distance Functions and Adaptive Binoctrees},
   booktitle = {IEEE Conference on Computer Vision and 
      Pattern Recognition (CVPR)},
   month = {June},
   year = {2024}
}