-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy patheval.py
45 lines (38 loc) · 1.36 KB
/
eval.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
import argparse
import core.metrics as Metrics
from PIL import Image
import numpy as np
import glob
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument('-p', '--path', type=str,
default='experiments/basic_sr_ffhq_210809_142238/results')
args = parser.parse_args()
real_names = list(glob.glob('{}/*_hr.png'.format(args.path)))
fake_names = list(glob.glob('{}/*_sr.png'.format(args.path)))
real_names.sort()
fake_names.sort()
avg_psnr = 0.0
avg_ssim = 0.0
idx = 0
for rname, fname in zip(real_names, fake_names):
# import pdb
# pdb.set_trace()
idx += 1
ridx = rname.rsplit("_hr")[0]
fidx = fname.rsplit("_sr")[0]
assert ridx == fidx, 'Image ridx:{ridx}!=fidx:{fidx}'.format(
ridx, fidx)
hr_img = np.array(Image.open(rname))
sr_img = np.array(Image.open(fname))
psnr = Metrics.calculate_psnr(sr_img, hr_img)
ssim = Metrics.calculate_ssim(sr_img, hr_img)
avg_psnr += psnr
avg_ssim += ssim
if idx % 20 == 0:
print('Image:{}, PSNR:{:.4f}, SSIM:{:.4f}'.format(idx, psnr, ssim))
avg_psnr = avg_psnr / idx
avg_ssim = avg_ssim / idx
# log
print('# Validation # PSNR: {:.2f}'.format(avg_psnr))
print('# Validation # SSIM: {:.3f}'.format(avg_ssim))