Spaces:
Running
Running
File size: 2,183 Bytes
ae81e6c 76f48d2 dce5242 76f48d2 85a00f7 ae81e6c 76f48d2 ae81e6c b778661 76f48d2 b778661 76f48d2 b778661 76f48d2 b778661 ae81e6c 76f48d2 ae81e6c dce5242 b778661 ae81e6c 76f48d2 ae81e6c b778661 76f48d2 38f7b83 |
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 46 47 48 49 50 51 52 |
import streamlit as st
import torch
import numpy as np
from diffusers import DiffusionPipeline
from transformers import pipeline
# Load text generation pipeline
text_pipe = pipeline('text-generation', model='daspartho/prompt-extend')
def extend_prompt(prompt):
return text_pipe(prompt + ',', num_return_sequences=1, max_new_tokens=50)[0]["generated_text"]
@st.cache_resource
def load_pipeline(use_cuda):
device = "cuda" if use_cuda and torch.cuda.is_available() else "cpu"
pipe = DiffusionPipeline.from_pretrained(
"stabilityai/sdxl-turbo",
torch_dtype=torch.float16 if device == "cuda" else torch.float32,
variant="fp16" if device == "cuda" else None,
use_safetensors=True
)
if device == "cuda":
pipe.enable_xformers_memory_efficient_attention()
pipe.to(device)
return pipe
def generate_image(prompt, use_details, use_cuda):
pipe = load_pipeline(use_cuda)
generator = torch.manual_seed(np.random.randint(0, 2**32))
extended_prompt = extend_prompt(prompt) if use_details else prompt
image = pipe(prompt=extended_prompt, generator=generator, num_inference_steps=25, guidance_scale=7.5).images[0]
return image, extended_prompt
# Add the custom CSS file
st.markdown('<link rel="stylesheet" href="styles.css">', unsafe_allow_html=True)
st.markdown("<div class='header'>β¨ Generate Your Custom GitHub Profile Picture! β¨</div>", unsafe_allow_html=True)
st.markdown("<div class='subheader'>Create an anime-style GitHub profile picture that reflects your personality and passion for coding. ππ¨βπ»</div>", unsafe_allow_html=True)
# Input widgets
input_text = st.text_area("Describe your GitHub profile picture:", "Create an anime-style GitHub profile picture for a boy")
details_checkbox = st.checkbox("Generate Details?", value=True)
cuda_checkbox = st.checkbox("Use CUDA?", value=False)
if st.button("Generate Image"):
with st.spinner('Generating image...'):
image, extended_prompt = generate_image(input_text, details_checkbox, cuda_checkbox)
st.image(image, caption="Generated Image")
st.text(f"Extended Prompt: {extended_prompt}")
st.balloons()
|