data:image/s3,"s3://crabby-images/f4e62/f4e6260433b3aa0b33eb22f43b449f93865577c0" alt="Example01"
data:image/s3,"s3://crabby-images/60779/60779fd1a67f7e881c46809d4b62a18acf176a6c" alt="Output01"
data:image/s3,"s3://crabby-images/ac00e/ac00eba2a693203821711886e29590cac001bcb7" alt="Example01"
data:image/s3,"s3://crabby-images/76cec/76cec06221d5abbe05337b991a2a105ed3407d75" alt="Output01"
data:image/s3,"s3://crabby-images/8c624/8c624e30ed56f219336935d4d4b50a73dcf4003c" alt="Example01"
data:image/s3,"s3://crabby-images/f4937/f49370701b77b2c99f3c96824afc5a3a0ffce22b" alt="Output01"
data:image/s3,"s3://crabby-images/bdc97/bdc975550ed5e9ba56adab297b9946efc9846ef9" alt="Example01"
data:image/s3,"s3://crabby-images/2823f/2823f2eeb0a1b844ce6d123f3a51963c2ac6e3d4" alt="Output01"
data:image/s3,"s3://crabby-images/9d9c9/9d9c987d8e65628f366059bea921a0f23156dcdd" alt="Example01"
data:image/s3,"s3://crabby-images/937a5/937a59785ca4974cdf56da37d7a364e5a30745b4" alt="Output01"
data:image/s3,"s3://crabby-images/e7f88/e7f88169887cc519a3a08ea37dc90570e9bb524f" alt="Example01"
data:image/s3,"s3://crabby-images/47652/476523463be72756c1799c99a976b51bdaf8a2aa" alt="Output01"
data:image/s3,"s3://crabby-images/b43d0/b43d08020cfd47f8bc3eb60e80fca3d0706ece49" alt="Example01"
data:image/s3,"s3://crabby-images/a4c6c/a4c6c9955b55cb5e8050cd8fe3921293c7ec9532" alt="Output01"
data:image/s3,"s3://crabby-images/96d13/96d134bad3560ca02686788f337de080903b83f2" alt="Example01"
data:image/s3,"s3://crabby-images/88f72/88f723df099616b4dcdb47acf59b835a77fd67d4" alt="Output01"
data:image/s3,"s3://crabby-images/586c9/586c981d186ab2ac7f87ed1d1b7df14e832bf8c4" alt="Example01"
data:image/s3,"s3://crabby-images/e89b0/e89b07a04b46d9dff7cca8719fc50b970adc33d8" alt="Output01"
data:image/s3,"s3://crabby-images/f818e/f818eb8ee36580d34230f27b7d1dbe32286caf46" alt="Example01"
data:image/s3,"s3://crabby-images/b37ad/b37ad8002a15b76d7e46b562392797dfaae041cd" alt="Output01"
import gradio as gr import numpy as np from huggingface_hub import hf_hub_url, cached_download import PIL import onnx import onnxruntime config_file_url = hf_hub_url("Jacopo/ToonClip", filename="model.onnx") model_file = cached_download(config_file_url) onnx_model = onnx.load(model_file) onnx.checker.check_model(onnx_model) opts = onnxruntime.SessionOptions() opts.intra_op_num_threads = 16 ort_session = onnxruntime.InferenceSession(model_file, sess_options=opts) input_name = ort_session.get_inputs()[0].name output_name = ort_session.get_outputs()[0].name def normalize(x, mean=(0., 0., 0.), std=(1.0, 1.0, 1.0)): # x = (x - mean) / std x = np.asarray(x, dtype=np.float32) if len(x.shape) == 4: for dim in range(3): x[:, dim, :, :] = (x[:, dim, :, :] - mean[dim]) / std[dim] if len(x.shape) == 3: for dim in range(3): x[dim, :, :] = (x[dim, :, :] - mean[dim]) / std[dim] return x def denormalize(x, mean=(0., 0., 0.), std=(1.0, 1.0, 1.0)): # x = (x * std) + mean x = np.asarray(x, dtype=np.float32) if len(x.shape) == 4: for dim in range(3): x[:, dim, :, :] = (x[:, dim, :, :] * std[dim]) + mean[dim] if len(x.shape) == 3: for dim in range(3): x[dim, :, :] = (x[dim, :, :] * std[dim]) + mean[dim] return x def nogan(input_img): i = np.asarray(input_img) i = i.astype("float32") i = np.transpose(i, (2, 0, 1)) i = np.expand_dims(i, 0) i = i / 255.0 i = normalize(i, (0.485, 0.456, 0.406), (0.229, 0.224, 0.225)) ort_outs = ort_session.run([output_name], {input_name: i}) output = ort_outs output = output[0][0] output = denormalize(output, (0.485, 0.456, 0.406), (0.229, 0.224, 0.225)) output = output * 255.0 output = output.astype('uint8') output = np.transpose(output, (1, 2, 0)) output_image = PIL.Image.fromarray(output, 'RGB') return output_image title = "" description = """ """ article = """
Example images from untrained FFHQ validation set: