-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtest_net.py
More file actions
97 lines (82 loc) · 2.6 KB
/
test_net.py
File metadata and controls
97 lines (82 loc) · 2.6 KB
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
import argparse
import os
import torch
import torch.nn.parallel
import torch.optim
import torch.utils.data
import torch.utils.data.distributed
from lib.config import cfg
from lib.data import build_data_loader
from lib.engine.inference import inference
from lib.models.model import build_model
from lib.utils.checkpoint import Checkpointer
from lib.utils.comm import get_rank, synchronize
from lib.utils.directory import makedir
from lib.utils.logger import setup_logger
def main():
parser = argparse.ArgumentParser(
description="PyTorch Image-Text Matching Inference"
)
parser.add_argument(
"--config-file",
default="",
metavar="FILE",
help="path to config file",
type=str,
)
parser.add_argument(
"--checkpoint-file",
default="",
metavar="FILE",
help="path to checkpoint file",
type=str,
)
parser.add_argument(
"--local-rank",
default=0,
type=int,
)
parser.add_argument(
"opts",
help="Modify config options using the command-line",
default=None,
nargs=argparse.REMAINDER,
)
args = parser.parse_args()
num_gpus = int(os.environ["WORLD_SIZE"]) if "WORLD_SIZE" in os.environ else 1
distributed = num_gpus > 1
if distributed:
torch.cuda.set_device(args.local_rank)
torch.distributed.init_process_group(backend="nccl", init_method="env://")
synchronize()
cfg.merge_from_file(args.config_file)
cfg.merge_from_list(args.opts)
cfg.freeze()
model = build_model(cfg)
device = "cuda" if torch.cuda.is_available() else "cpu"
model.to(device)
output_dir = os.path.join("./output", args.config_file[8:-5])
checkpointer = Checkpointer(model, save_dir=output_dir)
_ = checkpointer.load(args.checkpoint_file)
output_folders = list()
dataset_names = cfg.DATASETS.TEST
for dataset_name in dataset_names:
output_folder = os.path.join(output_dir, "inference", dataset_name)
makedir(output_folder)
output_folders.append(output_folder)
data_loaders_val = build_data_loader(
cfg, is_train=False, is_distributed=distributed
)
for data_loader_val, output_folder in zip(data_loaders_val, output_folders):
logger = setup_logger("CompFashion", output_folder, get_rank())
logger.info("Using {} GPUs".format(num_gpus))
inference(
model,
data_loader_val,
device=device,
)
synchronize()
logger.handlers.pop()
logger.handlers.pop()
if __name__ == "__main__":
main()