"""Test script for anime-to-sketch translation Example: python3 test.py --dataroot /your_path/dir --load_size 512 python3 test.py --dataroot /your_path/img.jpg --load_size 512 """ import os import torch from scripts.data import get_image_list, get_transform, tensor_to_img, save_image from scripts.model import create_model import argparse from tqdm.auto import tqdm from kornia.enhance import equalize_clahe from PIL import Image import numpy as np import spaces model = None device = None @spaces.GPU def init_model(use_local=False): global model, device model_opt = "default" device = torch.device('cuda' if torch.cuda.is_available() else 'cpu') # issue: nevetherless, use_gpu is False, it still uses GPU model = create_model(model_opt, use_local).to(device) model.eval() # numpy配列の画像を受け取り、線画を生成してnumpy配列で返す @spaces.GPU def generate_sketch(image, clahe_clip=-1, load_size=512): """ Generate sketch image from input image Args: image (np.ndarray): input image clahe_clip (float): clip threshold for CLAHE load_size (int): image size to load Returns: np.ndarray: output image """ # create model # device = torch.device('cuda' if torch.cuda.is_available() else 'cpu') # model_opt = "default" # model = create_model(model_opt).to(device) # model.eval() aus_resize = None if load_size > 0: aus_resize = (image.shape[0], image.shape[1]) transform = get_transform(load_size=load_size) image = torch.from_numpy(image).permute(2, 0, 1).float() # [0,255] to [-1,1] image = transform(image) if image.max() > 1: image = (image-image.min())/(image.max()-image.min())*2-1 img, aus_resize = image.unsqueeze(0), aus_resize if clahe_clip > 0: img = (img + 1) / 2 # [-1,1] to [0,1] img = equalize_clahe(img, clip_limit=clahe_clip) img = (img - .5) / .5 # [0,1] to [-1,1] aus_tensor = model(img.to(device)) # resize to original size if aus_resize is not None: aus_tensor = torch.nn.functional.interpolate(aus_tensor, aus_resize, mode='bilinear', align_corners=False) aus_img = tensor_to_img(aus_tensor) return aus_img if __name__ == '__main__': os.chdir(os.path.dirname("Anime2Sketch/")) parser = argparse.ArgumentParser(description='Anime-to-sketch test options.') parser.add_argument('--dataroot','-i', default='test_samples/', type=str) parser.add_argument('--load_size','-s', default=512, type=int) parser.add_argument('--output_dir','-o', default='results/', type=str) parser.add_argument('--gpu_ids', '-g', default=[], help="gpu ids: e.g. 0 0,1,2 0,2.") parser.add_argument('--model', default="default", type=str, help="variant of model to use. you can choose from ['default','improved']") parser.add_argument('--clahe_clip', default=-1, type=float, help="clip threshold for CLAHE set to -1 to disable") opt = parser.parse_args() # # generate sketchで線画生成 # for test_path in tqdm(get_image_list(opt.dataroot)): # basename = os.path.basename(test_path) # aus_path = os.path.join(opt.output_dir, basename) # # numpy配列で画像を読み込む # img = Image.open(test_path) # img = np.array(img) # aus_img = generate_sketch(img, opt.clahe_clip) # # 画像を保存 # save_image(aus_img, aus_path, (512, 512)) # create model gpu_list = ','.join(str(x) for x in opt.gpu_ids) device = torch.device('cuda' if torch.cuda.is_available() else 'cpu') model = create_model(opt.model, use_local=True).to(device) # create a model given opt.model and other options model.eval() for test_path in tqdm(get_image_list(opt.dataroot)): basename = os.path.basename(test_path) aus_path = os.path.join(opt.output_dir, basename) img = Image.open(test_path).convert('RGB') img = np.array(img) load_size = 512 aus_resize = None if load_size > 0: aus_resize = (img.shape[1], img.shape[0]) transform = get_transform(load_size=load_size) img = torch.from_numpy(img).permute(2, 0, 1).float() # [0,255] to [-1,1] image = transform(img) if image.max() > 1: image = (image-image.min())/(image.max()-image.min())*2-1 print(image.min(), image.max()) img, aus_resize = image.unsqueeze(0), aus_resize if opt.clahe_clip > 0: img = (img + 1) / 2 # [-1,1] to [0,1] img = equalize_clahe(img, clip_limit=opt.clahe_clip) img = (img - .5) / .5 # [0,1] to [-1,1] aus_tensor = model(img.to(device)) aus_img = tensor_to_img(aus_tensor) save_image(aus_img, aus_path, aus_resize) """ # create model gpu_list = ','.join(str(x) for x in opt.gpu_ids) os.environ['CUDA_VISIBLE_DEVICES'] = gpu_list device = torch.device('cuda' if len(opt.gpu_ids)>0 else 'cpu') model = create_model(opt.model).to(device) # create a model given opt.model and other options model.eval() # get input data if os.path.isdir(opt.dataroot): test_list = get_image_list(opt.dataroot) elif os.path.isfile(opt.dataroot): test_list = [opt.dataroot] else: raise Exception("{} is not a valid directory or image file.".format(opt.dataroot)) # save outputs save_dir = opt.output_dir os.makedirs(save_dir, exist_ok=True) for test_path in tqdm(test_list): basename = os.path.basename(test_path) aus_path = os.path.join(save_dir, basename) img, aus_resize = read_img_path(test_path, opt.load_size) if opt.clahe_clip > 0: img = (img + 1) / 2 # [-1,1] to [0,1] img = equalize_clahe(img, clip_limit=opt.clahe_clip) img = (img - .5) / .5 # [0,1] to [-1,1] aus_tensor = model(img.to(device)) print(aus_tensor.shape) aus_img = tensor_to_img(aus_tensor) save_image(aus_img, aus_path, aus_resize) """