Skip to content

Latest commit

 

History

History
147 lines (102 loc) · 7.41 KB

README.md

File metadata and controls

147 lines (102 loc) · 7.41 KB

(CVPR 2023) NeFII: Inverse Rendering for Reflectance Decomposition with Near-Field Indirect Illumination

1 Preparation

  • Create conda environment

    Firstly, choose your anaconda path in requirements.sh. (e.g. source /root/anaconda3/etc/profile.d/conda.sh).

    bash requirements.sh
    conda activate nefii

2 Training

Use NeuS to train geometry.

Turn to NeuS : git clone https://github.com/Jangmin-Lee/NeuS.git.

Take the thin_cube subdataset of NeuS as an example.

Step1: Optimize for geometry.

  1. images w.o. masks.
  • modify code_path and anaconda path in run_s1_womask.sh
  • modify general.base_exp_dir and dataset.data_dir in NeuS/confs/womask.conf
    bash code/training/training_scripts/run_s1_womask.sh
  1. images w. masks.

    Take the same process like 'images without masks' except run_s1_wmask.sh and NeuS/confs/wmask.conf.

Step2: Transform datasets.

  • modify in_data_path, code_path, out_data_path, and anaconda path in neus2nefii.sh to transform datasets.
    bash code/training/training_scripts/neus2nefii.sh

Step3: Optimize for materials and environment map.

  1. images w.o. masks.
  • modify your data_path, code_path, and save_path, and anaconda path in run_s2_womask.sh.
  • modify the geometry_neus, in run_s2_womask.sh.
    bash code/training/training_scripts/run_s2_womask.sh
  1. images w. masks.

    Take the same process like 'images without masks' except run_s2_wmask.sh.

3 Training for Sec. 4.2.

As mentioned in Sec. 4.2, when comparing the performance of different approaches on synthetic data, we directly learn geometry from the mesh for each approach. This enables us to better evaluate the material estimation ability without interference from the quality of the geometry reconstruction. Below are the corresponding scripts.

Take the robot subdataset as an example.

Step1: Optimize for geometry.

  1. modify your anaconda path in run_s1.sh and run_s2.sh. (e.g. source /root/anaconda3/etc/profile.d/conda.sh).

  2. modify your data_path, code_path, and save_path in run_s1.sh and run_s2.sh.

    bash code/training/training_scripts/robot/run_s1.sh

Step2: Optimize for materials and environment map.

  • Modify the Geometry in run_s2.sh first.

    bash code/training/training_scripts/robot/run_s2.sh

4 Render Novel Views.

  1. modify your anaconda path in render.sh.
  2. modify your data_path, code_path, and save_path in render.sh.
  3. modify old_expdir, Expname, and Timestamp for rendering in render.sh.
    bash code/training/training_scripts/robot/render.sh

Tips:

  • if you training w./w.o. masks, --conf should be modified as the form of */conf_neus.conf.
  • for viewing exr images, you can use tev hdr viewer.

5 Evaluating

  1. modify your anaconda path in eval.sh.
  2. modify the code_path, data_path, and render_folder in eval.sh.
    bash code/training/training_scripts/robot/eval.sh

6 Some Important Pointers

  1. for the network.
  1. for the training phase.
  • geometry_train.py : optimization of unknown geometry with mesh.
  • sdf_dataset.py : dataloader for mesh.
  • conf : configuration file for the network and traiining strategy. It should be noted that the Step2 in Training phase is memory-consuming and you can decrease num_pixels and num_rays to train on your device.
  • conf_neus : for models traning w./w.o. masks.
  • exp_runner.py : training script for step2. DDP is also feasible.
  1. for evaluating phase.
  • render.py : novel view rendering with materials. It's memory-comsuming and decreasing Memory_capacity_level in render.sh will be help. It should be noted that the rendering phase is time-comsuing and DDP will be faster.

  • evaluate.py : evaluating script. The results can be found in code/results/*.txt.

  • fit_envmap_with_sg.py : represent an envmap with mixture of spherical Gaussians. We provide three envmaps represented by spherical Gaussians optimized via this script in the 'code/envmaps' folder.

7 Citation

@InProceedings{Wu_2023_CVPR,
    author    = {Wu, Haoqian and Hu, Zhipeng and Li, Lincheng and Zhang, Yongqiang and Fan, Changjie and Yu, Xin},
    title     = {NeFII: Inverse Rendering for Reflectance Decomposition With Near-Field Indirect Illumination},
    booktitle = {Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)},
    month     = {June},
    year      = {2023},
    pages     = {4295-4304}
  } 

8 Acknowledgement

We have used codes from the following repositories, and we thank the authors for sharing their codes.

Tips :

  • Thanks to DIVE128 for his contribution in organizing the code for the release version.