-
Notifications
You must be signed in to change notification settings - Fork 45
/
Copy pathimg_demo.py
50 lines (42 loc) · 1.42 KB
/
img_demo.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
import os
import torch
import cv2
import argparse
import warnings
import torchvision
import numpy as np
from utils import PSNR, validation, LossNetwork
from model.IAT_main import IAT
from torchvision.transforms import Normalize
import matplotlib.pyplot as plt
from PIL import Image
parser = argparse.ArgumentParser()
parser.add_argument('--file_name', type=str, default='demo_imgs/low_demo.jpg')
parser.add_argument('--normalize', type=bool, default=False)
parser.add_argument('--task', type=str, default='enhance', help='Choose from exposure or enhance')
config = parser.parse_args()
# Weights path
exposure_pretrain = r'best_Epoch_exposure.pth'
enhance_pretrain = r'best_Epoch_lol_v1.pth'
normalize_process = Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))
## Load Pre-train Weights
model = IAT().cuda()
if config.task == 'exposure':
model.load_state_dict(torch.load(exposure_pretrain))
elif config.task == 'enhance':
model.load_state_dict(torch.load(enhance_pretrain))
else:
warnings.warn('Only could be exposure or enhance')
model.eval()
## Load Image
img = Image.open(config.file_name)
img = (np.asarray(img)/ 255.0)
if img.shape[2] == 4:
img = img[:,:,:3]
input = torch.from_numpy(img).float().cuda()
input = input.permute(2,0,1).unsqueeze(0)
if config.normalize: # False
input = normalize_process(input)
## Forward Network
_, _ ,enhanced_img = model(input)
torchvision.utils.save_image(enhanced_img, 'result.png')