from diffusers import AutoencoderKL, DDPMScheduler, T2IAdapter, UNet2DConditionModel
from transformers import AutoTokenizer, CLIPTextModel, CLIPTextModelWithProjection
from diffengine.models.editors import StableDiffusionXLT2IAdapter
[docs]base_model = "stabilityai/stable-diffusion-xl-base-1.0"
[docs]model = dict(type=StableDiffusionXLT2IAdapter,
model=base_model,
tokenizer_one=dict(type=AutoTokenizer.from_pretrained,
subfolder="tokenizer",
use_fast=False),
tokenizer_two=dict(type=AutoTokenizer.from_pretrained,
subfolder="tokenizer_2",
use_fast=False),
scheduler=dict(type=DDPMScheduler.from_pretrained,
subfolder="scheduler"),
text_encoder_one=dict(type=CLIPTextModel.from_pretrained,
subfolder="text_encoder"),
text_encoder_two=dict(type=CLIPTextModelWithProjection.from_pretrained,
subfolder="text_encoder_2"),
vae=dict(
type=AutoencoderKL.from_pretrained,
pretrained_model_name_or_path="madebyollin/sdxl-vae-fp16-fix"),
unet=dict(type=UNet2DConditionModel.from_pretrained,
subfolder="unet"),
adapter=dict(type=T2IAdapter,
in_channels=3,
channels=[320, 640, 1280, 1280],
num_res_blocks=2,
downscale_factor=16,
adapter_type="full_adapter_xl"),
gradient_checkpointing=True)