Spaces:
Runtime error
Runtime error
Commit
·
629deb2
1
Parent(s):
546037a
Create app.py
Browse files
app.py
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import gradio as gr
|
| 2 |
+
from stability_sdk import client
|
| 3 |
+
import stability_sdk.interfaces.gooseai.generation.generation_pb2 as generation
|
| 4 |
+
|
| 5 |
+
|
| 6 |
+
theme = gr.themes.Monochrome(
|
| 7 |
+
primary_hue="indigo",
|
| 8 |
+
secondary_hue="blue",
|
| 9 |
+
neutral_hue="slate",
|
| 10 |
+
radius_size=gr.themes.sizes.radius_sm,
|
| 11 |
+
font=[gr.themes.GoogleFont("Open Sans"), "ui-sans-serif", "system-ui", "sans-serif"],
|
| 12 |
+
)
|
| 13 |
+
|
| 14 |
+
def infer(prompt, api_key):
|
| 15 |
+
stability_api = client.StabilityInference(
|
| 16 |
+
key=api_key, # API Key reference.
|
| 17 |
+
verbose=True, # Print debug messages.
|
| 18 |
+
engine="stable-diffusion-xl-beta-v2-2-2", # Set the engine to use for generation.
|
| 19 |
+
# Available engines: stable-diffusion-v1 stable-diffusion-v1-5 stable-diffusion-512-v2-0 stable-diffusion-768-v2-0 stable-inpainting-v1-0 stable-inpainting-512-v2-0
|
| 20 |
+
)
|
| 21 |
+
answers = stability_api.generate(
|
| 22 |
+
prompt=prompt,
|
| 23 |
+
seed=992446758, # If a seed is provided, the resulting generated image will be deterministic.
|
| 24 |
+
# 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.
|
| 25 |
+
# Note: This isn't quite the case for Clip Guided generations, which we'll tackle in a future example notebook.
|
| 26 |
+
steps=30, # Amount of inference steps performed on image generation. Defaults to 30.
|
| 27 |
+
cfg_scale=8.0, # Influences how strongly your generation is guided to match your prompt.
|
| 28 |
+
# Setting this value higher increases the strength in which it tries to match your prompt.
|
| 29 |
+
# Defaults to 7.0 if not specified.
|
| 30 |
+
width=512, # Generation width, defaults to 512 if not included.
|
| 31 |
+
height=512, # Generation height, defaults to 512 if not included.
|
| 32 |
+
samples=1, # Number of images to generate, defaults to 1 if not included.
|
| 33 |
+
sampler=generation.SAMPLER_K_DPMPP_2M # Choose which sampler we want to denoise our generation with.
|
| 34 |
+
# Defaults to k_dpmpp_2m if not specified. Clip Guidance only supports ancestral samplers.
|
| 35 |
+
# (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)
|
| 36 |
+
)
|
| 37 |
+
for resp in answers:
|
| 38 |
+
for artifact in resp.artifacts:
|
| 39 |
+
if artifact.finish_reason == generation.FILTER:
|
| 40 |
+
warnings.warn(
|
| 41 |
+
"Your request activated the API's safety filters and could not be processed."
|
| 42 |
+
"Please modify the prompt and try again.")
|
| 43 |
+
if artifact.type == generation.ARTIFACT_IMAGE:
|
| 44 |
+
img = Image.open(io.BytesIO(artifact.binary))
|
| 45 |
+
|
| 46 |
+
return img
|
| 47 |
+
|
| 48 |
+
with gr.Blocks(theme = theme) as demo:
|
| 49 |
+
gr.Markdown("# Stable Diffusion XL")
|
| 50 |
+
#gr.Markdown('<p> For faster inference without waiting in queue, you may duplicate the space and upgrade to GPU in settings. <a href="https://huggingface.co/spaces/RamAnanth1/stable-diffusion-xl?duplicate=true"><img style="display: inline; margin-top: 0em; margin-bottom: 0em" src="https://bit.ly/3gLdBN6" alt="Duplicate Space" /></a></p>')
|
| 51 |
+
api_key_input = gr.Textbox(type = "password", label = "Enter your StabilityAI API key here")
|
| 52 |
+
text = gr.Textbox(label="Enter your prompt",
|
| 53 |
+
show_label=True,
|
| 54 |
+
max_lines=1,
|
| 55 |
+
placeholder="Enter your prompt",
|
| 56 |
+
elem_id="prompt-text-input",
|
| 57 |
+
).style(
|
| 58 |
+
border=(True, False, True, True),
|
| 59 |
+
rounded=(True, False, False, True),
|
| 60 |
+
container=False,
|
| 61 |
+
)
|
| 62 |
+
btn = gr.Button("Generate image").style(
|
| 63 |
+
margin=False,
|
| 64 |
+
rounded=(False, True, True, False),
|
| 65 |
+
full_width=False,
|
| 66 |
+
)
|
| 67 |
+
|
| 68 |
+
gallery = gr.Gallery(
|
| 69 |
+
label="Generated images", show_label=False, elem_id="gallery"
|
| 70 |
+
).style(grid=[2], height="auto")
|
| 71 |
+
|
| 72 |
+
btn.click(infer, inputs=[text, api_key_input], outputs=[gallery])
|
| 73 |
+
|
| 74 |
+
|
| 75 |
+
|
| 76 |
+
demo.launch()
|