Spaces:
Running
on
T4
Running
on
T4
Ahsen Khaliq
commited on
Commit
·
2061b93
1
Parent(s):
f912059
pytorch to onnx
Browse files
app.py
CHANGED
@@ -1,63 +1,51 @@
|
|
|
|
|
|
1 |
import os
|
2 |
-
os.system("git clone https://github.com/bryandlee/animegan2-pytorch")
|
3 |
-
os.system("gdown https://drive.google.com/uc?id=18H3iK09_d54qEDoWIc82SyWB2xun4gjU")
|
4 |
-
import sys
|
5 |
-
sys.path.append("animegan2-pytorch")
|
6 |
-
|
7 |
-
import torch
|
8 |
-
torch.set_grad_enabled(False)
|
9 |
-
|
10 |
-
from model import Generator
|
11 |
-
|
12 |
-
device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
|
13 |
-
|
14 |
-
model = Generator().eval().to(device)
|
15 |
-
model.load_state_dict(torch.load("face_paint_512_v2_0.pt"))
|
16 |
-
|
17 |
-
from PIL import Image
|
18 |
-
from torchvision.transforms.functional import to_tensor, to_pil_image
|
19 |
import gradio as gr
|
20 |
-
|
21 |
-
|
22 |
-
img: Image.Image,
|
23 |
-
size: int,
|
24 |
-
side_by_side: bool = False,
|
25 |
-
) -> Image.Image:
|
26 |
|
27 |
|
28 |
-
|
29 |
-
output = model(input.to(device)).cpu()[0]
|
30 |
|
31 |
-
|
32 |
-
|
33 |
|
34 |
-
|
35 |
-
|
36 |
-
return to_pil_image(output)
|
37 |
-
|
38 |
|
39 |
-
import
|
40 |
-
from typing import Union, List
|
41 |
import numpy as np
|
42 |
from PIL import Image
|
43 |
|
44 |
-
|
45 |
-
|
46 |
-
|
47 |
-
|
48 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
49 |
|
50 |
|
51 |
-
|
52 |
-
|
53 |
-
|
54 |
-
out = face2paint(img, 512)
|
55 |
-
return out
|
56 |
|
57 |
|
58 |
title = "Animeganv2"
|
59 |
description = "Gradio demo for AnimeGanv2 Face Portrait v2. To use it, simply upload your image, or click one of the examples to load them. Read more at the links below. Please use a cropped portrait picture for best results similar to the examples below"
|
60 |
-
article = "<p style='text-align: center'><a href='https://github.com/bryandlee/animegan2-pytorch' target='_blank'>Github Repo</a></p><p style='text-align: center'>samples from repo: <img src='https://user-images.githubusercontent.com/26464535/129888683-98bb6283-7bb8-4d1a-a04a-e795f5858dcf.gif' alt='animation'/> <img src='https://user-images.githubusercontent.com/26464535/137619176-59620b59-4e20-4d98-9559-a424f86b7f24.jpg' alt='animation'/></p>"
|
61 |
|
62 |
examples=[['groot.jpeg'],['bill.png'],['tony.png'],['elon.png'],['IU.png'],['billie.png'],['will.png'],['beyonce.jpeg'],['gongyoo.jpeg']]
|
63 |
-
gr.Interface(inference, gr.inputs.Image(type="pil"
|
|
|
1 |
+
import onnxruntime
|
2 |
+
print(onnxruntime.get_device())
|
3 |
import os
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
4 |
import gradio as gr
|
5 |
+
os.system("pip install gdown")
|
6 |
+
os.system("gdown https://drive.google.com/uc?id=1riNxV1BWMAXfmWZ3LrQbEkvzV8f7lOCp")
|
|
|
|
|
|
|
|
|
7 |
|
8 |
|
9 |
+
onnx_session = onnxruntime.InferenceSession("face_paint_512_v2_0.onnx")
|
|
|
10 |
|
11 |
+
input_name = onnx_session.get_inputs()[0].name
|
12 |
+
output_name = onnx_session.get_outputs()[0].name
|
13 |
|
14 |
+
side_length = 512
|
|
|
|
|
|
|
15 |
|
16 |
+
import cv2 as cv
|
|
|
17 |
import numpy as np
|
18 |
from PIL import Image
|
19 |
|
20 |
+
def inference(img):
|
21 |
+
image = np.array(img)
|
22 |
+
image = image[:, :, ::-1].copy()
|
23 |
+
image = cv.resize(image, dsize=(side_length, side_length))
|
24 |
+
x = cv.cvtColor(image, cv.COLOR_BGR2RGB)
|
25 |
+
|
26 |
+
x = np.array(x, dtype=np.float32)
|
27 |
+
x = x.transpose(2, 0, 1)
|
28 |
+
x = x * 2 - 1
|
29 |
+
x = x.reshape(-1, 3, side_length, side_length)
|
30 |
+
|
31 |
+
onnx_result = onnx_session.run([output_name], {input_name: x})
|
32 |
+
|
33 |
+
onnx_result = np.array(onnx_result).squeeze()
|
34 |
+
onnx_result = (onnx_result * 0.5 + 0.5).clip(0, 1)
|
35 |
+
onnx_result = onnx_result * 255
|
36 |
+
|
37 |
+
onnx_result = onnx_result.transpose(1, 2, 0).astype('uint8')
|
38 |
+
onnx_result = cv.cvtColor(onnx_result, cv.COLOR_RGB2BGR)
|
39 |
|
40 |
|
41 |
+
img = cv.cvtColor(onnx_result, cv.COLOR_BGR2RGB)
|
42 |
+
im_pil = Image.fromarray(img)
|
43 |
+
return im_pil
|
|
|
|
|
44 |
|
45 |
|
46 |
title = "Animeganv2"
|
47 |
description = "Gradio demo for AnimeGanv2 Face Portrait v2. To use it, simply upload your image, or click one of the examples to load them. Read more at the links below. Please use a cropped portrait picture for best results similar to the examples below"
|
48 |
+
article = "<p style='text-align: center'><a href='https://github.com/bryandlee/animegan2-pytorch' target='_blank'>Github Repo Pytorch</a> | <a href='https://github.com/Kazuhito00/AnimeGANv2-ONNX-Sample' target='_blank'>Github Repo ONNX</a></p><p style='text-align: center'>samples from repo: <img src='https://user-images.githubusercontent.com/26464535/129888683-98bb6283-7bb8-4d1a-a04a-e795f5858dcf.gif' alt='animation'/> <img src='https://user-images.githubusercontent.com/26464535/137619176-59620b59-4e20-4d98-9559-a424f86b7f24.jpg' alt='animation'/></p>"
|
49 |
|
50 |
examples=[['groot.jpeg'],['bill.png'],['tony.png'],['elon.png'],['IU.png'],['billie.png'],['will.png'],['beyonce.jpeg'],['gongyoo.jpeg']]
|
51 |
+
gr.Interface(inference, gr.inputs.Image(type="pil"), gr.outputs.Image(type="pil"),title=title,description=description,article=article,enable_queue=True,examples=examples).launch()
|