| import numpy as np
|
| import math
|
|
|
| def crop_seamless(img):
|
| img_height, img_width = img.shape[:2]
|
| y, x = 16, 16
|
| h, w = img_height - 32, img_width - 32
|
| img = img[y:y+h, x:x+w]
|
| return img
|
|
|
|
|
| def esrgan_launcher_split_merge(input_image, upscale_function, models, scale_factor=4, tile_size=512, tile_padding=0.125):
|
| width, height, depth = input_image.shape
|
| output_width = width * scale_factor
|
| output_height = height * scale_factor
|
| output_shape = (output_width, output_height, depth)
|
|
|
|
|
| output_images = [np.zeros(output_shape, np.uint8) for i in range(len(models))]
|
|
|
| tile_padding = math.ceil(tile_size * tile_padding)
|
| tile_size = math.ceil(tile_size / scale_factor)
|
|
|
| tiles_x = math.ceil(width / tile_size)
|
| tiles_y = math.ceil(height / tile_size)
|
|
|
| for y in range(tiles_y):
|
| for x in range(tiles_x):
|
|
|
| ofs_x = x * tile_size
|
| ofs_y = y * tile_size
|
|
|
|
|
| input_start_x = ofs_x
|
| input_end_x = min(ofs_x + tile_size, width)
|
|
|
| input_start_y = ofs_y
|
| input_end_y = min(ofs_y + tile_size, height)
|
|
|
|
|
| input_start_x_pad = max(input_start_x - tile_padding, 0)
|
| input_end_x_pad = min(input_end_x + tile_padding, width)
|
|
|
| input_start_y_pad = max(input_start_y - tile_padding, 0)
|
| input_end_y_pad = min(input_end_y + tile_padding, height)
|
|
|
|
|
| input_tile_width = input_end_x - input_start_x
|
| input_tile_height = input_end_y - input_start_y
|
|
|
| input_tile = input_image[input_start_x_pad:input_end_x_pad, input_start_y_pad:input_end_y_pad]
|
|
|
| for idx, model in enumerate(models):
|
|
|
|
|
| output_tile = upscale_function(input_tile, model)
|
|
|
|
|
| output_start_x = input_start_x * scale_factor
|
| output_end_x = input_end_x * scale_factor
|
|
|
| output_start_y = input_start_y * scale_factor
|
| output_end_y = input_end_y * scale_factor
|
|
|
|
|
| output_start_x_tile = (input_start_x - input_start_x_pad) * scale_factor
|
| output_end_x_tile = output_start_x_tile + input_tile_width * scale_factor
|
|
|
| output_start_y_tile = (input_start_y - input_start_y_pad) * scale_factor
|
| output_end_y_tile = output_start_y_tile + input_tile_height * scale_factor
|
|
|
|
|
| output_images[idx][output_start_x:output_end_x, output_start_y:output_end_y] = \
|
| output_tile[output_start_x_tile:output_end_x_tile, output_start_y_tile:output_end_y_tile]
|
|
|
| return output_images |