-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy patheval.py
68 lines (53 loc) · 2.05 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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import numpy as np
from skimage.measure import compare_ssim as SSIM
from torch.autograd import Variable
from utils import save_image
def test(config, test_data_loader, gen, criterionMSE, epoch):
avg_mse = 0
avg_psnr = 0
avg_ssim = 0
for i, batch in enumerate(test_data_loader):
x, t = Variable(batch[0]), Variable(batch[1])
if config.cuda:
x = x.cuda(0)
t = t.cuda(0)
att, out = gen(x)
if epoch % config.snapshot_interval == 0:
h = 1
w = 3
c = 3
width = config.width
height = config.height
allim = np.zeros((h, w, c, width, height))
x_ = x.cpu().numpy()[0]
t_ = t.cpu().numpy()[0]
out_ = out.cpu().numpy()[0]
in_rgb = x_[:3]
t_rgb = t_[:3]
out_rgb = np.clip(out_[:3], 0, 1)
allim[0, 0, :] = in_rgb * 255
allim[0, 1, :] = out_rgb * 255
allim[0, 2, :] = t_rgb * 255
allim = allim.transpose(0, 3, 1, 4, 2)
allim = allim.reshape((h*height, w*width, c))
save_image(config.out_dir, allim, i, epoch)
mse = criterionMSE(out, t)
psnr = 10 * np.log10(1 / mse.item())
img1 = np.tensordot(out.cpu().numpy()[0, :3].transpose(1, 2, 0), [0.298912, 0.586611, 0.114478], axes=1)
img2 = np.tensordot(t.cpu().numpy()[0, :3].transpose(1, 2, 0), [0.298912, 0.586611, 0.114478], axes=1)
ssim = SSIM(img1, img2)
avg_mse += mse.item()
avg_psnr += psnr
avg_ssim += ssim
avg_mse = avg_mse / len(test_data_loader)
avg_psnr = avg_psnr / len(test_data_loader)
avg_ssim = avg_ssim / len(test_data_loader)
print("===> Avg. MSE: {:.4f}".format(avg_mse))
print("===> Avg. PSNR: {:.4f} dB".format(avg_psnr))
print("===> Avg. SSIM: {:.4f} dB".format(avg_ssim))
log_test = {}
log_test['epoch'] = epoch
log_test['mse'] = avg_mse
log_test['psnr'] = avg_psnr
log_test['ssim'] = avg_ssim
return log_test