Afbeeldingen bewerken met diffusie­modellen

Multi-modale modellen met Hugging Face

James Chapman

Curriculum Manager, DataCamp

Diffusers

Stappen van een diffusie­model dat een afbeelding uit ruis maakt

  • Getraind om ruis naar een afbeelding te mappen
  • CLIP + Diffusion → 2 soorten conditionele generatie
    • Generatie: tekst → afbeelding
    • Modificatie: tekst+afbeelding → afbeelding
1 https://huggingface.co/docs/diffusers
Multi-modale modellen met Hugging Face

Aangepaste beeldbewerking

ControlNet: voorwaardelijke generatie op basis van beeld en tekst

Diagram met de aanpak voor aangepaste beeldbewerking met een Canny-filter en ControlNet

1 https://stable-diffusion-art.com/controlnet/
Multi-modale modellen met Hugging Face

Aangepaste beeldbewerking

from diffusers.utils import load_image

image = load_image("http://301.nz/o81bf")

import cv2 from PIL import Image import numpy as np image = cv2.Canny(np.array(image), 100, 200)
image = image[:, :, None] image = np.concatenate([image, image, image], axis=2)

Afbeelding van de Mona Lisa

Multi-modale modellen met Hugging Face

Aangepaste beeldbewerking

from diffusers.utils import load_image

image = load_image("http://301.nz/o81bf")

import cv2
from PIL import Image
import numpy as np

image = cv2.Canny(np.array(image), 100, 200)
image = image[:, :, None]
image = np.concatenate([image, image, image], 
                       axis=2)
canny_image = Image.fromarray(image)

Afbeelding van de Mona Lisa en versie met canny-filter

Multi-modale modellen met Hugging Face

Aangepaste beeldbewerking

from diffusers import StableDiffusionControlNetPipeline
from diffusers import ControlNetModel
import torch

controlnet = ControlNetModel.from_pretrained("lllyasviel/sd-controlnet-canny", 
                                             torch_dtype=torch.float16)


pipe = StableDiffusionControlNetPipeline.from_pretrained( "runwayml/stable-diffusion-v1-5", controlnet=controlnet, torch_dtype=torch.float16 )
pipe = pipe.to("cuda")
Multi-modale modellen met Hugging Face

Aangepaste beeldbewerking

prompt = ["Albert Einstein, 
          best quality, 
          extremely detailed"]

generator = [ torch.Generator(device="cuda").manual_seed(2)]
output = pipe( prompt, canny_image, negative_prompt=["monochrome, lowres, bad anatomy, worst quality, low quality"], generator=generator, num_inference_steps=20)

Albert Einstein in de Mona Lisa-houding

Multi-modale modellen met Hugging Face

Image inpainting

  • Genereer nieuwe content voor een specifieke regio

Mona Lisa zonder masker

Multi-modale modellen met Hugging Face

Image inpainting

  • Genereer nieuwe content voor een specifieke regio
  • Binaire mask: wit (1), zwart (0)
  • Maskers via segmentatie of handmatig (bijv. met InpaintingMask-Generation)

Mona Lisa plus ons masker

Multi-modale modellen met Hugging Face

Image inpainting

from diffusers import StableDiffusionControlNetInpaintPipeline, ControlNetModel


controlnet = ControlNetModel.from_pretrained("lllyasviel/control_v11p_sd15_inpaint", torch_dtype=torch.float16, use_safetensors=True)
pipe = StableDiffusionControlNetInpaintPipeline.from_pretrained( "stable-diffusion-v1-5/stable-diffusion-v1-5", controlnet=controlnet, torch_dtype=torch.float16, use_safetensors=True )
Multi-modale modellen met Hugging Face

Image inpainting

def make_inpaint_condition(image, image_mask):
    image = np.array(image.convert("RGB")).astype(np.float32) / 255.0
    image_mask = np.array(image_mask.convert("L")).astype(np.float32) / 255.0


image[image_mask > 0.5] = -1.0
image = np.expand_dims(image, 0).transpose(0, 3, 1, 2) image = torch.from_numpy(image) return image control_image = make_inpaint_condition(init_image, mask_image)
Multi-modale modellen met Hugging Face

Image inpainting

output = pipe(
    "The head of the mona lisa in the 
  same style and quality as the original
  mona lisa with a clear smile and a 
  slightly smaller head size",

num_inference_steps=40,
eta=1.0,
image=init_image, mask_image=mask_image, control_image=control_image, ).images[0]

Mona Lisa nu met een glimlach

Multi-modale modellen met Hugging Face

Laten we oefenen!

Multi-modale modellen met Hugging Face

Preparing Video For Download...