import os import gradio as gr import PIL.Image import numpy as np import random import torch import subprocess from diffusers import StableDiffusionPipeline # from diffusers import StableDiffusionPipeline, DPMSolverMultistepScheduler import time model_id = "dicoo_model" # dpm = DPMSolverMultistepScheduler.from_pretrained(model_id, subfolder="scheduler") # pipe = StableDiffusionPipeline.from_pretrained(model_id, scheduler=dpm, torch_dtype=torch.float) pipe = StableDiffusionPipeline.from_pretrained(model_id, torch_dtype=torch.float) def predict(prompt, steps=50, seed=42, guidance_scale=7.5): print("prompt: ", prompt) print("steps: ", steps) generator = torch.manual_seed(seed) start_time = time.time() image = pipe(prompt, generator=generator, num_inference_steps=steps, guidance_scale=7.5).images[0] print("cost: ", time.time() - start_time) return image md = """ This Spaces app is created by Intel AIA/AIPC team with the model fine-tuned with one shot (one image) for a newly introduced object \"dicoo\". To replicate the model fine-tuning, please refer to the code sample in Intel Neural Compressor. You may also refer to our blog for more details. **For better experience and faster generation, please visit this page, with DPM-Solver scheduler and upgraded hardware support.** You can skip the queue by duplicating this space: Duplicate Space""" random_seed = random.randint(0, 2147483647) gr.Interface( predict, inputs=[ gr.inputs.Textbox(label='Prompt', default='a lovely in red dress and hat, in the snowy and brightly night, with many brightly buildings'), gr.inputs.Slider(1, 100, label='Inference Steps', default=50, step=1), gr.inputs.Slider(0, 2147483647, label='Seed', default=random_seed, step=1), gr.inputs.Slider(1.0, 20.0, label='Guidance Scale - how much the prompt will influence the results', default=6.0, step=0.1), ], outputs=gr.Image(shape=[512, 512], type="pil", elem_id="output_image"), css="#output_image{width: 256px}", title="Demo of dicoo-finetuned-diffusion-model 🧨", description=md, ).launch()