This repo is my work in getting a functional and feature-rich GUI working for Stable Diffusion on the three major desktop OSes — Windows, macOS, and Linux. All the development and testing was done on Apple Silicon macs, but the code does work on Windows and Linux as well. It has been tested under Windows and Linux, but not extensively — if you find bugs, please do let me know and I'll fix them 🙂
The aim of the GUI is to keep things as simple as possible and yet provide as many features as is necessary to get your work done should you do a lot of image generation using Stable Diffusion. The original aim was to keep the Python package requirements as low (and simple) as possible while providing a GUI that works on a Mac, Linux, or Windows. However, the package requirements might change as more functionality is added to the GUI.
Note: All development has been done on an Apple Silicon Mac and this has been optimized for Apple Silicon. It does work on Intel Macs as well but look at the Installation Errors section below for help if things go wrong with the installation. Also, on a 2017 MacBook Pro, it took about 40 minutes to generate a single image if you did the image generation locally! But, you can run the GUI locally and have the image generation happen remotely (on a different machine with a GPU, for example) to get much faster image generation.
macOS | Windows | Linux |
The GUI currently has the following functionality:
-
Generate images via just a text prompt or a text prompt + image (either txt2img or img2img)
-
Remember all the prompts you've used in the past and allows you to manage them via a simple interface
-
Allows you to add modifiers (such as artists, art styles etc.) to your prompts, provides a built-in list of modifiers, and allows you to manage the list of modifiers and modifier categories. You can add as many new modifiers as you want or organize them as you want.
-
You can use the default Standard Diffusion scheduler/sampler or select another scheduler/sampler from the available list.
-
You can specify the size of the image that you want to generate
-
Remembers the last settings (and prompt) you used the next time you run the app
-
Can generate more than one image at a time and allows you to view all generated images in the GUI
-
Saves all generated images and the accompanying prompt info to local storage.
-
Allows you to delete any image and its prompt info from within the GUI itself
-
Shows you the seed for any image so that you can use that seed to generate image variants
-
Allows you to run the GUI locally but run a server elsewhere so that you can connect to the server from the GUI and do image generation on the server — great for when your local machine isn't powerful enough for SD but you still want the convenience of the GUI locally.
-
Shows a log of all console output and errors within the app itself so that you can see what is going on without having to go back to the console to see what happened.
-
Has a built-in basic editor so that you can create basic prompt images or create masks from a generated image for inpainting.
-
Allows you to in/outpaint images from within the image editor interface.
-
Has a built-in image gallery which shows you all images in the app output folder and if the images were generated from within the app, also shows creation and prompt information for those images.
Before you start your installation, you might also want to sign up at Hugging Face since you'll need a Hugging Face user account in order to download the Stable Diffusion models. Do note also that you would need to visit the Hugging Face Stable Diffusion model page and accept their license before you would be able to download the model — you'll need to download the model during the installation.
There's also an Installation Errors section further down in this document. Please refer to that if you run into issues since common issues that others have faced are documented there 🙂
To get set up, you'll need to run the following commands in terminal one at a time. Do note that some of these commands would require you to make decisions and respond to prompts. If you are not comforable with that, this process might not be for you and you might wan to try one of the one-click installers listed here 🙂
For installation instructions for each OS, refer to the relevant OS sub-document below for installation instructions. The sub-documents are a work in progress and will be updated over time as I test fully on each OS:
Once you've complted the installation following the installation instructions above, if you are still at the terminal, simply type the following to launch the UI:
python app.py
If you closed the terminal or want to use the UI at some other point, you'd have to navigate back to where you have this repo (sd-gui
) before you run the above command.
Note: If you are not familiar with conda, do note that every time you close your terminal, your Python environment will revert to the base environment when you next start a terminal session.
The base environment does not have all the packages you installed above since those are in the ml
environment. So you have to switch to that environment (and navigate to the sd-gui
folder) before you can run the GUI again. So you'll need to run something like the following each time you start a new terminal session:
conda activate ml
cd sd-gui
python app.py
Of course, in the above, change the cd sd-gui
to put the actual location of sd-gui
on your hard disk 🙂
You can run the server from a terminal/command-line by simply running the following command:
python server.py
This should result in something like the following as output:
Once the server is running, you can connect to it from another machine using the server's IP and the port number 5000. So, if your server IP address is 192.168.0.11 as in the above screenshot, then run the GUI on your local machine, set the Server to Remote and then enter the IP and port number as follows before you generate an image:
There are tooltips for most UI elements explaining what they do. Just hover your mouse cursor ove a UI element like a button or combobox and a tooltip should appear explaining what that particular item does.
I will add more detailed how-tos for tasks later on once I can find some time 🙂 (Or, if you'd like to contribute, add to the documentation and send me a pull request on GitHub and I'll merge the changes in.)
-
If you get a Homebrew error like this:
homebrew-core is a shallow clone
then run the following command in terminal:git -C /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core fetch --unshallow
-
During the conda install it should prompt you to update your system settings to add the conda installation path to your system path. If you didn't do this, then you would have to manually update your .zshrc or .bashrc to add conda to your path. This StackOverflow question might help. If not, please Google and let me know if you find a good link 🙂
-
If installing the Python packages fails due to conflicting dependencies, use the following commands to create an environment with a known set of package versions. (Since the PyTorch nigthly builds will have fixes for Apple Silicon, if you are on Apple Silicon, the recommended method would be to install the latest night. But if that fails, this should work...) But do this only after you've cloned this repo and have changed your folder into the repo folder.
conda activate base conda env remove -n ml conda env create -f environment.yaml
-
If you get the following error:
The operator 'aten::index.Tensor' is not current implemented for the MPS device. If you want this op to be added in priority during the prototype phase of this feature, please comment on https://github.com/pytorch/pytorch/issues/77764. As a temporary fix, you can set the environment variable `PYTORCH_ENABLE_MPS_FALLBACK=1` to use the CPU as a fallback for this op. WARNING: this will be slower than running natively on MPS.
Then you are not running PyTorch nigthly. You can fix this one of two ways:
-
You can create an environment variable to fix the issue. In terminal, run the following:
export PYTORCH_ENABLE_MPS_FALLBACK=1
-
Update your PyTorch to the latest nightly. Again, in terminal run the following:
conda install pytorch torchvision torchaudio -c pytorch-nightly --force-reinstall
The above should force your PyTorch to be updated to the latest nightly build.
-
-
If you get either of the following errors:
ImportError: cannot import name 'EntryNotFoundError' from 'huggingface_hub.utils'
Or:
ImportError: cannot import name 'StableDiffusionImg2ImgPipeline' from 'diffusers.pipelines'
Then try running the following command from terminal:
pip install diffusers --force-reinstall --no-cache-dir
That should re-install diffusers and fix the issue.
-
You will not see any output in the in-app logging to console at the moment. If everything is working correctly and you do want to see loggin in the app, open the
app.py
file in a text editor and remove the comment from the following line inapp.py
:sys.stdout = sys.stderr = LogStream(queue)
If you do have a crash later, this will disable full crash logging in the console. So if that happens, go back and comment out the line above again and run the code again to get the full crash details so that you can report the crash to me 🙂
-
The latest Pytorch nightly (1.13.0.dev20220930) appears to be much slower in generating images on an Apple Silicon machine than the previous Pytorch nightly that I used (1.13.0.dev20220922). I don't know if this is a permanent situation or something that will get fixed in the future. I tried setting up conda to install using the particular nightly version that is faster (at least for me) but conda could not find that particular build — if you have a solution for that, please let me know. If you do want to switch to the faster Pytorch nightly version, the only way I know of is to run the folloiwng command after you've completed the installation as detailed above:
pip install --pre -r requirements.txt -f https://download.pytorch.org/whl/nightly/torch_nightly.html
-
You get an error message saying: "indices should be either on cpu or on the same device as the indexed tensor (cpu)" Know issue that has been reported to Hugging Face. Read the issue comments to see how it can be fixed by modifying the diffusers source code ...(Fixed in the latest Hugging Face diffusers dev branch. Should be out with diffusers 0.4.0) -
You get an error saying: "Cannot convert a MPS Tensor to float64 dtype as the MPS framework doesn't support float64. Please use float32 instead" Known issue that has been reported to Hugging Face. Read the issue comments to see how it can be fixed by modifying the diffusers source code ...(Appears to have been a PyTorch nightly issue.) -
If you try to generate an image using both an image and a text prompt, you'll get a brown image as the result. This used to work previously but is broken in the diffusers 0.3.0 release. Issue reported.(Appears to have been a PyTorch nightly issue.)
-
A good portion of the drawing/canvas handling code comes from UnstableFusion.
-
Other inspiration for the editor comes from Piecasso
-
The outpainting code/implementation comes from stablediffusion-infinity.