|
import torch |
|
from PIL import Image |
|
from io import BytesIO |
|
from diffusers import StableDiffusionUpscalePipeline |
|
import gradio as gr |
|
|
|
model_id = "stabilityai/stable-diffusion-x4-upscaler" |
|
device = "cuda" if torch.cuda.is_available() else "cpu" |
|
pipe = StableDiffusionUpscalePipeline.from_pretrained(model_id, torch_dtype=torch.float16, revision="fp16") if torch.cuda.is_available() else StableDiffusionUpscalePipeline.from_pretrained(model_id) |
|
pipe = pipe.to(device) |
|
|
|
def upscale(low_res_img, prompt): |
|
low_res_img = Image.open(low_res_img).convert("RGB") |
|
low_res_img = low_res_img.resize((128, 128)) |
|
upscaled_image = pipe(prompt=prompt, image=low_res_img, guidance_scale=20, num_inference_steps=100).images[0] |
|
|
|
return upscaled_image |
|
|
|
gr.Interface(fn=upscale, inputs=[gr.Image(type='filepath', label='Low Resolution Image (less than 512x512, i.e. 128x128, 256x256, ect., ect..)'), gr.Textbox(label='Optional: Enter a Prompt to Slightly Guide the AI')], outputs=gr.Image(type='filepath'), title='SD 2.0 4x Upscaler', description='A 4x Low Resolution Upscaler using SD 2.0. Currently it takes about 15mins an image. <br>Expects a Lower than 512x512 image. <br><br><b>Warning: Images 512x512 or Higher Resolution WILL NOT BE UPSCALED and may result Quality Loss!', article = "Code Monkey: <a href=\"https://huggingface.co/Manjushri\">Manjushri</a>").launch(max_threads=True, debug=True) |