forked from chaofengc/IQA-PyTorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
inference_iqa.py
79 lines (66 loc) · 2.57 KB
/
inference_iqa.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
import argparse
import glob
import os
from pyiqa import create_metric
from tqdm import tqdm
def main():
"""Inference demo for pyiqa.
"""
parser = argparse.ArgumentParser()
parser.add_argument('-i', '--input', type=str, default=None, help='input image/folder path.')
parser.add_argument('-r', '--ref', type=str, default=None, help='reference image/folder path if needed.')
parser.add_argument(
'--metric_mode',
type=str,
default='FR',
help='metric mode Full Reference or No Reference. options: FR|NR.')
parser.add_argument('-m', '--metric_name', type=str, default='PSNR', help='IQA metric name, case sensitive.')
parser.add_argument('--save_file', type=str, default=None, help='path to save results.')
args = parser.parse_args()
metric_name = args.metric_name.lower()
# set up IQA model
iqa_model = create_metric(metric_name, metric_mode=args.metric_mode)
metric_mode = iqa_model.metric_mode
if os.path.isfile(args.input):
input_paths = [args.input]
if args.ref is not None:
ref_paths = [args.ref]
else:
input_paths = sorted(glob.glob(os.path.join(args.input, '*')))
if args.ref is not None:
ref_paths = sorted(glob.glob(os.path.join(args.ref, '*')))
if args.save_file:
sf = open(args.save_file, 'w')
avg_score = 0
test_img_num = len(input_paths)
if metric_name != 'fid':
pbar = tqdm(total=test_img_num, unit='image')
for idx, img_path in enumerate(input_paths):
img_name = os.path.basename(img_path)
if metric_mode == 'FR':
ref_img_path = ref_paths[idx]
else:
ref_img_path = None
score = iqa_model(img_path, ref_img_path).cpu().item()
avg_score += score
pbar.update(1)
pbar.set_description(f'{metric_name} of {img_name}: {score}')
pbar.write(f'{metric_name} of {img_name}: {score}')
if args.save_file:
sf.write(f'{img_name}\t{score}\n')
pbar.close()
avg_score /= test_img_num
else:
assert os.path.isdir(args.input), 'input path must be a folder for FID.'
avg_score = iqa_model(args.input, args.ref)
msg = f'Average {metric_name} score of {args.input} with {test_img_num} images is: {avg_score}'
print(msg)
if args.save_file:
sf.write(msg + '\n')
sf.close()
if args.save_file:
print(f'Done! Results are in {args.save_file}.')
else:
print(f'Done!')
if __name__ == '__main__':
main()