-
Notifications
You must be signed in to change notification settings - Fork 96
/
Copy pathtest_super_resolution.py
executable file
·74 lines (56 loc) · 2.63 KB
/
test_super_resolution.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
"""
## Learning Enriched Features for Real Image Restoration and Enhancement
## Syed Waqas Zamir, Aditya Arora, Salman Khan, Munawar Hayat, Fahad Shahbaz Khan, Ming-Hsuan Yang, and Ling Shao
## ECCV 2020
## https://arxiv.org/abs/2003.06792
"""
import numpy as np
import os
import argparse
from tqdm import tqdm
import torch.nn as nn
import torch
from torch.utils.data import DataLoader
import torch.nn.functional as F
import scipy.io as sio
from networks.MIRNet_model import MIRNet
from dataloaders.data_rgb import get_test_data_SR
import utils
from skimage import img_as_ubyte
parser = argparse.ArgumentParser(description='Super-resolve images of RealSR dataset')
parser.add_argument('--input_dir', default='./datasets/realSR/x',
type=str, help='Directory of validation images')
parser.add_argument('--result_dir', default='./results/super_resolution/x',
type=str, help='Directory for results')
parser.add_argument('--weights', default='./pretrained_models/super_resolution/model_SR_x',
type=str, help='Path to weights')
parser.add_argument('--gpus', default='0', type=str, help='CUDA_VISIBLE_DEVICES')
parser.add_argument('--bs', default=1, type=int, help='Batch size for dataloader')
parser.add_argument('--scale', default='4', type=str, help='Scale factor for super-resolution')
parser.add_argument('--save_images', action='store_true', help='Save super-resolved images in the result directory')
args = parser.parse_args()
os.environ["CUDA_DEVICE_ORDER"] = "PCI_BUS_ID"
os.environ["CUDA_VISIBLE_DEVICES"] = args.gpus
output_dir = args.result_dir+args.scale
utils.mkdir(output_dir)
test_dataset = get_test_data_SR(args.input_dir+args.scale+'/LR/')
test_loader = DataLoader(dataset=test_dataset, batch_size=args.bs, shuffle=False, num_workers=8, drop_last=False)
model_restoration = MIRNet()
weights = args.weights+args.scale+'.pth'
utils.load_checkpoint(model_restoration, weights)
print("===>Testing using weights: ", weights)
model_restoration.cuda()
model_restoration=nn.DataParallel(model_restoration)
model_restoration.eval()
with torch.no_grad():
for ii, data_test in enumerate(tqdm(test_loader), 0):
LR_img = data_test[0].cuda()
filenames = data_test[1]
rgb_restored = model_restoration(LR_img)
rgb_restored = torch.clamp(rgb_restored,0,1)
LR_img = LR_img.permute(0, 2, 3, 1).cpu().detach().numpy()
rgb_restored = rgb_restored.permute(0, 2, 3, 1).cpu().detach().numpy()
if args.save_images:
for batch in range(len(LR_img)):
sr_img = img_as_ubyte(rgb_restored[batch])
utils.save_img(os.path.join(output_dir, filenames[batch][:-4]+'.png'), sr_img)