diffusers
🤗 Diffusers: State-of-the-art diffusion models for image and audio generation in PyTorch and FLAX.
Top Related Projects
High-Resolution Image Synthesis with Latent Diffusion Models
Stable Diffusion web UI
Invoke is a leading creative engine for Stable Diffusion models, empowering professionals, artists, and enthusiasts to generate and create visual media using the latest AI-driven technologies. The solution offers an industry leading WebUI, and serves as the foundation for multiple commercial products.
Generative Models by Stability AI
Quick Overview
Hugging Face's Diffusers is a state-of-the-art library for diffusion models in computer vision and audio. It provides pre-trained models, training utilities, and inference pipelines for various diffusion-based generative AI tasks, including image generation, inpainting, and audio synthesis.
Pros
- Extensive collection of pre-trained diffusion models
- Easy-to-use API for both inference and fine-tuning
- Seamless integration with other Hugging Face libraries
- Active development and community support
Cons
- Can be computationally intensive, requiring significant GPU resources
- Learning curve for understanding diffusion models and their parameters
- Limited documentation for some advanced features
- Dependency on other libraries may lead to version conflicts
Code Examples
- Basic image generation using Stable Diffusion:
from diffusers import StableDiffusionPipeline
import torch
pipe = StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5", torch_dtype=torch.float16)
pipe = pipe.to("cuda")
prompt = "a photo of an astronaut riding a horse on mars"
image = pipe(prompt).images[0]
image.save("astronaut_rides_horse.png")
- Image-to-image generation with Stable Diffusion:
from diffusers import StableDiffusionImg2ImgPipeline
from PIL import Image
import torch
pipe = StableDiffusionImg2ImgPipeline.from_pretrained("runwayml/stable-diffusion-v1-5", torch_dtype=torch.float16)
pipe = pipe.to("cuda")
init_image = Image.open("path_to_initial_image.png").convert("RGB")
prompt = "A fantasy landscape with a castle"
image = pipe(prompt=prompt, image=init_image, strength=0.75, guidance_scale=7.5).images[0]
image.save("fantasy_landscape.png")
- Audio generation using Audio Diffusion:
from diffusers import AudioDiffusionPipeline
import torch
pipe = AudioDiffusionPipeline.from_pretrained("teticio/audio-diffusion-256", torch_dtype=torch.float16)
pipe = pipe.to("cuda")
audio = pipe(batch_size=1, num_inference_steps=50).audios[0]
audio.save("generated_audio.wav")
Getting Started
To get started with Diffusers, follow these steps:
- Install the library:
pip install diffusers transformers accelerate
- Import and use a pre-trained model:
from diffusers import StableDiffusionPipeline
import torch
pipe = StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5", torch_dtype=torch.float16)
pipe = pipe.to("cuda")
prompt = "a beautiful sunset over the ocean"
image = pipe(prompt).images[0]
image.save("sunset.png")
This example loads a pre-trained Stable Diffusion model and generates an image based on the given prompt.
Competitor Comparisons
High-Resolution Image Synthesis with Latent Diffusion Models
Pros of stablediffusion
- More focused on the Stable Diffusion model, providing specialized tools and optimizations
- Offers direct integration with Stability AI's ecosystem and services
- Includes advanced features like textual inversion and custom pipelines
Cons of stablediffusion
- Less versatile compared to diffusers, which supports multiple models and architectures
- May have a steeper learning curve for beginners due to its more specialized nature
- Potentially slower update cycle for new features and models
Code Comparison
stablediffusion:
import torch
from ldm.util import instantiate_from_config
from omegaconf import OmegaConf
config = OmegaConf.load("configs/stable-diffusion/v1-inference.yaml")
model = instantiate_from_config(config.model)
diffusers:
from diffusers import StableDiffusionPipeline
pipeline = StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5")
image = pipeline("A beautiful sunset over the ocean").images[0]
The stablediffusion repository provides lower-level access to the model, while diffusers offers a more user-friendly API with pre-built pipelines. diffusers supports a wider range of models and use cases, making it more versatile for general use, while stablediffusion may be preferred for advanced users focusing specifically on Stable Diffusion.
Stable Diffusion web UI
Pros of stable-diffusion-webui
- User-friendly web interface for easy interaction with Stable Diffusion models
- Extensive features including inpainting, outpainting, and various image processing tools
- Active community with frequent updates and extensions
Cons of stable-diffusion-webui
- Less flexible for integration into custom applications or workflows
- Primarily focused on image generation, with limited support for other diffusion tasks
- Steeper learning curve for developers wanting to modify or extend core functionality
Code Comparison
diffusers:
from diffusers import StableDiffusionPipeline
pipeline = StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5")
image = pipeline("A beautiful sunset over the ocean").images[0]
image.save("sunset.png")
stable-diffusion-webui:
import modules.scripts as scripts
import gradio as gr
class ExampleScript(scripts.Script):
def title(self):
return "Example Script"
def ui(self, is_img2img):
return [gr.Textbox(label="Prompt")]
def run(self, p, prompt):
p.prompt = prompt
return p
Invoke is a leading creative engine for Stable Diffusion models, empowering professionals, artists, and enthusiasts to generate and create visual media using the latest AI-driven technologies. The solution offers an industry leading WebUI, and serves as the foundation for multiple commercial products.
Pros of InvokeAI
- More user-friendly interface with a web UI and CLI options
- Specialized features for image generation, including inpainting and outpainting
- Active community with frequent updates and contributions
Cons of InvokeAI
- Less flexible for general machine learning tasks
- Steeper learning curve for developers new to image generation
- More resource-intensive due to its comprehensive features
Code Comparison
InvokeAI:
from invokeai.app.invocations.baseinvocation import BaseInvocation
class CustomInvocation(BaseInvocation):
def invoke(self, context):
# Custom image generation logic here
Diffusers:
from diffusers import StableDiffusionPipeline
pipeline = StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5")
image = pipeline("A beautiful sunset over the ocean").images[0]
InvokeAI focuses on providing a complete image generation solution with a user-friendly interface, while Diffusers offers a more flexible and modular approach for various diffusion models. InvokeAI is better suited for end-users and artists, whereas Diffusers is more adaptable for researchers and developers working on diverse machine learning projects.
Generative Models by Stability AI
Pros of generative-models
- Focuses specifically on Stability AI's models, offering deeper integration and optimization
- Provides more direct access to cutting-edge generative AI research from Stability AI
- Includes specialized tools and utilities tailored for Stability AI's model architectures
Cons of generative-models
- Less extensive documentation and community support compared to diffusers
- Narrower scope, primarily centered around Stability AI's models rather than a broad range of architectures
- May have a steeper learning curve for users not familiar with Stability AI's specific approaches
Code Comparison
diffusers:
from diffusers import StableDiffusionPipeline
pipeline = StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5")
image = pipeline("A beautiful sunset over the ocean").images[0]
generative-models:
from sgm.inference.api import SamplingPipeline
from sgm.inference.helpers import embed_clip
pipeline = SamplingPipeline.from_pretrained("stabilityai/stable-diffusion-2-1-base")
image = pipeline.text_to_image(embed_clip("A beautiful sunset over the ocean"))
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
ð¤ Diffusers is the go-to library for state-of-the-art pretrained diffusion models for generating images, audio, and even 3D structures of molecules. Whether you're looking for a simple inference solution or training your own diffusion models, ð¤ Diffusers is a modular toolbox that supports both. Our library is designed with a focus on usability over performance, simple over easy, and customizability over abstractions.
ð¤ Diffusers offers three core components:
- State-of-the-art diffusion pipelines that can be run in inference with just a few lines of code.
- Interchangeable noise schedulers for different diffusion speeds and output quality.
- Pretrained models that can be used as building blocks, and combined with schedulers, for creating your own end-to-end diffusion systems.
Installation
We recommend installing ð¤ Diffusers in a virtual environment from PyPI or Conda. For more details about installing PyTorch and Flax, please refer to their official documentation.
PyTorch
With pip
(official package):
pip install --upgrade diffusers[torch]
With conda
(maintained by the community):
conda install -c conda-forge diffusers
Flax
With pip
(official package):
pip install --upgrade diffusers[flax]
Apple Silicon (M1/M2) support
Please refer to the How to use Stable Diffusion in Apple Silicon guide.
Quickstart
Generating outputs is super easy with ð¤ Diffusers. To generate an image from text, use the from_pretrained
method to load any pretrained diffusion model (browse the Hub for 30,000+ checkpoints):
from diffusers import DiffusionPipeline
import torch
pipeline = DiffusionPipeline.from_pretrained("stable-diffusion-v1-5/stable-diffusion-v1-5", torch_dtype=torch.float16)
pipeline.to("cuda")
pipeline("An image of a squirrel in Picasso style").images[0]
You can also dig into the models and schedulers toolbox to build your own diffusion system:
from diffusers import DDPMScheduler, UNet2DModel
from PIL import Image
import torch
scheduler = DDPMScheduler.from_pretrained("google/ddpm-cat-256")
model = UNet2DModel.from_pretrained("google/ddpm-cat-256").to("cuda")
scheduler.set_timesteps(50)
sample_size = model.config.sample_size
noise = torch.randn((1, 3, sample_size, sample_size), device="cuda")
input = noise
for t in scheduler.timesteps:
with torch.no_grad():
noisy_residual = model(input, t).sample
prev_noisy_sample = scheduler.step(noisy_residual, t, input).prev_sample
input = prev_noisy_sample
image = (input / 2 + 0.5).clamp(0, 1)
image = image.cpu().permute(0, 2, 3, 1).numpy()[0]
image = Image.fromarray((image * 255).round().astype("uint8"))
image
Check out the Quickstart to launch your diffusion journey today!
How to navigate the documentation
Documentation | What can I learn? |
---|---|
Tutorial | A basic crash course for learning how to use the library's most important features like using models and schedulers to build your own diffusion system, and training your own diffusion model. |
Loading | Guides for how to load and configure all the components (pipelines, models, and schedulers) of the library, as well as how to use different schedulers. |
Pipelines for inference | Guides for how to use pipelines for different inference tasks, batched generation, controlling generated outputs and randomness, and how to contribute a pipeline to the library. |
Optimization | Guides for how to optimize your diffusion model to run faster and consume less memory. |
Training | Guides for how to train a diffusion model for different tasks with different training techniques. |
Contribution
We â¤ï¸ contributions from the open-source community! If you want to contribute to this library, please check out our Contribution guide. You can look out for issues you'd like to tackle to contribute to the library.
- See Good first issues for general opportunities to contribute
- See New model/pipeline to contribute exciting new diffusion models / diffusion pipelines
- See New scheduler
Also, say ð in our public Discord channel . We discuss the hottest trends about diffusion models, help each other with contributions, personal projects or just hang out â.
Popular Tasks & Pipelines
Task | Pipeline | ð¤ Hub |
---|---|---|
Unconditional Image Generation | DDPM | google/ddpm-ema-church-256 |
Text-to-Image | Stable Diffusion Text-to-Image | stable-diffusion-v1-5/stable-diffusion-v1-5 |
Text-to-Image | unCLIP | kakaobrain/karlo-v1-alpha |
Text-to-Image | DeepFloyd IF | DeepFloyd/IF-I-XL-v1.0 |
Text-to-Image | Kandinsky | kandinsky-community/kandinsky-2-2-decoder |
Text-guided Image-to-Image | ControlNet | lllyasviel/sd-controlnet-canny |
Text-guided Image-to-Image | InstructPix2Pix | timbrooks/instruct-pix2pix |
Text-guided Image-to-Image | Stable Diffusion Image-to-Image | stable-diffusion-v1-5/stable-diffusion-v1-5 |
Text-guided Image Inpainting | Stable Diffusion Inpainting | runwayml/stable-diffusion-inpainting |
Image Variation | Stable Diffusion Image Variation | lambdalabs/sd-image-variations-diffusers |
Super Resolution | Stable Diffusion Upscale | stabilityai/stable-diffusion-x4-upscaler |
Super Resolution | Stable Diffusion Latent Upscale | stabilityai/sd-x2-latent-upscaler |
Popular libraries using 𧨠Diffusers
- https://github.com/microsoft/TaskMatrix
- https://github.com/invoke-ai/InvokeAI
- https://github.com/InstantID/InstantID
- https://github.com/apple/ml-stable-diffusion
- https://github.com/Sanster/lama-cleaner
- https://github.com/IDEA-Research/Grounded-Segment-Anything
- https://github.com/ashawkey/stable-dreamfusion
- https://github.com/deep-floyd/IF
- https://github.com/bentoml/BentoML
- https://github.com/bmaltais/kohya_ss
- +14,000 other amazing GitHub repositories ðª
Thank you for using us â¤ï¸.
Credits
This library concretizes previous work by many different authors and would not have been possible without their great research and implementations. We'd like to thank, in particular, the following implementations which have helped us in our development and without which the API could not have been as polished today:
- @CompVis' latent diffusion models library, available here
- @hojonathanho original DDPM implementation, available here as well as the extremely useful translation into PyTorch by @pesser, available here
- @ermongroup's DDIM implementation, available here
- @yang-song's Score-VE and Score-VP implementations, available here
We also want to thank @heejkoo for the very helpful overview of papers, code and resources on diffusion models, available here as well as @crowsonkb and @rromb for useful discussions and insights.
Citation
@misc{von-platen-etal-2022-diffusers,
author = {Patrick von Platen and Suraj Patil and Anton Lozhkov and Pedro Cuenca and Nathan Lambert and Kashif Rasul and Mishig Davaadorj and Dhruv Nair and Sayak Paul and William Berman and Yiyi Xu and Steven Liu and Thomas Wolf},
title = {Diffusers: State-of-the-art diffusion models},
year = {2022},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/huggingface/diffusers}}
}
Top Related Projects
High-Resolution Image Synthesis with Latent Diffusion Models
Stable Diffusion web UI
Invoke is a leading creative engine for Stable Diffusion models, empowering professionals, artists, and enthusiasts to generate and create visual media using the latest AI-driven technologies. The solution offers an industry leading WebUI, and serves as the foundation for multiple commercial products.
Generative Models by Stability AI
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot