Diffusers 文件

ControlNetUnionModel

Hugging Face's logo
加入 Hugging Face 社群

並獲得增強的文件體驗

開始使用

ControlNetUnionModel

ControlNetUnionModel 是 Stable Diffusion XL 的 ControlNet 實現。

ControlNet 模型由 xinsir6 在 ControlNetPlus 中引入。它支援多個條件輸入而無需增加計算量。

我們設計了一種新架構,可以在條件文字到影像生成中支援 10 多種控制型別,並且可以生成視覺效果與 midjourney 媲美的高解析度影像。該網路基於原始 ControlNet 架構,我們提出了兩個新模組:1. 擴充套件原始 ControlNet 以支援使用相同網路引數的不同影像條件。2. 支援多個條件輸入而無需增加計算解除安裝,這對於想要詳細編輯影像的設計師來說尤其重要,不同的條件使用相同的條件編碼器,無需額外的計算或引數。

載入

預設情況下,應使用 ControlNetUnionModel 載入 from_pretrained()

from diffusers import StableDiffusionXLControlNetUnionPipeline, ControlNetUnionModel

controlnet = ControlNetUnionModel.from_pretrained("xinsir/controlnet-union-sdxl-1.0")
pipe = StableDiffusionXLControlNetUnionPipeline.from_pretrained("stabilityai/stable-diffusion-xl-base-1.0", controlnet=controlnet)

ControlNetUnionModel

class diffusers.ControlNetUnionModel

< >

( in_channels: int = 4 conditioning_channels: int = 3 flip_sin_to_cos: bool = True freq_shift: int = 0 down_block_types: typing.Tuple[str, ...] = ('CrossAttnDownBlock2D', 'CrossAttnDownBlock2D', 'CrossAttnDownBlock2D', 'DownBlock2D') only_cross_attention: typing.Union[bool, typing.Tuple[bool]] = False block_out_channels: typing.Tuple[int, ...] = (320, 640, 1280, 1280) layers_per_block: int = 2 downsample_padding: int = 1 mid_block_scale_factor: float = 1 act_fn: str = 'silu' norm_num_groups: typing.Optional[int] = 32 norm_eps: float = 1e-05 cross_attention_dim: int = 1280 transformer_layers_per_block: typing.Union[int, typing.Tuple[int, ...]] = 1 encoder_hid_dim: typing.Optional[int] = None encoder_hid_dim_type: typing.Optional[str] = None attention_head_dim: typing.Union[int, typing.Tuple[int, ...]] = 8 num_attention_heads: typing.Union[int, typing.Tuple[int, ...], NoneType] = None use_linear_projection: bool = False class_embed_type: typing.Optional[str] = None addition_embed_type: typing.Optional[str] = None addition_time_embed_dim: typing.Optional[int] = None num_class_embeds: typing.Optional[int] = None upcast_attention: bool = False resnet_time_scale_shift: str = 'default' projection_class_embeddings_input_dim: typing.Optional[int] = None controlnet_conditioning_channel_order: str = 'rgb' conditioning_embedding_out_channels: typing.Optional[typing.Tuple[int, ...]] = (48, 96, 192, 384) global_pool_conditions: bool = False addition_embed_type_num_heads: int = 64 num_control_type: int = 6 num_trans_channel: int = 320 num_trans_head: int = 8 num_trans_layer: int = 1 num_proj_channel: int = 320 )

引數

  • in_channels (int, 預設為 4) — 輸入樣本中的通道數。
  • flip_sin_to_cos (bool, 預設為 True) — 是否在時間嵌入中將 sin 翻轉為 cos。
  • freq_shift (int, 預設為 0) — 應用於時間嵌入的頻率偏移。
  • down_block_types (tuple[str], 預設為 ("CrossAttnDownBlock2D", "CrossAttnDownBlock2D", "CrossAttnDownBlock2D", "DownBlock2D")) — 要使用的下采樣塊元組。
  • only_cross_attention (Union[bool, Tuple[bool]], 預設為 False) —
  • block_out_channels (tuple[int], 預設為 (320, 640, 1280, 1280)) — 每個塊的輸出通道元組。
  • layers_per_block (int, 預設為 2) — 每個塊的層數。
  • downsample_padding (int, 預設為 1) — 下采樣卷積要使用的填充。
  • mid_block_scale_factor (float, 預設為 1) — 中間塊的比例因子。
  • act_fn (str, 預設為 “silu”) — 要使用的啟用函式。
  • norm_num_groups (int, 可選, 預設為 32) — 歸一化要使用的組數。如果為 None,則在後處理中跳過歸一化和啟用層。
  • norm_eps (float, 預設為 1e-5) — 歸一化要使用的 epsilon。
  • cross_attention_dim (int, 預設為 1280) — 交叉注意力特徵的維度。
  • transformer_layers_per_block (intTuple[int], 可選, 預設為 1) — 型別為 BasicTransformerBlock 的 transformer 塊的數量。僅與 ~models.unet_2d_blocks.CrossAttnDownBlock2D, ~models.unet_2d_blocks.CrossAttnUpBlock2D, ~models.unet_2d_blocks.UNetMidBlock2DCrossAttn 相關。
  • encoder_hid_dim (int, 可選, 預設為 None) — 如果定義了 encoder_hid_dim_type,則 encoder_hidden_states 將從 encoder_hid_dim 維度投影到 cross_attention_dim
  • encoder_hid_dim_type (str, 可選, 預設為 None) — 如果給定,encoder_hidden_states 和其他可能的嵌入將根據 encoder_hid_dim_type 下投影到維度為 cross_attention 的文字嵌入。
  • attention_head_dim (Union[int, Tuple[int]], 預設為 8) — 注意力頭的維度。
  • use_linear_projection (bool, 預設為 False) —
  • class_embed_type (str, 可選, 預設為 None) — 要使用的類嵌入型別,最終與時間嵌入求和。可選擇 None, "timestep", "identity", "projection", 或 "simple_projection"
  • addition_embed_type (str, 可選, 預設為 None) — 配置一個可選嵌入,該嵌入將與時間嵌入求和。可選擇 None 或 “text”。“text”將使用 TextTimeEmbedding 層。
  • num_class_embeds (int, 可選, 預設為 0) — 當 class_embed_type 等於 None 時,要投影到 time_embed_dim 的可學習嵌入矩陣的輸入維度。當 class_embed_type="projection" 時必需。
  • upcast_attention (bool, 預設為 False) —
  • resnet_time_scale_shift (str, 預設為 "default") — ResNet 塊的時間尺度偏移配置(參見 ResnetBlock2D)。可選擇 defaultscale_shift
  • projection_class_embeddings_input_dim (int, 可選, 預設為 None) — 當 class_embed_type="projection" 時,class_labels 輸入的維度。當 class_embed_type="projection" 時必需。
  • controlnet_conditioning_channel_order (str, 預設為 "rgb") — 條件影像的通道順序。如果為 bgr,將轉換為 rgb
  • conditioning_embedding_out_channels (tuple[int], 可選, 預設為 (48, 96, 192, 384)) — conditioning_embedding 層中每個塊的輸出通道元組。
  • global_pool_conditions (bool, 預設為 False) —

ControlNetUnion 模型。

forward

< >

( sample: Tensor timestep: typing.Union[torch.Tensor, float, int] encoder_hidden_states: Tensor controlnet_cond: typing.List[torch.Tensor] control_type: Tensor control_type_idx: typing.List[int] conditioning_scale: typing.Union[float, typing.List[float]] = 1.0 class_labels: typing.Optional[torch.Tensor] = None timestep_cond: typing.Optional[torch.Tensor] = None attention_mask: typing.Optional[torch.Tensor] = None added_cond_kwargs: typing.Optional[typing.Dict[str, torch.Tensor]] = None cross_attention_kwargs: typing.Optional[typing.Dict[str, typing.Any]] = None from_multi: bool = False guess_mode: bool = False return_dict: bool = True ) ControlNetOutput tuple

引數

  • sample (torch.Tensor) — 噪聲輸入張量。
  • timestep (Union[torch.Tensor, float, int]) — 去噪輸入的步長數。
  • encoder_hidden_states (torch.Tensor) — 編碼器隱藏狀態。
  • controlnet_cond (List[torch.Tensor]) — 條件輸入張量。
  • control_type (torch.Tensor) — 形狀為 (batch, num_control_type) 的張量,其值根據是否使用控制型別為 01
  • control_type_idx (List[int]) — control_type 的索引。
  • conditioning_scale (float, 預設為 1.0) — ControlNet 輸出的比例因子。
  • class_labels (torch.Tensor, 可選, 預設為 None) — 可選的用於條件化的類標籤。它們的嵌入將與時間嵌入求和。
  • timestep_cond (torch.Tensor, 可選, 預設為 None) — 時間步長的額外條件嵌入。如果提供,嵌入將與透過 self.time_embedding 層的時間嵌入求和,以獲得最終的時間嵌入。
  • attention_mask (torch.Tensor, 可選, 預設為 None) — 形狀為 (batch, key_tokens) 的注意力掩碼應用於 encoder_hidden_states。如果為 1 則保留掩碼,否則如果為 0 則丟棄。掩碼將轉換為偏置,其將較大的負值新增到與“丟棄”令牌對應的注意力分數中。
  • added_cond_kwargs (dict) — Stable Diffusion XL UNet 的附加條件。
  • cross_attention_kwargs (dict[str], 可選, 預設為 None) — 一個 kwargs 字典,如果指定,則會傳遞給 AttnProcessor
  • from_multi (bool, 預設為 False) — 當從 MultiControlNetUnionModel 呼叫時,使用標準縮放。
  • guess_mode (bool, 預設為 False) — 在此模式下,ControlNet 編碼器會盡力識別輸入的輸入內容,即使您刪除了所有提示。建議 guidance_scale 在 3.0 到 5.0 之間。
  • return_dict (bool, 預設為 True) — 是否返回 ControlNetOutput 而不是普通元組。

返回

ControlNetOutput tuple

如果 return_dictTrue,則返回 ControlNetOutput,否則返回一個元組,其中第一個元素是樣本張量。

ControlNetUnionModel 的 forward 方法。

from_unet

< >

( unet: UNet2DConditionModel controlnet_conditioning_channel_order: str = 'rgb' conditioning_embedding_out_channels: typing.Optional[typing.Tuple[int, ...]] = (16, 32, 96, 256) load_weights_from_unet: bool = True )

引數

  • unet (UNet2DConditionModel) — 要複製到 ControlNetUnionModel 的 UNet 模型權重。所有適用的配置選項也會複製。

UNet2DConditionModel 例項化 ControlNetUnionModel

set_attention_slice

< >

( slice_size: typing.Union[str, int, typing.List[int]] )

引數

  • slice_size (strintlist(int), 可選, 預設為 "auto") — 當為 "auto" 時,輸入到注意力頭的輸入減半,因此注意力分兩步計算。如果為 "max",則透過每次只執行一個切片來最大程度地節省記憶體。如果提供一個數字,則使用 attention_head_dim // slice_size 個切片。在這種情況下,attention_head_dim 必須是 slice_size 的倍數。

啟用分片注意力計算。

啟用此選項後,注意力模組會將輸入張量分片以分步計算注意力。這對於節省記憶體非常有用,但會稍微降低速度。

設定注意力處理器

< >

