-
Notifications
You must be signed in to change notification settings - Fork 106
/
Copy pathmeasure_uiqm.py
44 lines (37 loc) · 1.32 KB
/
measure_uiqm.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
"""
# > Script for measuring quantitative performances in terms of
# - Structural Similarity Metric (SSIM)
# - Peak Signal to Noise Ratio (PSNR)
# > Maintainer: https://github.com/xahidbuffon
"""
## python libs
import numpy as np
from PIL import Image, ImageOps
from glob import glob
from os.path import join
from ntpath import basename
## local libs
from uqim_utils import getUIQM
def measure_UIQMs(dir_name, im_res=(256, 256)):
paths = sorted(glob(join(dir_name, "*.*")))
uqims = []
for img_path in paths:
im = Image.open(img_path).resize(im_res)
uiqm = getUIQM(np.array(im))
uqims.append(uiqm)
return np.array(uqims)
"""
Get datasets from
- http://irvlab.cs.umn.edu/resources/euvp-dataset
- http://irvlab.cs.umn.edu/resources/ufo-120-dataset
"""
#inp_dir = "/home/xahid/datasets/released/EUVP/test_samples/Inp/"
inp_dir = "/home/xahid/datasets/released/UFO-120/TEST/lrd/"
## UIQMs of the distorted input images
inp_uqims = measure_UIQMs(inp_dir)
print ("Input UIQMs >> Mean: {0} std: {1}".format(np.mean(inp_uqims), np.std(inp_uqims)))
## UIQMs of the enhanceded output images
#gen_dir = "eval_data/euvp_test/funie-gan/"
gen_dir = "eval_data/ufo_test/deep-sesr/"
gen_uqims = measure_UIQMs(gen_dir)
print ("Enhanced UIQMs >> Mean: {0} std: {1}".format(np.mean(gen_uqims), np.std(gen_uqims)))