| import cv2
|
| import numpy as np
|
| import onnxruntime
|
| import roop.globals
|
|
|
| from roop.utilities import resolve_relative_path
|
| from roop.typing import Frame
|
|
|
| class Frame_Masking():
|
| plugin_options:dict = None
|
| model_masking = None
|
| devicename = None
|
| name = None
|
|
|
| processorname = 'removebg'
|
| type = 'frame_masking'
|
|
|
|
|
| def Initialize(self, plugin_options:dict):
|
| if self.plugin_options is not None:
|
| if self.plugin_options["devicename"] != plugin_options["devicename"]:
|
| self.Release()
|
|
|
| self.plugin_options = plugin_options
|
| if self.model_masking is None:
|
|
|
| self.devicename = self.plugin_options["devicename"]
|
| self.devicename = self.devicename.replace('mps', 'cpu')
|
| model_path = resolve_relative_path('../models/Frame/isnet-general-use.onnx')
|
| self.model_masking = onnxruntime.InferenceSession(model_path, None, providers=roop.globals.execution_providers)
|
| self.model_inputs = self.model_masking.get_inputs()
|
| model_outputs = self.model_masking.get_outputs()
|
| self.io_binding = self.model_masking.io_binding()
|
| self.io_binding.bind_output(model_outputs[0].name, self.devicename)
|
|
|
| def Run(self, temp_frame: Frame) -> Frame:
|
|
|
| input_image = cv2.resize(temp_frame, (1024, 1024))
|
| input_image = cv2.cvtColor(input_image, cv2.COLOR_BGR2RGB)
|
| mean = [0.5, 0.5, 0.5]
|
| std = [1.0, 1.0, 1.0]
|
| input_image = (input_image / 255.0 - mean) / std
|
| input_image = input_image.transpose(2, 0, 1)
|
| input_image = np.expand_dims(input_image, axis=0)
|
| input_image = input_image.astype('float32')
|
|
|
| self.io_binding.bind_cpu_input(self.model_inputs[0].name, input_image)
|
| self.model_masking.run_with_iobinding(self.io_binding)
|
| ort_outs = self.io_binding.copy_outputs_to_cpu()
|
| result = ort_outs[0][0]
|
| del ort_outs
|
|
|
| mask = np.squeeze(result[0])
|
| min_value = np.min(mask)
|
| max_value = np.max(mask)
|
| mask = (mask - min_value) / (max_value - min_value)
|
|
|
|
|
| mask = cv2.resize(mask, (temp_frame.shape[1], temp_frame.shape[0]), interpolation=cv2.INTER_LINEAR)
|
| mask = np.reshape(mask, [mask.shape[0],mask.shape[1],1])
|
| result = mask * temp_frame.astype(np.float32)
|
| return result.astype(np.uint8)
|
|
|
|
|
|
|
| def Release(self):
|
| del self.model_masking
|
| self.model_masking = None
|
| del self.io_binding
|
| self.io_binding = None
|
|
|
|
|