-
Notifications
You must be signed in to change notification settings - Fork 677
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
3a64cc2
commit 6a25006
Showing
2 changed files
with
113 additions
and
22 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
# ControlNet | ||
|
||
We provide extensive ControlNet support. Taking the FLUX model as an example, we support many different ControlNet models that can be freely combined, even if their structures differ. Additionally, ControlNet models are compatible with high-resolution refinement and partition control techniques, enabling very powerful controllable image generation. | ||
|
||
These examples are in [`flux_controlnet.py`](./flux_controlnet.py). | ||
|
||
## Canny/Depth/Normal: Structure Control | ||
|
||
Structural control is the most fundamental capability of the ControlNet model. By using Canny to extract edge information, or by utilizing depth maps and normal maps, we can extract the structure of an image, which can then serve as control information during the image generation process. | ||
|
||
Model link: https://modelscope.cn/models/InstantX/FLUX.1-dev-Controlnet-Union-alpha | ||
|
||
For example, if we generate an image of a cat and use a model like InstantX/FLUX.1-dev-Controlnet-Union-alpha that supports multiple control conditions, we can simultaneously enable both Canny and Depth controls to transform the environment into a twilight setting. | ||
|
||
|data:image/s3,"s3://crabby-images/356f4/356f48c7b50fbbf42f97f5711abf64fe36ddf8fd" alt="image_5"|data:image/s3,"s3://crabby-images/05c6f/05c6f0d085c1d1d2a861a93dc97b2b15e9bc27a3" alt="image_6"| | ||
|-|-| | ||
|
||
The control strength of ControlNet for structure can be adjusted. For example, in the case below, when we move the girl from summer to winter, we can appropriately lower the control strength of ControlNet so that the model will adapt to the content of the image and change her into warm clothes. | ||
|
||
|data:image/s3,"s3://crabby-images/48bc1/48bc198e0a5083f17393bccf39c6f419462e529c" alt="image_7"|data:image/s3,"s3://crabby-images/9b483/9b483f48c4ef390595dd3259ddc3d598f2f9483e" alt="image_8"| | ||
|-|-| | ||
|
||
## Upscaler/Tile/Blur: High-Resolution Image Synthesis | ||
|
||
There are many ControlNet models that support high definition, such as: | ||
|
||
Model link: https://modelscope.cn/models/jasperai/Flux.1-dev-Controlnet-Upscaler, https://modelscope.cn/models/InstantX/FLUX.1-dev-Controlnet-Union-alpha, https://modelscope.cn/models/Shakker-Labs/FLUX.1-dev-ControlNet-Union-Pro | ||
|
||
These models can transform blurry, noisy low-quality images into clear ones. In DiffSynth-Studio, the native high-resolution patch processing technology supported by the framework can overcome the resolution limitations of the models, enabling image generation at resolutions of 2048 or even higher, significantly enhancing the capabilities of these models. In the example below, we can see that in the high-definition image enlarged to 2048 resolution, the cat's fur is rendered in exquisite detail, and the skin texture of the characters is delicate and realistic. | ||
|
||
|data:image/s3,"s3://crabby-images/6a779/6a7797885c8f05515c296235db5e1ff75ad06336" alt="image_1"|data:image/s3,"s3://crabby-images/d173c/d173c3eefa6d6cd2f49dfbd1fe2a4996ab401b12" alt="image_2"| | ||
|-|-| | ||
|
||
|data:image/s3,"s3://crabby-images/082d9/082d90b1d67794d3d85b9e2c5b55075aca3ce17c" alt="image_3"|data:image/s3,"s3://crabby-images/ddab3/ddab314b30dfae4edd68f55ba0eeab9295027b28" alt="image_4"| | ||
|-|-| | ||
|
||
## Inpaint: Image Restoration | ||
|
||
The Inpaint ControlNet model can repaint specific areas in an image. For example, we can put sunglasses on a cat. | ||
|
||
Model link: https://modelscope.cn/models/alimama-creative/FLUX.1-dev-Controlnet-Inpainting-Beta | ||
|
||
|data:image/s3,"s3://crabby-images/f3e03/f3e03e3fc71f0ef57b4c77efa9ddd2788dbae7b3" alt="image_9"|data:image/s3,"s3://crabby-images/16dd9/16dd985828fe63e490981d1926201692bea486d8" alt="mask_9"|data:image/s3,"s3://crabby-images/77580/775804105f489b8504ab54bb7541fc96b8a36484" alt="image_10"| | ||
|-|-|-| | ||
|
||
However, we noticed that the head movements of the cat have changed. If we want to preserve the original structural features, we can use the Canny, Depth, and Normal models. DiffSynth-Studio provides seamless support for ControlNet of different structures. By using a Normal ControlNet, we can ensure that the structure of the image remains unchanged during local redrawing. | ||
|
||
Model link: https://modelscope.cn/models/jasperai/Flux.1-dev-Controlnet-Surface-Normals | ||
|
||
|data:image/s3,"s3://crabby-images/887fb/887fb203cc3892efd08be2df2042e65b8587a4d6" alt="image_11"|data:image/s3,"s3://crabby-images/33ef6/33ef6b1152795a2e2ab691c04575eaccb649cb4e" alt="mask_11"|data:image/s3,"s3://crabby-images/c88e2/c88e240a2476279db8f1f952602c0caf86987639" alt="image_12"| | ||
|-|-|-| | ||
|
||
## MultiControlNet+MultiDiffusion: Fine-Grained Control | ||
|
||
DiffSynth-Studio not only supports the simultaneous activation of multiple ControlNet structures, but also allows for the partitioned control of content within an image using different prompts. Additionally, it supports the chunk processing of ultra-high-resolution large images, enabling us to achieve extremely detailed high-level control. Next, we will showcase the creative process behind a beautiful image. | ||
|
||
First, use the prompt "a beautiful Asian woman and a cat on a bed. The woman wears a dress" to generate a cat and a young girl. | ||
|
||
data:image/s3,"s3://crabby-images/37307/3730753f50f53abfeafd61e8ca1d641f0b94fba9" alt="image_13" | ||
|
||
Then, enable Inpaint ControlNet and Canny ControlNet. | ||
|
||
Model link: https://modelscope.cn/models/alimama-creative/FLUX.1-dev-Controlnet-Inpainting-Beta, https://modelscope.cn/models/InstantX/FLUX.1-dev-Controlnet-Union-alpha | ||
|
||
We control the image using two component. | ||
|
||
|Prompt: an orange cat, highly detailed|Prompt: a girl wearing a red camisole| | ||
|-|-| | ||
|data:image/s3,"s3://crabby-images/7493a/7493a2cb5524739d10bc59c8f891ebf241f77e47" alt="mask_13_1"|data:image/s3,"s3://crabby-images/311aa/311aab48c6ffc963216d04be5ab10b245552c5fa" alt="mask_13_2"| | ||
|
||
Generate! | ||
|
||
data:image/s3,"s3://crabby-images/0ed80/0ed8024d21d7d67f14c49cff2ce4a6f487938347" alt="image_14" | ||
|
||
The background is a bit blurry, so we use deblurring LoRA for image-to-image generation. | ||
|
||
Model link: https://modelscope.cn/models/LiblibAI/FLUX.1-dev-LoRA-AntiBlur | ||
|
||
data:image/s3,"s3://crabby-images/67f41/67f41da99881cab59145592cb91155ce27ebab3e" alt="image_15" | ||
|
||
The entire image is much clearer now. Next, let's use the high-definition model to increase the resolution to 4096*4096! | ||
|
||
Model link: https://modelscope.cn/models/jasperai/Flux.1-dev-Controlnet-Upscaler | ||
|
||
data:image/s3,"s3://crabby-images/c8731/c87310ed455b526e2736550400a823ba4b4c5240" alt="image_17" | ||
|
||
Zoom in to see details. | ||
|
||
data:image/s3,"s3://crabby-images/0a65e/0a65ef638c59b61d7a4971d60a350504bb26881a" alt="image_17_cropped" | ||
|
||
Enjoy! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters