-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathpsnr_ssim.py
80 lines (66 loc) · 2.45 KB
/
psnr_ssim.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
import numpy as np
from skimage.measure import compare_ssim
from PIL import Image
import os
def rgb2y_matlab(x):
"""Convert RGB image to illumination Y in Ycbcr space in matlab way.
-------------
# Args
- Input: x, byte RGB image, value range [0, 255]
- Ouput: byte gray image, value range [16, 235]
# Shape
- Input: (H, W, C)
- Output: (H, W)
"""
K = np.array([65.481, 128.553, 24.966]) / 255.0
Y = 16 + np.matmul(x, K)
return Y.astype(np.uint8)
def PSNR(im1, im2, use_y_channel=True):
"""Calculate PSNR score between im1 and im2
--------------
# Args
- im1, im2: input byte RGB image, value range [0, 255]
- use_y_channel: if convert im1 and im2 to illumination channel first
"""
if use_y_channel:
im1 = rgb2y_matlab(im1)
im2 = rgb2y_matlab(im2)
im1 = im1.astype(np.float)
im2 = im2.astype(np.float)
mse = np.mean(np.square(im1 - im2))
return 10 * np.log10(255**2 / mse)
def SSIM(gt_img, noise_img):
"""Calculate SSIM score between im1 and im2 in Y space
-------------
# Args
- gt_img: ground truth image, byte RGB image
- noise_img: image with noise, byte RGB image
"""
gt_img = rgb2y_matlab(gt_img)
noise_img = rgb2y_matlab(noise_img)
ssim_score = compare_ssim(gt_img, noise_img, gaussian_weights=True,
sigma=1.5, use_sample_covariance=False)
return ssim_score
def psnr_ssim_dir(gt_dir, test_dir):
gt_img_list = sorted([x for x in sorted(os.listdir(gt_dir))])
test_img_list = sorted([x for x in sorted(os.listdir(test_dir))])
# assert gt_img_list == test_img_list, 'Test image names are different from gt images.'
psnr_score = 0
ssim_score = 0
for gt_name, test_name in zip(gt_img_list, test_img_list):
gt_img = Image.open(os.path.join(gt_dir, gt_name))
test_img = Image.open(os.path.join(test_dir, test_name))
gt_img = np.array(gt_img)
test_img = np.array(test_img)
psnr_score += PSNR(gt_img, test_img)
ssim_score += SSIM(gt_img, test_img)
return psnr_score / len(gt_img_list), ssim_score / len(gt_img_list)
if __name__ == '__main__':
gt_dir = 'test_dirs/Helen_test_DIC/HR'
test_dirs = [
'./results_helen/SPARNet_S16_V4_Attn2D',
'./results_helen/SPARNetLight_Attn3D',
]
for td in test_dirs:
result = psnr_ssim_dir(td, gt_dir)
print(td, result)