( processor: typing.Union[diffusers.models.attention_processor.AttnProcessor, diffusers.models.attention_processor.CustomDiffusionAttnProcessor, diffusers.models.attention_processor.AttnAddedKVProcessor, diffusers.models.attention_processor.AttnAddedKVProcessor2_0, diffusers.models.attention_processor.JointAttnProcessor2_0, diffusers.models.attention_processor.PAGJointAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGJointAttnProcessor2_0, diffusers.models.attention_processor.FusedJointAttnProcessor2_0, diffusers.models.attention_processor.AllegroAttnProcessor2_0, diffusers.models.attention_processor.AuraFlowAttnProcessor2_0, diffusers.models.attention_processor.FusedAuraFlowAttnProcessor2_0, diffusers.models.attention_processor.FluxAttnProcessor2_0, diffusers.models.attention_processor.FluxAttnProcessor2_0_NPU, diffusers.models.attention_processor.FusedFluxAttnProcessor2_0, diffusers.models.attention_processor.FusedFluxAttnProcessor2_0_NPU, diffusers.models.attention_processor.CogVideoXAttnProcessor2_0, diffusers.models.attention_processor.FusedCogVideoXAttnProcessor2_0, diffusers.models.attention_processor.XFormersAttnAddedKVProcessor, diffusers.models.attention_processor.XFormersAttnProcessor, diffusers.models.attention_processor.XLAFlashAttnProcessor2_0, diffusers.models.attention_processor.AttnProcessorNPU, diffusers.models.attention_processor.AttnProcessor2_0, diffusers.models.attention_processor.MochiVaeAttnProcessor2_0, diffusers.models.attention_processor.MochiAttnProcessor2_0, diffusers.models.attention_processor.StableAudioAttnProcessor2_0, diffusers.models.attention_processor.HunyuanAttnProcessor2_0, diffusers.models.attention_processor.FusedHunyuanAttnProcessor2_0, diffusers.models.attention_processor.PAGHunyuanAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGHunyuanAttnProcessor2_0, diffusers.models.attention_processor.LuminaAttnProcessor2_0, diffusers.models.attention_processor.FusedAttnProcessor2_0, diffusers.models.attention_processor.CustomDiffusionXFormersAttnProcessor, diffusers.models.attention_processor.CustomDiffusionAttnProcessor2_0, diffusers.models.attention_processor.SlicedAttnProcessor, diffusers.models.attention_processor.SlicedAttnAddedKVProcessor, diffusers.models.attention_processor.SanaLinearAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGSanaLinearAttnProcessor2_0, diffusers.models.attention_processor.PAGIdentitySanaLinearAttnProcessor2_0, diffusers.models.attention_processor.SanaMultiscaleLinearAttention, diffusers.models.attention_processor.SanaMultiscaleAttnProcessor2_0, diffusers.models.attention_processor.SanaMultiscaleAttentionProjection, diffusers.models.attention_processor.IPAdapterAttnProcessor, diffusers.models.attention_processor.IPAdapterAttnProcessor2_0, diffusers.models.attention_processor.IPAdapterXFormersAttnProcessor, diffusers.models.attention_processor.SD3IPAdapterJointAttnProcessor2_0, diffusers.models.attention_processor.PAGIdentitySelfAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGIdentitySelfAttnProcessor2_0, diffusers.models.attention_processor.LoRAAttnProcessor, diffusers.models.attention_processor.LoRAAttnProcessor2_0, diffusers.models.attention_processor.LoRAXFormersAttnProcessor, diffusers.models.attention_processor.LoRAAttnAddedKVProcessor, typing.Dict[str, typing.Union[diffusers.models.attention_processor.AttnProcessor, diffusers.models.attention_processor.CustomDiffusionAttnProcessor, diffusers.models.attention_processor.AttnAddedKVProcessor, diffusers.models.attention_processor.AttnAddedKVProcessor2_0, diffusers.models.attention_processor.JointAttnProcessor2_0, diffusers.models.attention_processor.PAGJointAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGJointAttnProcessor2_0, diffusers.models.attention_processor.FusedJointAttnProcessor2_0, diffusers.models.attention_processor.AllegroAttnProcessor2_0, diffusers.models.attention_processor.AuraFlowAttnProcessor2_0, diffusers.models.attention_processor.FusedAuraFlowAttnProcessor2_0, diffusers.models.attention_processor.FluxAttnProcessor2_0, diffusers.models.attention_processor.FluxAttnProcessor2_0_NPU, diffusers.models.attention_processor.FusedFluxAttnProcessor2_0, diffusers.models.attention_processor.FusedFluxAttnProcessor2_0_NPU, diffusers.models.attention_processor.CogVideoXAttnProcessor2_0, diffusers.models.attention_processor.FusedCogVideoXAttnProcessor2_0, diffusers.models.attention_processor.XFormersAttnAddedKVProcessor, diffusers.models.attention_processor.XFormersAttnProcessor, diffusers.models.attention_processor.XLAFlashAttnProcessor2_0, diffusers.models.attention_processor.AttnProcessorNPU, diffusers.models.attention_processor.AttnProcessor2_0, diffusers.models.attention_processor.MochiVaeAttnProcessor2_0, diffusers.models.attention_processor.MochiAttnProcessor2_0, diffusers.models.attention_processor.StableAudioAttnProcessor2_0, diffusers.models.attention_processor.HunyuanAttnProcessor2_0, diffusers.models.attention_processor.FusedHunyuanAttnProcessor2_0, diffusers.models.attention_processor.PAGHunyuanAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGHunyuanAttnProcessor2_0, diffusers.models.attention_processor.LuminaAttnProcessor2_0, diffusers.models.attention_processor.FusedAttnProcessor2_0, diffusers.models.attention_processor.CustomDiffusionXFormersAttnProcessor, diffusers.models.attention_processor.CustomDiffusionAttnProcessor2_0, diffusers.models.attention_processor.SlicedAttnProcessor, diffusers.models.attention_processor.SlicedAttnAddedKVProcessor, diffusers.models.attention_processor.SanaLinearAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGSanaLinearAttnProcessor2_0, diffusers.models.attention_processor.PAGIdentitySanaLinearAttnProcessor2_0, diffusers.models.attention_processor.SanaMultiscaleLinearAttention, diffusers.models.attention_processor.SanaMultiscaleAttnProcessor2_0, diffusers.models.attention_processor.SanaMultiscaleAttentionProjection, diffusers.models.attention_processor.IPAdapterAttnProcessor, diffusers.models.attention_processor.IPAdapterAttnProcessor2_0, diffusers.models.attention_processor.IPAdapterXFormersAttnProcessor, diffusers.models.attention_processor.SD3IPAdapterJointAttnProcessor2_0, diffusers.models.attention_processor.PAGIdentitySelfAttnProcessor2_0, diffusers.models.attention_processor.PAGCFGIdentitySelfAttnProcessor2_0, diffusers.models.attention_processor.LoRAAttnProcessor, diffusers.models.attention_processor.LoRAAttnProcessor2_0, diffusers.models.attention_processor.LoRAXFormersAttnProcessor, diffusers.models.attention_processor.LoRAAttnAddedKVProcessor]]] )

引數

  • processor (AttentionProcessordict 或僅 AttentionProcessor) — 例項化的處理器類或處理器類字典,它將設定為所有 Attention 層的處理器。

    如果 processor 是一個字典,則鍵需要定義到相應交叉注意力處理器的路徑。強烈建議在設定可訓練注意力處理器時使用此方法。

設定用於計算注意力的注意力處理器。

set_default_attn_processor

< >

( )

停用自定義注意力處理器並設定預設注意力實現。

< > 在 GitHub 上更新

© . This site is unofficial and not affiliated with Hugging Face, Inc.