onnx.mdx 1.71 KB
Newer Older
Nathan Lambert's avatar
Nathan Lambert committed
1
2
3
4
5
6
7
8
9
10
11
12
<!--Copyright 2022 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.
-->

Patrick von Platen's avatar
Patrick von Platen committed
13

14
# How to use the ONNX Runtime for inference
Patrick von Platen's avatar
Patrick von Platen committed
15

16
🤗 Diffusers provides a Stable Diffusion pipeline compatible with the ONNX Runtime. This allows you to run Stable Diffusion on any hardware that supports ONNX (including CPUs), and where an accelerated version of PyTorch is not available.
Patrick von Platen's avatar
Patrick von Platen committed
17

18
## Installation
Patrick von Platen's avatar
Patrick von Platen committed
19

20
- TODO
Patrick von Platen's avatar
Patrick von Platen committed
21

22
## Stable Diffusion Inference
Patrick von Platen's avatar
Patrick von Platen committed
23

24
The snippet below demonstrates how to use the ONNX runtime. You need to use `StableDiffusionOnnxPipeline` instead of `StableDiffusionPipeline`. You also need to download the weights from the `onnx` branch of the repository, and indicate the runtime provider you want to use.
Patrick von Platen's avatar
Patrick von Platen committed
25

26
27
28
```python
# make sure you're logged in with `huggingface-cli login`
from diffusers import StableDiffusionOnnxPipeline
Patrick von Platen's avatar
Patrick von Platen committed
29

30
31
32
33
34
35
36
37
38
39
pipe = StableDiffusionOnnxPipeline.from_pretrained(
    "CompVis/stable-diffusion-v1-4",
    revision="onnx",
    provider="CUDAExecutionProvider",
    use_auth_token=True,
)

prompt = "a photo of an astronaut riding a horse on mars"
image = pipe(prompt).images[0]
```
Patrick von Platen's avatar
Patrick von Platen committed
40

41
## Known Issues
Patrick von Platen's avatar
Patrick von Platen committed
42

43
- Generating multiple prompts in a batch seems to take too much memory. While we look into it, you may need to iterate instead of batching.