Spaces:
Runtime error
Runtime error
Commit
·
d9a4e74
1
Parent(s):
25fe7da
Update app.py
Browse files
app.py
CHANGED
|
@@ -1,11 +1,11 @@
|
|
| 1 |
import gradio as gr
|
| 2 |
-
from stability_sdk import client
|
| 3 |
-
import stability_sdk.interfaces.gooseai.generation.generation_pb2 as generation
|
| 4 |
from PIL import Image
|
| 5 |
import io
|
| 6 |
import os
|
| 7 |
import warnings
|
| 8 |
-
|
|
|
|
|
|
|
| 9 |
|
| 10 |
# theme = gr.themes.Monochrome(
|
| 11 |
# primary_hue="indigo",
|
|
@@ -15,41 +15,17 @@ import warnings
|
|
| 15 |
# font=[gr.themes.GoogleFont("Open Sans"), "ui-sans-serif", "system-ui", "sans-serif"],
|
| 16 |
# )
|
| 17 |
|
| 18 |
-
def infer(prompt
|
| 19 |
-
|
| 20 |
-
|
| 21 |
-
|
| 22 |
-
|
| 23 |
-
|
| 24 |
-
)
|
| 25 |
-
|
| 26 |
-
|
| 27 |
-
#seed=992446758, # If a seed is provided, the resulting generated image will be deterministic.
|
| 28 |
-
# What this means is that as long as all generation parameters remain the same, you can always recall the same image simply by generating it again.
|
| 29 |
-
# Note: This isn't quite the case for Clip Guided generations, which we'll tackle in a future example notebook.
|
| 30 |
-
steps=50, # Amount of inference steps performed on image generation. Defaults to 30.
|
| 31 |
-
cfg_scale=8.0, # Influences how strongly your generation is guided to match your prompt.
|
| 32 |
-
# Setting this value higher increases the strength in which it tries to match your prompt.
|
| 33 |
-
# Defaults to 7.0 if not specified.
|
| 34 |
-
width=512, # Generation width, defaults to 512 if not included.
|
| 35 |
-
height=512, # Generation height, defaults to 512 if not included.
|
| 36 |
-
samples=2, # Number of images to generate, defaults to 1 if not included.
|
| 37 |
-
sampler=generation.SAMPLER_K_DPMPP_2M # Choose which sampler we want to denoise our generation with.
|
| 38 |
-
# Defaults to k_dpmpp_2m if not specified. Clip Guidance only supports ancestral samplers.
|
| 39 |
-
# (Available Samplers: ddim, plms, k_euler, k_euler_ancestral, k_heun, k_dpm_2, k_dpm_2_ancestral, k_dpmpp_2s_ancestral, k_lms, k_dpmpp_2m)
|
| 40 |
-
)
|
| 41 |
-
results = []
|
| 42 |
-
for resp in answers:
|
| 43 |
-
for artifact in resp.artifacts:
|
| 44 |
-
if artifact.finish_reason == generation.FILTER:
|
| 45 |
-
warnings.warn(
|
| 46 |
-
"Your request activated the API's safety filters and could not be processed."
|
| 47 |
-
"Please modify the prompt and try again.")
|
| 48 |
-
if artifact.type == generation.ARTIFACT_IMAGE:
|
| 49 |
-
img = Image.open(io.BytesIO(artifact.binary))
|
| 50 |
-
results.append(img)
|
| 51 |
|
| 52 |
-
return
|
| 53 |
|
| 54 |
css = """
|
| 55 |
.gradio-container {
|
|
@@ -238,8 +214,7 @@ with gr.Blocks(css = css) as demo:
|
|
| 238 |
)
|
| 239 |
gr.HTML("<p>You can duplicate this Space to run it privately without a queue for shorter queue times : <a style='display:inline-block' href='https://huggingface.co/spaces/RamAnanth1/stable-diffusion-xl?duplicate=true'><img src='https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=14' alt='Duplicate Space'></a> </p>")
|
| 240 |
|
| 241 |
-
|
| 242 |
-
|
| 243 |
with gr.Row(elem_id="prompt-container").style(mobile_collapse=False, equal_height=True):
|
| 244 |
with gr.Column():
|
| 245 |
text = gr.Textbox(
|
|
@@ -263,7 +238,7 @@ with gr.Blocks(css = css) as demo:
|
|
| 263 |
label="Generated images", show_label=False, elem_id="gallery"
|
| 264 |
).style(grid=[2], height="auto")
|
| 265 |
|
| 266 |
-
btn.click(infer, inputs=[text
|
| 267 |
examples = [
|
| 268 |
["Vintage hot rod with custom flame paint job"],
|
| 269 |
["Ancient, mysterious temple in a mountain range, surrounded by misty clouds and tall peaks"],
|
|
|
|
| 1 |
import gradio as gr
|
|
|
|
|
|
|
| 2 |
from PIL import Image
|
| 3 |
import io
|
| 4 |
import os
|
| 5 |
import warnings
|
| 6 |
+
import torch
|
| 7 |
+
import numpy as np
|
| 8 |
+
from diffusers import DiffusionPipeline
|
| 9 |
|
| 10 |
# theme = gr.themes.Monochrome(
|
| 11 |
# primary_hue="indigo",
|
|
|
|
| 15 |
# font=[gr.themes.GoogleFont("Open Sans"), "ui-sans-serif", "system-ui", "sans-serif"],
|
| 16 |
# )
|
| 17 |
|
| 18 |
+
def infer(prompt):
|
| 19 |
+
torch.cuda.max_memory_allocated(device='cpu')
|
| 20 |
+
pipe = DiffusionPipeline.from_pretrained("stabilityai/stable-diffusion-xl-base-0.9", torch_dtype=torch.float16, variant="fp16", use_safetensors=True)
|
| 21 |
+
pipe = pipe.to(device)
|
| 22 |
+
pipe.enable_xformers_memory_efficient_attention()
|
| 23 |
+
torch.cuda.empty_cache()
|
| 24 |
+
generator = torch.Generator(device=device).manual_seed(seed)
|
| 25 |
+
int_image = pipe(prompt, negative_prompt=negative_prompt, num_inference_steps=steps, height=height, width=width, guidance_scale=scale, num_images_per_prompt=1, generator=generator).images
|
| 26 |
+
torch.cuda.empty_cache()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 27 |
|
| 28 |
+
return int_image
|
| 29 |
|
| 30 |
css = """
|
| 31 |
.gradio-container {
|
|
|
|
| 214 |
)
|
| 215 |
gr.HTML("<p>You can duplicate this Space to run it privately without a queue for shorter queue times : <a style='display:inline-block' href='https://huggingface.co/spaces/RamAnanth1/stable-diffusion-xl?duplicate=true'><img src='https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=14' alt='Duplicate Space'></a> </p>")
|
| 216 |
|
| 217 |
+
|
|
|
|
| 218 |
with gr.Row(elem_id="prompt-container").style(mobile_collapse=False, equal_height=True):
|
| 219 |
with gr.Column():
|
| 220 |
text = gr.Textbox(
|
|
|
|
| 238 |
label="Generated images", show_label=False, elem_id="gallery"
|
| 239 |
).style(grid=[2], height="auto")
|
| 240 |
|
| 241 |
+
btn.click(infer, inputs=[text], outputs=[gallery])
|
| 242 |
examples = [
|
| 243 |
["Vintage hot rod with custom flame paint job"],
|
| 244 |
["Ancient, mysterious temple in a mountain range, surrounded by misty clouds and tall peaks"],
|