Diffusers documentation

SanaControlNetModel

You are viewing main version, which requires installation from source. If you'd like regular pip install, checkout the latest stable version (v0.38.0).
Hugging Face's logo
Join the Hugging Face community

and get access to the augmented documentation experience

to get started

SanaControlNetModel

The ControlNet model was introduced in Adding Conditional Control to Text-to-Image Diffusion Models by Lvmin Zhang, Anyi Rao, Maneesh Agrawala. It provides a greater degree of control over text-to-image generation by conditioning the model on additional inputs such as edge maps, depth maps, segmentation maps, and keypoints for pose detection.

The abstract from the paper is:

We present ControlNet, a neural network architecture to add spatial conditioning controls to large, pretrained text-to-image diffusion models. ControlNet locks the production-ready large diffusion models, and reuses their deep and robust encoding layers pretrained with billions of images as a strong backbone to learn a diverse set of conditional controls. The neural architecture is connected with “zero convolutions” (zero-initialized convolution layers) that progressively grow the parameters from zero and ensure that no harmful noise could affect the finetuning. We test various conditioning controls, eg, edges, depth, segmentation, human pose, etc, with Stable Diffusion, using single or multiple conditions, with or without prompts. We show that the training of ControlNets is robust with small (<50k) and large (>1m) datasets. Extensive results show that ControlNet may facilitate wider applications to control image diffusion models.

This model was contributed by ishan24. ❤️ The original codebase can be found at NVlabs/Sana, and you can find official ControlNet checkpoints on Efficient-Large-Model’s Hub profile.

SanaControlNetModel

class diffusers.SanaControlNetModel

< >

( in_channels: int = 32 out_channels: int | None = 32 num_attention_heads: int = 70 attention_head_dim: int = 32 num_layers: int = 7 num_cross_attention_heads: int | None = 20 cross_attention_head_dim: int | None = 112 cross_attention_dim: int | None = 2240 caption_channels: int = 2304 mlp_ratio: float = 2.5 dropout: float = 0.0 attention_bias: bool = False sample_size: int = 32 patch_size: int = 1 norm_elementwise_affine: bool = False norm_eps: float = 1e-06 interpolation_scale: int | None = None )

forward

< >

( hidden_states: Tensor encoder_hidden_states: Tensor timestep: LongTensor controlnet_cond: Tensor conditioning_scale: float = 1.0 encoder_attention_mask: torch.Tensor | None = None attention_mask: torch.Tensor | None = None attention_kwargs: dict[str, typing.Any] | None = None return_dict: bool = True )

Parameters

  • hidden_states (torch.Tensor of shape (batch_size, channel, height, width)) — Input hidden_states.
  • encoder_hidden_states (torch.Tensor) — Conditional embeddings (embeddings computed from the input conditions such as prompts) to use.
  • timestep (torch.LongTensor) — Used to indicate denoising step.
  • controlnet_cond (torch.Tensor) — The conditional input tensor for the ControlNet.
  • conditioning_scale (float, optional, defaults to 1.0) — The scale factor for ControlNet outputs.
  • encoder_attention_mask (torch.Tensor, optional) — Attention mask applied to encoder_hidden_states.
  • attention_mask (torch.Tensor, optional) — Attention mask applied to hidden_states.
  • attention_kwargs (dict, optional) — A kwargs dictionary that if specified is passed along to the AttentionProcessor as defined under self.processor in diffusers.models.attention_processor.
  • return_dict (bool, optional, defaults to True) — Whether or not to return a ~models.transformer_2d.Transformer2DModelOutput instead of a plain tuple.

SanaControlNetOutput

class diffusers.models.controlnets.controlnet_sana.SanaControlNetOutput

< >

( controlnet_block_samples: tuple )

Update on GitHub