forked from huggingface/diffusers
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add flux! Signed-off-by: Adrien <[email protected]> Co-authored-by: Adrien <[email protected]> Co-authored-by: Anatoly Belikov <[email protected]> Co-authored-by: Dhruv Nair <[email protected]> Co-authored-by: yiyixuxu <[email protected]>
- Loading branch information
1 parent
2ea22e1
commit 27637a5
Showing
21 changed files
with
2,270 additions
and
30 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
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,19 @@ | ||
<!--Copyright 2024 The HuggingFace Team. All rights reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | ||
the License. You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on | ||
an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the | ||
specific language governing permissions and limitations under the License. | ||
--> | ||
|
||
# FluxTransformer2DModel | ||
|
||
A Transformer model for image-like data from [Flux](https://blackforestlabs.ai/announcing-black-forest-labs/). | ||
|
||
## FluxTransformer2DModel | ||
|
||
[[autodoc]] FluxTransformer2DModel |
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,84 @@ | ||
<!--Copyright 2024 The HuggingFace Team. All rights reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with | ||
the License. You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on | ||
an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the | ||
specific language governing permissions and limitations under the License. | ||
--> | ||
|
||
# Flux | ||
|
||
Flux is a series of text-to-image generation models based on diffusion transformers. To know more about Flux, check out the original [blog post](https://blackforestlabs.ai/announcing-black-forest-labs/) by the creators of Flux, Black Forest Labs. | ||
|
||
Original model checkpoints for Flux can be found [here](https://huggingface.co/black-forest-labs). Original inference code can be found [here](https://github.com/black-forest-labs/flux). | ||
|
||
<Tip> | ||
|
||
Flux can be quite expensive to run on consumer hardware devices. However, you can perform a suite of optimizations to run it faster and in a more memory-friendly manner. Check out [this section](https://huggingface.co/blog/sd3#memory-optimizations-for-sd3) for more details. Additionally, Flux can benefit from quantization for memory efficiency with a trade-off in inference latency. Refer to [this blog post](https://huggingface.co/blog/quanto-diffusers) to learn more. | ||
|
||
</Tip> | ||
|
||
Flux comes in two variants: | ||
|
||
* Timestep-distilled (`black-forest-labs/FLUX.1-schnell`) | ||
* Guidance-distilled (`black-forest-labs/FLUX.1-dev`) | ||
|
||
Both checkpoints have slightly difference usage which we detail below. | ||
|
||
### Timestep-distilled | ||
|
||
* `max_sequence_length` cannot be more than 256. | ||
* `guidance_scale` needs to be 0. | ||
* As this is a timestep-distilled model, it benefits from fewer sampling steps. | ||
|
||
```python | ||
import torch | ||
from diffusers import FluxPipeline | ||
|
||
pipe = FluxPipeline.from_pretrained("black-forest-labs/FLUX.1-schnell", torch_dtype=torch.bfloat16) | ||
pipe.enable_model_cpu_offload() | ||
|
||
prompt = "A cat holding a sign that says hello world" | ||
out = pipe( | ||
prompt=prompt, | ||
guidance_scale=0., | ||
height=768, | ||
width=1360, | ||
num_inference_steps=4, | ||
max_sequence_length=256, | ||
).images[0] | ||
out.save("image.png") | ||
``` | ||
|
||
### Guidance-distilled | ||
|
||
* The guidance-distilled variant takes about 50 sampling steps for good-quality generation. | ||
* It doesn't have any limitations around the `max_sequence_length`. | ||
|
||
```python | ||
import torch | ||
from diffusers import FluxPipeline | ||
|
||
pipe = FluxPipeline.from_pretrained("black-forest-labs/FLUX.1-dev", torch_dtype=torch.bfloat16) | ||
pipe.enable_model_cpu_offload() | ||
|
||
prompt = "a tiny astronaut hatching from an egg on the moon" | ||
out = pipe( | ||
prompt=prompt, | ||
guidance_scale=3.5, | ||
height=768, | ||
width=1360, | ||
num_inference_steps=50, | ||
).images[0] | ||
out.save("image.png") | ||
``` | ||
|
||
## FluxPipeline | ||
|
||
[[autodoc]] FluxPipeline | ||
- all | ||
- __call__ |
Oops, something went wrong.