Skip to content

Latest commit

 

History

History
41 lines (27 loc) · 2.16 KB

README.md

File metadata and controls

41 lines (27 loc) · 2.16 KB

tf-nlr

An unofficial implementation of Neural Lumigraph Rendering in TensorFlow 2.
Undergraduate project by Laura Ann Perkins, New College of Florida.

3D model reconstructed with tf-nlr

This project is based on the 2021 paper Neural Lumigraph Rendering. I first started working on this project back in July 2021, before the code for MetaNLR++ had been released. This is the first open-source implementation of their original paper.

Requirements

  • This project requires Python 3.6+ with TensorFlow 2.5.0 (among other dependencies).
  • For the SIREN models, it builds upon tf_siren.
  • To run the Jupyter notebook, download the free NLR dataset and place nlr_dataset in a folder named data in the root directory.

Usage

To get started with tf-nlr, check out the Jupyter notebook. There you can see how to:

  • load a pre-trained model.
  • train your own model.
  • render fitted views.
  • render novel views.

You can train a model from scratch with train.py.

python train.py --dataset_path path/to/data/folder --img_ratio scale_ratio --out_folder path/to/output/folder

To evaluate a fitted model, run test.py.

python test.py --model path/to/fitted/model --dataset_path path/to/data/folder --img_ratio scale_ratio

Note that img_ratio divides the image dimensions. So if you enter img_ratio=5, the images will be five times smaller.

For more options, try running either script with the help flag, e.g. python train.py -h, or edit the config file.

Pretrained models

The h5 directory contains two trained models. The folder pretrain is a training initialization; the neural SDF is initialized to a radius of 0.5. The folder L1 contains a trained model for the scene titled L1 in the NLR dataset.