forked from eriksandstroem/Point-SLAM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_deterministic.py
75 lines (60 loc) · 2.07 KB
/
test_deterministic.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
import torch
import argparse
import subprocess
import os
import sys
config_folder = "configs"
outputs_folder = "output"
configs = {"Replica": "Replica/office0.yaml",
# "ScanNet": "ScanNet/scene0103.yaml",
#"TUM_RGBD": "TUM_RGBD/freiburg1_desk.yaml"
}
outputs = {"Replica": "Replica/office0/ckpts",
# "ScanNet": "ScanNet/scene0103/reference/ckpts",
# "TUM_RGBD": "TUM_RGBD/freiburg1_desk/reference/ckpts"
}
tensor_names = ["geo_feats", "col_feats", "gt_c2w_list", "estimate_c2w_list"]
def run(args):
for k, v in configs.items():
print("running {}".format(k))
proc = subprocess.Popen(["python", "run.py", os.path.join(
config_folder, v), "--stop={}".format(args.n_frames)], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
for c in iter(lambda: proc.stdout.read(1), b""):
sys.stdout.buffer.write(c)
print("{} terminated".format(k))
def rename(args, name):
cwd = os.getcwd()
for k, v in outputs.items():
folder = os.path.join(cwd, outputs_folder, v)
os.chdir(folder)
os.rename("{:05d}.tar".format(args.n_frames), "{}.tar".format(name))
os.chdir(cwd)
def compare():
cwd = os.getcwd()
for k, v in outputs.items():
folder = os.path.join(cwd, outputs_folder, v)
os.chdir(folder)
ref = torch.load("ref.tar")
new = torch.load("new.tar")
for tensor_name in tensor_names:
print(k, tensor_name, torch.equal(
ref[tensor_name], new[tensor_name]))
def main(args):
import time
tic = time.perf_counter()
run(args)
if args.gen_ref:
rename(args, "ref")
else:
rename(args, "new")
compare()
toc = time.perf_counter()
print("elapsed time", toc-tic)
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("--n_frames", type=int, default=50,
help="number of frames to run the scripts")
parser.add_argument("--gen_ref", action="store_true")
parser.set_defaults(gen_ref=False)
args = parser.parse_args()
main(args)