| import cv2 |
| import torch |
| import onnx |
| import onnxruntime |
| import numpy as np |
|
|
| import time |
|
|
| |
| |
|
|
|
|
| class CodeFormerEnhancer: |
| def __init__(self, model_path="codeformer.onnx", device='cpu'): |
| model = onnx.load(model_path) |
| session_options = onnxruntime.SessionOptions() |
| session_options.graph_optimization_level = onnxruntime.GraphOptimizationLevel.ORT_ENABLE_ALL |
| providers = ["CPUExecutionProvider"] |
| if device == 'cuda': |
| providers = [("CUDAExecutionProvider", {"cudnn_conv_algo_search": "DEFAULT"}),"CPUExecutionProvider"] |
| self.session = onnxruntime.InferenceSession(model_path, sess_options=session_options, providers=providers) |
|
|
| def enhance(self, img, w=0.9): |
| img = cv2.resize(img, (512, 512), interpolation=cv2.INTER_LINEAR) |
| img = img.astype(np.float32)[:,:,::-1] / 255.0 |
| img = img.transpose((2, 0, 1)) |
| nrm_mean = np.array([0.5, 0.5, 0.5]).reshape((-1, 1, 1)) |
| nrm_std = np.array([0.5, 0.5, 0.5]).reshape((-1, 1, 1)) |
| img = (img - nrm_mean) / nrm_std |
|
|
| img = np.expand_dims(img, axis=0) |
|
|
| out = self.session.run(None, {'x':img.astype(np.float32), 'w':np.array([w], dtype=np.double)})[0] |
| out = (out[0].transpose(1,2,0).clip(-1,1) + 1) * 0.5 |
| out = (out * 255)[:,:,::-1] |
|
|
| return out.astype('uint8') |
|
|