| | |
| | from diffusers import StableDiffusionImg2ImgPipeline |
| | import requests |
| | import torch |
| | from PIL import Image |
| | from io import BytesIO |
| |
|
| | url = "https://raw.githubusercontent.com/CompVis/stable-diffusion/main/assets/stable-samples/img2img/sketch-mountains-input.jpg" |
| |
|
| | response = requests.get(url) |
| | init_image = Image.open(BytesIO(response.content)).convert("RGB") |
| | init_image = init_image.resize((512, 512)) |
| |
|
| | path = "runwayml/stable-diffusion-v1-5" |
| |
|
| | run_compile = True |
| |
|
| | pipe = StableDiffusionImg2ImgPipeline.from_pretrained(path, torch_dtype=torch.float16) |
| | pipe = pipe.to("cuda:0") |
| | pipe.unet.to(memory_format=torch.channels_last) |
| |
|
| | if run_compile: |
| | print("Run torch compile") |
| | pipe.unet = torch.compile(pipe.unet, mode="reduce-overhead", fullgraph=True) |
| |
|
| | prompt = "ghibli style, a fantasy landscape with castles" |
| |
|
| | for _ in range(3): |
| | image = pipe(prompt=prompt, image=init_image).images[0] |
| |
|