-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathhsi_denoising_gauss.py
114 lines (89 loc) · 3.31 KB
/
hsi_denoising_gauss.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
103
104
105
106
107
108
109
110
111
112
113
114
import torch
import torch.nn as nn
import torch.optim as optim
import torchvision
import torchvision.transforms as transforms
import os
import argparse
from utility import *
from hsi_setup import Engine, train_options, make_dataset
if __name__ == '__main__':
"""Training settings"""
parser = argparse.ArgumentParser(
description='Hyperspectral Image Denoising (Gaussian Noise)')
opt = train_options(parser)
print(opt)
"""Setup Engine"""
engine = Engine(opt)
"""Dataset Setting"""
HSI2Tensor = partial(HSI2Tensor, use_2dconv=engine.get_net().use_2dconv)
common_transform_1 = lambda x: x
common_transform_2 = Compose([
partial(rand_crop, cropx=32, cropy=32),
])
target_transform = HSI2Tensor()
train_transform_1 = Compose([
AddNoise(50),
HSI2Tensor()
])
train_transform_2 = Compose([
AddNoiseBlind([10, 30, 50, 70]),
HSI2Tensor()
])
print('==> Preparing data..')
icvl_64_31_TL_1 = make_dataset(
opt, train_transform_1,
target_transform, common_transform_1, 16)
icvl_64_31_TL_2 = make_dataset(
opt, train_transform_2,
target_transform, common_transform_2, 64)
"""Test-Dev"""
basefolder = '/data/weikaixuan/hsi/data/'
mat_names = ['icvl_512_30', 'icvl_512_50']
mat_datasets = [MatDataFromFolder(os.path.join(
basefolder, name), size=5) for name in mat_names]
if not engine.get_net().use_2dconv:
mat_transform = Compose([
LoadMatHSI(input_key='input', gt_key='gt',
transform=lambda x:x[:, ...][None]),
])
else:
mat_transform = Compose([
LoadMatHSI(input_key='input', gt_key='gt'),
])
mat_datasets = [TransformDataset(mat_dataset, mat_transform)
for mat_dataset in mat_datasets]
mat_loaders = [DataLoader(
mat_dataset,
batch_size=1, shuffle=False,
num_workers=1, pin_memory=opt.no_cuda
) for mat_dataset in mat_datasets]
"""Main loop"""
base_lr = opt.lr
adjust_learning_rate(engine.optimizer, opt.lr)
epoch_per_save = 10
while engine.epoch < 50:
np.random.seed() # reset seed per epoch, otherwise the noise will be added with a specific pattern
if engine.epoch == 20:
adjust_learning_rate(engine.optimizer, base_lr*0.1)
if engine.epoch == 30:
adjust_learning_rate(engine.optimizer, base_lr)
if engine.epoch == 35:
adjust_learning_rate(engine.optimizer, base_lr*0.1)
if engine.epoch == 45:
adjust_learning_rate(engine.optimizer, base_lr*0.01)
if engine.epoch <= 30:
engine.train(icvl_64_31_TL_1)
engine.validate(mat_loaders[1], 'icvl-validate-50')
else:
engine.train(icvl_64_31_TL_2)
engine.validate(mat_loaders[0], 'icvl-validate-30')
engine.validate(mat_loaders[1], 'icvl-validate-50')
print('Latest Result Saving...')
model_latest_path = os.path.join(engine.basedir, engine.prefix, 'model_latest.pth')
engine.save_checkpoint(
model_out_path=model_latest_path
)
display_learning_rate(engine.optimizer)
if engine.epoch % epoch_per_save == 0:
engine.save_checkpoint()