Spaces:
Running
Running
#!/usr/bin/env python | |
import gradio as gr | |
from settings import DEFAULT_NUM_IMAGES, MAX_IMAGE_RESOLUTION, MAX_NUM_IMAGES | |
from utils import randomize_seed_fn | |
def create_demo(process): | |
with gr.Blocks() as demo: | |
with gr.Row(): | |
with gr.Column(): | |
image = gr.Image() | |
prompt = gr.Textbox(label='Prompt') | |
run_button = gr.Button('Run') | |
with gr.Accordion('Advanced options', open=False): | |
preprocessor_name = gr.Radio( | |
label='Preprocessor', | |
choices=[ | |
'Lineart', | |
'Lineart coarse', | |
'None', | |
'Lineart (anime)', | |
'None (anime)', | |
], | |
type='value', | |
value='Lineart', | |
info= | |
'Note that "Lineart (anime)" and "None (anime)" are for anime base models like Anything-v3.' | |
) | |
num_samples = gr.Slider(label='Number of images', | |
minimum=1, | |
maximum=MAX_NUM_IMAGES, | |
value=DEFAULT_NUM_IMAGES, | |
step=1) | |
image_resolution = gr.Slider(label='Image resolution', | |
minimum=256, | |
maximum=MAX_IMAGE_RESOLUTION, | |
value=512, | |
step=256) | |
preprocess_resolution = gr.Slider( | |
label='Preprocess resolution', | |
minimum=128, | |
maximum=512, | |
value=512, | |
step=1) | |
num_steps = gr.Slider(label='Number of steps', | |
minimum=1, | |
maximum=100, | |
value=20, | |
step=1) | |
guidance_scale = gr.Slider(label='Guidance scale', | |
minimum=0.1, | |
maximum=30.0, | |
value=9.0, | |
step=0.1) | |
seed = gr.Slider(label='Seed', | |
minimum=0, | |
maximum=1000000, | |
step=1, | |
value=0, | |
randomize=True) | |
randomize_seed = gr.Checkbox(label='Randomize seed', | |
value=True) | |
a_prompt = gr.Textbox( | |
label='Additional prompt', | |
value='best quality, extremely detailed') | |
n_prompt = gr.Textbox( | |
label='Negative prompt', | |
value= | |
'longbody, lowres, bad anatomy, bad hands, missing fingers, extra digit, fewer digits, cropped, worst quality, low quality' | |
) | |
with gr.Column(): | |
result = gr.Gallery(label='Output', | |
show_label=False, | |
columns=2, | |
object_fit='scale-down') | |
inputs = [ | |
image, | |
prompt, | |
a_prompt, | |
n_prompt, | |
num_samples, | |
image_resolution, | |
preprocess_resolution, | |
num_steps, | |
guidance_scale, | |
seed, | |
preprocessor_name, | |
] | |
prompt.submit( | |
fn=randomize_seed_fn, | |
inputs=[seed, randomize_seed], | |
outputs=seed, | |
queue=False, | |
).then( | |
fn=process, | |
inputs=inputs, | |
outputs=result, | |
) | |
run_button.click( | |
fn=randomize_seed_fn, | |
inputs=[seed, randomize_seed], | |
outputs=seed, | |
queue=False, | |
).then( | |
fn=process, | |
inputs=inputs, | |
outputs=result, | |
api_name='lineart', | |
) | |
return demo | |
if __name__ == '__main__': | |
from model import Model | |
model = Model(task_name='lineart') | |
demo = create_demo(model.process_lineart) | |
demo.queue().launch() | |