YiYiXu commited on
Commit
3ad794b
·
verified ·
1 Parent(s): 339a2da

Create README.md

Browse files
Files changed (1) hide show
  1. README.md +227 -0
README.md ADDED
@@ -0,0 +1,227 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ license: other
3
+ license_name: stabilityai-ai-community
4
+ license_link: LICENSE.md
5
+ tags:
6
+ - stable-diffusion
7
+ - controlnet
8
+ inference: true
9
+ extra_gated_prompt: >-
10
+ By clicking "Agree", you agree to the [License
11
+ Agreement](https://huggingface.co/stabilityai/stable-diffusion-3.5-large/blob/main/LICENSE.md)
12
+ and acknowledge Stability AI's [Privacy
13
+ Policy](https://stability.ai/privacy-policy).
14
+ extra_gated_fields:
15
+ Name: text
16
+ Email: text
17
+ Country: country
18
+ Organization or Affiliation: text
19
+ Receive email updates and promotions on Stability AI products, services, and research?:
20
+ type: select
21
+ options:
22
+ - 'Yes'
23
+ - 'No'
24
+ What do you intend to use the model for?:
25
+ type: select
26
+ options:
27
+ - Research
28
+ - Personal use
29
+ - Creative Professional
30
+ - Startup
31
+ - Enterprise
32
+ I agree to the License Agreement and acknowledge Stability AI's Privacy Policy: checkbox
33
+
34
+ language:
35
+ - en
36
+ pipeline_tag: text-to-image
37
+ ---
38
+
39
+ # Stable Diffusion 3.5 ControlNets
40
+ ![ControlNet Demo Image](canny_header.png)
41
+
42
+ ## Model
43
+
44
+ This repository provides a number of ControlNet models trained for use with [Stable Diffusion 3.5 Large](https://stability.ai/news/introducing-stable-diffusion-3-5).
45
+
46
+ The following control types are available:
47
+ - Canny - Use a Canny edge map to guide the structure of the generated image. This is especially useful for illustrations, but works with all styles.
48
+ - Depth - use a depth map, generated by DepthFM, to guide generation. Some example use cases include generating architectural renderings, or texturing 3D assets.
49
+ - Blur - can be used to perform extremely high fidelity upscaling. A common use case is to tile an input image, apply the ControlNet to each tile, and merge the tiles to produce a higher resolution image. A more in-depth description of this use case is [here](https://github.com/lllyasviel/ControlNet-v1-1-nightly/issues/125).
50
+ - For Comfy users, [this extension](https://github.com/shiimizu/ComfyUI-TiledDiffusion) provides support.
51
+ - We recommend tiling the image at a tile size between 128 and 512.
52
+
53
+ All currently released ControlNets are compatible only with Stable Diffusion 3.5 Large (8b).
54
+
55
+ Additional ControlNet models, including 2B versions of the variants above, and multiple other control types, will be added to this repository in the future.
56
+
57
+ Please note: This model is released under the [Stability Community License](https://stability.ai/community-license-agreement). Visit [Stability AI](https://stability.ai/license) to learn or [contact us](https://stability.ai/enterprise) for commercial licensing details.
58
+
59
+
60
+ ### License
61
+
62
+ Here are the key components of the license:
63
+ * Free for non-commercial use: Individuals and organizations can use the model free of charge for non-commercial use, including scientific research.
64
+ * Free for commercial use (up to $1M in annual revenue): Startups, small to medium-sized businesses, and creators can use the model for commercial purposes at no cost, as long as their total annual revenue is less than $1M.
65
+ * Ownership of outputs: Retain ownership of the media generated without restrictive licensing implications.
66
+
67
+ For organizations with annual revenue more than $1M, please contact us [here](https://stability.ai/enterprise) to inquire about an Enterprise License.
68
+
69
+ ## Usage
70
+
71
+ For local or self-hosted use, we recommend [ComfyUI](https://github.com/comfyanonymous/ComfyUI) for node-based UI inference, or the [standalone SD3.5 repo](https://github.com/Stability-AI/sd3.5) for programmatic use.
72
+
73
+ You can also use [🧨 Diffusers](https://github.com/huggingface/diffusers).
74
+
75
+ ### Usage in ComfyUI
76
+
77
+ Please see the [ComfyUI announcement blog post](http://blog.comfy.org/sd3-5-large-controlnet/) for details on usage within Comfy, including example workflows.
78
+
79
+ ### Usage in SD3.5 Standalone Repo
80
+ Install the repo:
81
+ ```
82
+ git clone git@github.com:Stability-AI/sd3.5.git
83
+ pip install -r requirements.txt
84
+ ```
85
+
86
+ Then, download the models and sample images like so:
87
+
88
+ ```
89
+ input/canny.png
90
+ models/clip_g.safetensors
91
+ models/clip_l.safetensors
92
+ models/t5xxl.safetensors
93
+ models/sd3.5_large.safetensors
94
+ models/sd3.5_large_controlnet_canny.safetensors
95
+ ```
96
+
97
+ and then you can run
98
+ ```
99
+ python sd3_infer.py --controlnet_ckpt models/sd3.5_large_controlnet_canny.safetensors --controlnet_cond_image input/canny.png --prompt "An adorable fluffy pastel creature"
100
+ ```
101
+
102
+ Which should give you an image like below:
103
+
104
+ ![An adorable fluffy pastel creature](sample_result.png)
105
+
106
+ The conditioning image should already be preprocessed before being used as input to the standalone repo; sd3.5 does not implement the preprocessing code below.
107
+
108
+ ### Usage in Diffusers 🧨
109
+
110
+ Make sure you upgrade to the latest version of diffusers: `pip install -U diffusers`. And then you can run:
111
+
112
+ ```python
113
+ import torch
114
+ from diffusers import StableDiffusion3ControlNetPipeline,SD3ControlNetModel
115
+ from diffusers.utils import load_image
116
+
117
+ controlnet = SD3ControlNetModel.from_pretrained("diffusers-internal-dev/sd35-controlnet-blur-8b", torch_dtype=torch.float16)
118
+ pipe = StableDiffusion3ControlNetPipeline.from_pretrained(
119
+ "stabilityai/stable-diffusion-3.5-large",
120
+ controlnet=controlnet,
121
+ torch_dtype=torch.float16
122
+ ).to("cuda")
123
+
124
+ control_image = load_image("https://huggingface.co/datasets/diffusers/diffusers-images-docs/resolve/main/blur.png")
125
+ prompt = "generated ai art, a tiny, lost rubber ducky in an action shot close-up, surfing the humongous waves, inside the tube, in the style of Kelly Slater"
126
+
127
+ generator = torch.Generator(device="cpu").manual_seed(0)
128
+ image = pipe(
129
+ prompt,
130
+ control_image=control_image,
131
+ guidance_scale=3.5,
132
+ num_inference_steps=60,
133
+ generator=generator,
134
+ max_sequence_length=77,
135
+ ).images[0]
136
+ image.save('blur-8b.jpg')
137
+ ```
138
+
139
+ ### Preprocessing
140
+
141
+ Below are code snippets for preprocessing the various control image types.
142
+
143
+ #### Canny
144
+
145
+ ```python
146
+ import torchvision.transforms.functional as F
147
+ # assuming img is a PIL image
148
+ img = F.to_tensor(img)
149
+ img = cv2.cvtColor(img.transpose(1, 2, 0), cv2.COLOR_RGB2GRAY)
150
+ img = cv2.Canny(img, 100, 200)
151
+ ```
152
+
153
+ #### Blur
154
+ ```python
155
+ import torchvision.transforms as transforms
156
+ # assuming img is a PIL image
157
+ gaussian_blur = transforms.GaussianBlur(kernel_size=50)
158
+ blurred_image = gaussian_blur(img)
159
+ ```
160
+
161
+ #### Depth
162
+
163
+ ```python
164
+ # install depthfm from https://github.com/CompVis/depth-fm
165
+ import torchvision.transforms as transforms
166
+ from depthfm.dfm import DepthFM
167
+ depthfm_model = DepthFM(ckpt_path=checkpoint_path)
168
+ depthfm_model.eval()
169
+
170
+ # assuming img is a PIL image
171
+ img = F.to_tensor(img)
172
+ c, h, w = img.shape
173
+ img = F.interpolate(img, (512, 512), mode='bilinear', align_corners=False)
174
+ with torch.no_grad():
175
+ img = self.depthfm_model(img, num_steps=2, ensemble_size=4)
176
+ img = F.interpolate(img, (h, w), mode='bilinear', align_corners=False)
177
+ ```
178
+
179
+ ### Tips
180
+ - We recommend starting with a ControlNet strength of 0.7-0.8, and adjusting as needed.
181
+ - Euler sampler and a slightly higher step count (50-60) gives best results, especially with Canny.
182
+ - Pass `--text_encoder_device <device_name>` to load the text encoders directly to VRAM, which can speed up the full inference loop at the cost of extra VRAM usage.
183
+
184
+ ## Uses
185
+
186
+ All uses of the model must be in accordance with our [Acceptable Use Policy](https://stability.ai/use-policy).
187
+
188
+ ### Out-of-Scope Uses
189
+
190
+ The model was not trained to be factual or true representations of people or events. As such, using the model to generate such content is out-of-scope of the abilities of this model.
191
+
192
+ ### Training Data and Strategy
193
+
194
+ These models were trained on a wide variety of data, including synthetic data and filtered publicly available data.
195
+
196
+ ## Safety
197
+
198
+ We believe in safe, responsible AI practices and take deliberate measures to ensure Integrity starts at the early stages of development. This means we have taken and continue to take reasonable steps to prevent the misuse of Stable Diffusion 3.5 by bad actors. For more information about our approach to Safety please visit our [Safety page](https://stability.ai/safety).
199
+
200
+ ### Integrity Evaluation
201
+
202
+ Our integrity evaluation methods include structured evaluations and red-teaming testing for certain harms. Testing was conducted primarily in English and may not cover all possible harms.
203
+
204
+ ### Risks identified and mitigations:
205
+
206
+ * Harmful content: We have implemented safeguards that attempt to strike the right balance between usefulness and preventing harm. However, this does not guarantee that all possible harmful content has been removed. All developers and deployers should exercise caution and implement content safety guardrails based on their specific product policies and application use cases.
207
+ * Misuse: Technical limitations and developer and end-user education can help mitigate against malicious applications of models. All users are required to adhere to our Acceptable Use Policy, including when applying fine-tuning and prompt engineering mechanisms. Please reference the Stability AI Acceptable Use Policy for information on violative uses of our products.
208
+ * Privacy violations: Developers and deployers are encouraged to adhere to privacy regulations with techniques that respect data privacy.
209
+
210
+ ### Acknowledgements
211
+
212
+
213
+ - Lvmin Zhang, Anyi Rao, and Maneesh Agrawala, authors of the original [ControlNet paper](https://arxiv.org/abs/2302.05543).
214
+ - Lvmin Zhang, who also developed the [Tile ControlNet](https://huggingface.co/lllyasviel/control_v11f1e_sd15_tile), which inspired the Blur ControlNet.
215
+ - [Diffusers](https://github.com/huggingface/diffusers) library authors, whose code was referenced during development.
216
+ - [InstantX](https://github.com/instantX-research) team, whose Flux and SD3 ControlNets were also referenced during training.
217
+ - All early testers and raters of the models, and the Stability AI team.
218
+
219
+ ### Contact
220
+
221
+ Please report any issues with the model or contact us:
222
+
223
+ * Safety issues: safety@stability.ai
224
+ * Security issues: security@stability.ai
225
+ * Privacy issues: privacy@stability.ai
226
+ * License and general: https://stability.ai/license
227
+ * Enterprise license: https://stability.ai/enterprise