-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathderain_test.py
executable file
·102 lines (76 loc) · 2.78 KB
/
derain_test.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
from MyDataset.Datasets import *
from model_Dense_w_net_modelfy_dialate import *
from Utils.Vidsom import *
from torch.utils import data as Data
from config import DefaultConfig
import torch.nn as nn
def test():
#parametre
opt = DefaultConfig()
num_works = opt.num_workers
# path
test_data_root = opt.test_data_root #test data root
load_root = opt.load_root #load weights root
save_image_root = opt.save_image_root #save image root
stage1 = Rain_steaks_with_BG()
weights = torch.load(load_root + '/stage1/'+'426.pth')
stage1.load_state_dict(weights['state_dict'])
classfy = Classfication()
weights = torch.load(load_root + '/classfy/'+'426.pth')
classfy.load_state_dict(weights['state_dict'])
stage2 = Low_BackGround()
weights = torch.load(load_root + '/stage2/' + '426.pth')
stage2.load_state_dict(weights['state_dict'])
derain = Refine()
weights = torch.load(load_root + '/derain/' + '426.pth')
derain.load_state_dict(weights['state_dict'])
#Dataloader
test_datasets = derain_test_datasets(test_data_root)
test_dataloader = Data.DataLoader(
test_datasets,
batch_size=1,
shuffle=True,
num_workers=num_works
)
criter_loss_MSE = nn.MSELoss()
#######test#######
print("------> testing")
stage1.cuda()
stage2.cuda()
classfy.cuda()
derain.cuda()
stage1.eval()
stage2.eval()
classfy.eval()
derain.eval()
test_Psnr_sum = 0.0
test_Ssim_sum = 0.0
#showing list
test_Psnr_loss = []
test_Ssim_loss = []
dict_psnr_ssim = {}
for test_step, (data, label,data_path ) in enumerate(test_dataloader,1):
data = data.clone().detach().requires_grad_(True).cuda()
label = label.cuda()
Rain_High_data = stage1(data)
img_low_backgroung = stage2(data)
out = derain(Rain_High_data, img_low_backgroung, data).cuda()
Psnr , Ssim = get_psnr_ssim(out, label)
test_Psnr_sum +=Psnr
test_Ssim_sum += Ssim
loss = criter_loss_MSE ( out , label)
if opt.save_image == True :
dict_psnr_ssim["Psnr%s_Ssim%s"%(Psnr , Ssim)] = data_path
out = out.cpu().data[0]
out = ToPILImage()(out)
image_number = re.findall(r'\d+', data_path[0])[0]
out.save(save_image_root + "/dataset1_%s.jpg"%image_number)
# loss.append
if test_step% 100 == 0:
print("Psnr={} Ssim={} loss{}".format(Psnr ,Ssim,loss.item()))
test_Psnr_loss.append(test_Psnr_sum / test_step)
test_Ssim_loss.append(test_Ssim_sum / test_step)
#
print(" avr_Psnr ={} avr_Ssim={}".format(test_Psnr_sum / test_step , test_Ssim_sum / test_step))
if __name__ == "__main__" :
test()