| |
| 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] |
|
|