| | --- |
| | license: apache-2.0 |
| | --- |
| | |
| | [Optimum Habana](https://github.com/huggingface/optimum-habana) is the interface between the Hugging Face Transformers and Diffusers libraries and Habana's Gaudi processor (HPU). |
| | It provides a set of tools enabling easy and fast model loading, training and inference on single- and multi-HPU settings for different downstream tasks. |
| | Learn more about how to take advantage of the power of Habana HPUs to train and deploy Transformers and Diffusers models at [hf.co/hardware/habana](https://huggingface.co/hardware/habana). |
| |
|
| | ## Stable Diffusion HPU configuration |
| |
|
| | This model only contains the `GaudiConfig` file for running **Stable Diffusion v2** (e.g. [stabilityai/stable-diffusion-2-1](https://huggingface.co/stabilityai/stable-diffusion-2-1)) on Habana's Gaudi processors (HPU). |
| |
|
| | **This model contains no model weights, only a GaudiConfig.** |
| |
|
| | This enables to specify: |
| | - `use_torch_autocast`: whether to use Torch Autocast for mixed precision |
| | - `hmp_bf16_ops`: list of operators that should run in bf16 |
| | - `hmp_fp32_ops`: list of operators that should run in fp32 |
| |
|
| | ## Usage |
| |
|
| | The `GaudiStableDiffusionPipeline` (`GaudiDDIMScheduler`) is instantiated the same way as the `StableDiffusionPipeline` (`DDIMScheduler`) in the 🤗 Diffusers library. |
| | The only difference is that there are a few new training arguments specific to HPUs. |
| |
|
| | Here is an example with one prompt: |
| | ```python |
| | from optimum.habana import GaudiConfig |
| | from optimum.habana.diffusers import GaudiDDIMScheduler, GaudiStableDiffusionPipeline |
| | |
| | |
| | model_name = "stabilityai/stable-diffusion-2-1" |
| | |
| | scheduler = GaudiDDIMScheduler.from_pretrained(model_name, subfolder="scheduler") |
| | |
| | pipeline = GaudiStableDiffusionPipeline.from_pretrained( |
| | model_name, |
| | height=768, |
| | width=768, |
| | scheduler=scheduler, |
| | use_habana=True, |
| | use_hpu_graphs=True, |
| | gaudi_config="Habana/stable-diffusion-2", |
| | ) |
| | |
| | outputs = pipeline( |
| | ["An image of a squirrel in Picasso style"], |
| | num_images_per_prompt=6, |
| | batch_size=2, |
| | ) |
| | ``` |
| |
|
| | Check out the [documentation](https://huggingface.co/docs/optimum/habana/usage_guides/stable_diffusion) and [this example](https://github.com/huggingface/optimum-habana/tree/main/examples/stable-diffusion) for more advanced usage. |
| |
|