File size: 1,616 Bytes
b021ace
 
 
3a1adec
b021ace
efc9ce3
b021ace
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
c21edc5
 
 
 
 
 
 
 
 
 
d6331eb
b021ace
 
 
 
c8890b6
 
b021ace
 
 
 
 
 
 
 
 
 
 
293a1c7
b021ace
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
import subprocess
import shutil
import os
import gradio as gr
import torchvision.transforms as T
import sys
import spaces

subprocess.run(["git", "clone", "https://github.com/AIRI-Institute/HairFastGAN"], check=True)
os.chdir("HairFastGAN")

subprocess.run(["git", "clone", "https://huggingface.co/AIRI-Institute/HairFastGAN"], check=True)

os.chdir("HairFastGAN")
subprocess.run(["git", "lfs", "pull"], check=True)
os.chdir("..")

shutil.move("HairFastGAN/pretrained_models", "pretrained_models")
shutil.move("HairFastGAN/input", "input")

shutil.rmtree("HairFastGAN")

items = os.listdir()

for item in items:
    print(item)
    shutil.move(item, os.path.join('..', item))

os.chdir("..")

shutil.rmtree("HairFastGAN")

from hair_swap import HairFast, get_parser

hair_fast = HairFast(get_parser().parse_args([]))

@spaces.GPU
def swap_hair(source, target_1, target_2, progress=gr.Progress(track_tqdm=True)):
    final_image = hair_fast.swap(source, target_1, target_2)
    return T.functional.to_pil_image(final_image)
    
with gr.Blocks() as demo:
    gr.Markdown("Start typing below and then click **Run** to see the output.")
    with gr.Row():
        source = gr.Image(label="Photo that you want to replace the hair", type="filepath")
        target_1 = gr.Image(label="Reference hair you want to get", type="filepath")
        target_2 = gr.Image(label="Reference color hair you want to get (optional)", type="filepath")
    btn = gr.Button("Get the haircut")
    output = gr.Image(label="Your result")
    
    btn.click(fn=swap_hair, inputs=[source, target_1, target_2], outputs=[output])

demo.launch()