Skip to content

Source Code for the Paper "MIRReS: Multi-bounce Inverse Rendering using Reservoir Sampling"

License

Notifications You must be signed in to change notification settings

xdobetter/MIRReS-ReSTIR_Nerf_mesh

 
 

Repository files navigation

MIRReS: Multi-bounce Inverse Rendering using Reservoir Sampling

This repository contains a PyTorch implementation of : MIRReS: Multi-bounce Inverse Rendering using Reservoir Sampling.

Acknowledgement

Install

git clone https://github.com/brabbitdousha/MIRReS-ReSTIR_Nerf_mesh.git
cd MIRReS-ReSTIR_Nerf_mesh

Install with pip

get right cuda version of your pytorch first

pip install -r requirements.txt

# tiny-cuda-nn
pip install git+https://github.com/NVlabs/tiny-cuda-nn/#subdirectory=bindings/torch

# nvdiffrast
pip install git+https://github.com/NVlabs/nvdiffrast/

# pytorch3d
pip install git+https://github.com/facebookresearch/pytorch3d.git

Build extension (optional)

This step is copied from nerf2mesh

By default, we use load to build the extension at runtime. However, this may be inconvenient sometimes. Therefore, we also provide the setup.py to build each extension:

# install all extension modules
bash scripts/install_ext.sh

# if you want to install manually, here is an example:
cd raymarching
python setup.py build_ext --inplace # build ext only, do not install (only can be used in the parent directory)
pip install . # install to python path (you still need the raymarching/ folder, since this only install the built extension.)

Tested environments

  • Linux with torch 2.2.0 and CUDA 12.1 on a RTX4090.

Check points and results

If you don't want to take the whole process of training, our checkpoints and results can be found at dataset and checkpoints and result

Usage

We support the original NeRF data format, so we convert the TensoIR-Synthetic into NeRF data format: Our format of TensoIR-Synthetic. and of course we support the original nerf-synthetic.

First time running will take some time to compile the CUDA extensions. If something went wrong with slangpy or other cpp extensions, switch to the debug mode, after everything runs successfully, you can switch back.

Basics

Take the TensoIR lego as an example

The first stage:

#stage0:
python main.py data/tensoir_syn/tensoir_train/tensoir_lego --workspace ir_lego/ -O --bound 1 --scale 0.8 --dt_gamma 0 --stage 0 --lambda_tv 1e-8 --iters 50000

In our paper settings, we use NeuS2 as the mesh input and refine it in the next stage, however sometimes NeuS can produce better mesh, but this is your option, you can put your own mesh from other methods.

Our mesh can be found in the mesh_stage0.rar

change the {workspace}/mesh_stage0/mesh_0.ply, to your mesh, and rename it: mesh_0.ply
Our provided mesh can be used directly, but please make sure your mesh and the mesh_0.ply are in the same coordinate system, you can check them in Blender, Maya or such.

The second stage:

#stage1:
python main.py data/tensoir_syn/tensoir_train/tensoir_lego --workspace ir_lego/ -O --bound 1 --scale 0.8 --dt_gamma 0 --stage 1 --use_brdf --use_restir --lambda_kd 0.017 --lambda_ks 0.0001 --lambda_normal 0.0001 --lambda_edgelen 0.1 --lambda_nrm 0.00035 --lambda_rgb_brdf 0.05 --lambda_brdf_diffuse 0.002 --lambda_brdf_specular 0.00003

evaluate the Novel View Synthesis using 512 spp, The spp used during training was too small, so you need to obtain the results after convergence for evaluation.

python main.py data/tensoir_syn/tensoir_train/tensoir_lego --workspace ir_lego/ -O --bound 1 --scale 0.8 --dt_gamma 0 --stage 1 --use_brdf --use_restir --test --test_no_mesh --spp 512

Albedo evaluation

this step requires the original TensoIR-Synthetic, so please download it first.

#Albedo eval
please check albedo_eval.py
you will get the albedo scale factor after running it

Relighting

# relighting eval
# for example bridge
# change the envmap and albedo scale for each scene
python main.py data/tensoir_syn/tensoir_relight/lego/test_bridge --workspace ir_lego/ -O --bound 1 --scale 0.8 --dt_gamma 0 --stage 1 --use_brdf --use_restir --test --test_no_mesh --spp 128 --albedo_scale_x X.XX --albedo_scale_y X.XX --albedo_scale_z X.XX --envmap_path data/tensoir_syn/tensoir_relight/envmap/bridge.hdr

and of course you can put the exported mesh and textures into rendering engine or such, feat0_0.jpg stands for Albedo, and in feat1_0.jpg , R is zero, G is roughness and B is metallic.

Other Datasets

All the steps of running other datasets are in the ./configs

Custom Dataset

Please check general_config_for_your_dataset

Other usage about the framework

the framework is based on nerf2mesh, please check their instruction for more details on NeRF training.

Besides, we changed their network to the original ngp network: torch-ngp because this can get better results in our settings.

Citation(arXiv)

@misc{dai2024mirres,
      title={MIRReS: Multi-bounce Inverse Rendering using Reservoir Sampling}, 
      author={Yuxin Dai and Qi Wang and Jingsen Zhu and Dianbing Xi and Yuchi Huo and Chen Qian and Ying He},
      year={2024},
      eprint={2406.16360},
      archivePrefix={arXiv},
      primaryClass={id='cs.CV' full_name='Computer Vision and Pattern Recognition' is_active=True alt_name=None in_archive='cs' is_general=False description='Covers image processing, computer vision, pattern recognition, and scene understanding. Roughly includes material in ACM Subject Classes I.2.10, I.4, and I.5.'}
}

About

Source Code for the Paper "MIRReS: Multi-bounce Inverse Rendering using Reservoir Sampling"

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 68.5%
  • Cuda 17.4%
  • C++ 6.7%
  • HTML 2.7%
  • C 2.6%
  • Shell 2.1%