Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
diffusers-rs: A Diffusers API in Rust/Torch
A rusty robot holding a fire torch, generated by stable diffusion using Rust and libtorch.
The diffusers
crate is a Rust equivalent to Huggingface's amazing
diffusers Python library.
It is based on the tch crate.
The implementation is complete enough so as to be able to run Stable Diffusion
v1.4.
In order to run the models, one has to get the weights, see the details below and can then run
the following command. At each step, some sd_*.png
image is generated, the last one sd_30.png
should be the least noisy one.
This requires a GPU with more than 8GB of memory, as a fallback the CPU version can be used but is slower.
The only supported scheduler is the Denoising Diffusion Implicit Model scheduler (DDIM). The original paper and some code can be found in the associated repo.
Examples
A bunch of rusty robots holding some torches!
Getting the Weights and Vocab File
In order to run this, the weights have to be downloaded, converted to the appropriate
format and copied in the top level data
directory. There are three set of weights to
download as well as some vocabulary file for the text model.
If there is some interest in having the final weight files available, open an issue and we could consider packaging them.
First get the vocabulary file and uncompress it.
&&
Clip Encoding Weights
For the clip encoding weights, start by downloading the weight file.
Then using Python, load the weights and save them in a .npz
file.
=
Finally use tensor-tools
from the tch repo to convert
this to a .ot
file that tch can use.
VAE and Unet Weights
The weight files can be downloaded from huggingface's hub but it first requires you to log in (and to accept the terms of use the first time). Then you can download the VAE weights and Unet weights.
After downloading the files, use Python to convert them to npz
files.
=
=
And again convert this to a .ot
file via tensor-tools
.