File size: 1,498 Bytes
09ca579
 
 
 
dcbba80
09ca579
 
 
 
 
 
 
 
 
 
 
 
 
 
dcbba80
 
 
 
 
 
 
09ca579
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
#!/usr/bin/env python

from __future__ import annotations

import os
import pathlib
import shlex
import subprocess

import gradio as gr

from app_generated_image import create_prompt_demo
from app_real_image import create_real_image_demo

DESCRIPTION = '''# Plug-and-Play diffusion features

This is an unofficial demo for [https://github.com/MichalGeyer/plug-and-play](https://github.com/MichalGeyer/plug-and-play).
'''

if (SPACE_ID := os.getenv('SPACE_ID')) is not None:
    DESCRIPTION += f'''<p>For faster inference without waiting in queue, you may duplicate the space and upgrade to GPU in settings.<br/>
<a href="https://huggingface.co/spaces/{SPACE_ID}?duplicate=true">
<img style="margin-top: 0em; margin-bottom: 0em" src="https://bit.ly/3gLdBN6" alt="Duplicate Space"></a>
<p/>
'''

weight_dir = pathlib.Path('plug-and-play/models/ldm/stable-diffusion-v1')
if not weight_dir.exists():
    subprocess.run(
        shlex.split('mkdir -p plug-and-play/models/ldm/stable-diffusion-v1/'))
    subprocess.run(
        shlex.split(
            'wget https://huggingface.co/CompVis/stable-diffusion-v-1-4-original/resolve/main/sd-v1-4.ckpt -O plug-and-play/models/ldm/stable-diffusion-v1/model.ckpt'
        ))

with gr.Blocks(css='style.css') as demo:
    gr.Markdown(DESCRIPTION)
    with gr.Tabs():
        with gr.TabItem('Use real image as input'):
            create_real_image_demo()
        with gr.TabItem('Use prompt as input'):
            create_prompt_demo()

demo.queue().launch()