-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtest_fullregression.py
108 lines (82 loc) · 3.55 KB
/
test_fullregression.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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import numpy as np
import matplotlib.pyplot as plt
import torch, torchvision
import os, argparse
from tqdm import tqdm
from model import FullRegression
import datasets
from utils import load_model, recover_uvd, select_gpus
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--suffix', type=str, default="full_regression",
help="the suffix of model file and log file"
)
parser.add_argument('--dataset', type=str, default='MSRA',
help="choose from MSRA, ICVL, NYU, HAND17"
)
parser.add_argument('--batch_size', type=int, default=32)
parser.add_argument('--label_size', type=int, default=64)
parser.add_argument('--kernel_size', type=int, default=7)
parser.add_argument('--sigmoid', type=float, default=1.5)
parser.add_argument('--norm_method', type=str, default='instance', help='choose from batch and instance')
parser.add_argument('--gpu_id', type=str, default='0')
parser.add_argument("--num_workers", type=int, default=9999)
parser.add_argument('--stages', type=int, default=1)
parser.add_argument('--features', type=int, default=128)
parser.add_argument('--level', type=int, default=4)
parser.add_argument('--seed', type=str, default='final')
args = parser.parse_args()
if not os.path.exists("Result"):
os.mkdir("Result")
assert os.path.exists('Model'), "Please put the models in ./Model folder"
dataset_parameters = {
"image_size" : args.label_size * 2,
"label_size" : args.label_size,
"kernel_size" : args.kernel_size,
"sigmoid" : args.sigmoid,
"dataset" : "test",
"test_only" : True,
}
test_loader_parameters = {
"batch_size" : args.batch_size,
"shuffle" : False,
"pin_memory" : True,
"drop_last" : False,
"num_workers" : min(args.num_workers, os.cpu_count()),
}
model_parameters = {
"stage" : args.stages,
"label_size" : args.label_size,
"features" : args.features,
"level" : args.level,
"norm_method" : args.norm_method,
}
model_name = "{}_{}_{}.pt".format(args.dataset, args.suffix, args.seed)
Dataset = getattr(datasets, "{}Dataset".format(args.dataset))
testset = Dataset(**dataset_parameters)
joints = testset.joint_number
config = testset.config
threshold = testset.cube_size
test_loader = torch.utils.data.DataLoader(testset, **test_loader_parameters)
select_gpus(args.gpu_id)
device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')
model = FullRegression(joints, **model_parameters)
load_model(model, os.path.join('Model', model_name), eval_mode=True)
model = model.to(device)
print("running on test dataset ......")
with torch.no_grad(), tqdm(total=len(testset) // args.batch_size + 1) as pbar:
pre_uvd = []
for batch in iter(test_loader):
img, label_img, mask, box_size, com = batch
img = img.to(device, non_blocking=True)
label_img = label_img.to(device, non_blocking=True)
mask = mask.to(device, non_blocking=True)
results = model(img, label_img, mask)
_uvd = results[-1]
_uvd = _uvd.cpu()
_uvd = recover_uvd(_uvd, box_size, com, threshold)
pre_uvd.append(_uvd.view(-1, joints * 3))
pbar.update(1)
pre_uvd = torch.cat(pre_uvd, dim=0)
pre_uvd = pre_uvd.numpy()
np.savetxt("Result/{}_{}.txt".format(args.dataset, args.suffix), pre_uvd, fmt="%.3f")