Skip to content
This repository has been archived by the owner on Jul 30, 2024. It is now read-only.

Commit

Permalink
Minor bugfixes
Browse files Browse the repository at this point in the history
Signed-off-by: Krishna Murthy <[email protected]>
  • Loading branch information
Krishna Murthy committed Apr 15, 2020
1 parent a2b00c8 commit 36bae46
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 7 deletions.
2 changes: 2 additions & 0 deletions cache_dataset.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@
import torch
from tqdm import tqdm

from load_blender import load_blender_data
from load_llff import load_llff_data
from nerf_helpers import get_ray_bundle, meshgrid_xy


Expand Down
10 changes: 5 additions & 5 deletions config/lego.yml
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
# Parameters to setup experiment.
experiment:
# Unique experiment identifier
id: lego
id: lego-lowres
# Experiment logs will be stored at "logdir"/"id"
logdir: logs
# Seed for random number generators (for repeatability).
randomseed: 42 # Cause, why not?
# Number of training iterations.
train_iters: 250000
train_iters: 200000
# Number of training iterations after which to validate.
validate_every: 100
# Number of training iterations after which to checkpoint.
Expand All @@ -23,12 +23,12 @@ dataset:
basedir: cache/nerf_synthetic/lego
# Optionally, provide a path to the pre-cached dataset dir. This
# overrides the other dataset options.
cachedir: cache/legocache/legofull
cachedir: cache/legocache200
# For the Blender datasets (synthetic), optionally return images
# at half the original resolution of 800 x 800, to save space.
half_res: True
# Stride (include one per "testskip" images in the dataset).
testskip: 10
testskip: 1
# Do not use NDC (normalized device coordinates). Usually True for
# synthetic (Blender) datasets.
no_ndc: True
Expand Down Expand Up @@ -116,7 +116,7 @@ nerf:
train:
# Number of random rays to retain from each image.
# These sampled rays are used for training, and the others are discarded.
num_random_rays: 8192 # 32 * 32 * 4
num_random_rays: 1024 # 32 * 32 * 4
# Size of each chunk (rays are batched into "chunks" and passed through
# the network)
chunksize: 131072 # 131072 # 1024 * 32
Expand Down
8 changes: 6 additions & 2 deletions train_nerf.py
Original file line number Diff line number Diff line change
Expand Up @@ -168,17 +168,21 @@ def encode_direction_fn(x):
with open(os.path.join(logdir, "config.yml"), "w") as f:
f.write(cfg.dump()) # cfg, f, default_flow_style=False)

# By default, start at iteration 0 (unless a checkpoint is specified).
start_iter = 0

# Load an existing checkpoint, if a path is specified.
if os.path.exists(configargs.load_checkpoint):
checkpoint = torch.load(configargs.load_checkpoint)
model_coarse.load_state_dict(checkpoint["model_coarse_state_dict"])
if checkpoint["model_fine_state_dict"]:
model_fine.load_state_dict(checkpoint["model_fine_state_dict"])
# optimizer.load_state_dict(checkpoint["optimizer_state_dict"])
optimizer.load_state_dict(checkpoint["optimizer_state_dict"])
start_iter = checkpoint["iter"]

# # TODO: Prepare raybatch tensor if batching random rays

for i in trange(cfg.experiment.train_iters):
for i in trange(start_iter, cfg.experiment.train_iters):

model_coarse.train()
if model_fine:
Expand Down

0 comments on commit 36bae46

Please sign in to comment.