[日本語版 README はこちら](README_ja.md) # Stable Diffusion CLI on Modal This is a Diffusers-based script for running Stable Diffusion on [Modal](https://modal.com/). This script has no WebUI and only works with CLI. It can perform txt2img inference and has the ability to increase resolution using ControlNet Tile and Upscaler. ## Features 1. Image generation using txt2img or img2img. ![example for txt2img](assets/20230902_tile_imgs.png) Available versions: - SDXL - 1.5 2. Upscaling | Before upscaling | After upscaling | | ---------------------------------------------------------------- | ---------------------------------------------------------------- | | | | ## Requirements The app requires the following to run: - python: >= 3.11 - modal: >= 0.64.155 - A token for Modal. The `modal` is the Python library. In order to install that: ```bash pip install modal ``` And you need a modal token to use this script: ```bash modal token new ``` Please see [the documentation of Modal](https://modal.com/docs/guide) for modals and tokens. ## Getting Started To use the script, execute the below. 1. git clone the repository. 2. Copy `./app/config.sample.yml` to `./app/config.yml` 3. Open the Makefile and set prompts. 4. Execute `make app` command. An application will be deployed to Modal. 5. Execute `make img_by_sd15_txt2img` command. Images are generated and output to the `outputs/` directory. ## Directory structure ```txt . ├── .env # Secrets manager ├── Makefile ├── README.md ├── cmd/ # A directory with scripts to run inference. │   ├── outputs/ # Images are outputted this directory. ... │   └── txt2img_handler.py # A script to run txt2img inference. └── app/ # A directory with config files. ├── __main__.py # A main script to run inference. ├── Dockerfile # To build a base image. ├── config.yml # To set a model, vae and some tools. ├── requirements.txt ├── setup.py # Build an application to deploy on Modal. ├── stable_diffusion_1_5.py # There is a class to run inference about sd15. └── stable_diffusion_xl.py # There is a class to run inference about sdxl. ``` ## How to use ### 1. `git clone` the repository ```bash git clone https://github.com/hodanov/stable-diffusion-modal.git cd stable-diffusion-modal ``` ### 2. Add hugging_face_token to .env file Add hugging_face_token to .env file. This script downloads and uses a model from HuggingFace, but if you want to use a model in a private repository, you will need to set this environment variable. ```txt HUGGING_FACE_TOKEN="Write your hugging face token here." ``` ### 3. Add the model to ./app/config.yml Add the model used for inference. Use the Safetensors file as is. VAE, LoRA, and Textual Inversion are also configurable. ```yml # ex) version: "sd15" # Specify 'sd15' or 'sdxl'. model: name: stable-diffusion-1-5 url: https://huggingface.co/runwayml/stable-diffusion-v1-5/blob/main/v1-5-pruned.safetensors # Specify URL for the safetensor file. vae: name: sd-vae-ft-mse url: https://huggingface.co/stabilityai/sd-vae-ft-mse-original/blob/main/vae-ft-mse-840000-ema-pruned.safetensors controlnets: - name: control_v11f1e_sd15_tile repo_id: lllyasviel/control_v11f1e_sd15_tile ``` If you want to use LoRA and Textual Inversion, configure as follows. ```yml # Example loras: - name: lora_name.safetensors # Specify the LoRA file name. Any name is fine, but the extension `.safetensors` is required. url: download_link_here # Specify the download link for the safetensor file. ``` If you want to use SDXL: ```yml version: "sdxl" model: name: stable-diffusion-xl url: https://huggingface.co/xxxx/xxxx ``` ### 4. Setting prompts Set the prompt to Makefile. ```makefile # ex) img_by_sdxl_txt2img: cd ./cmd && modal run txt2img_handler.py::main \ --version "sdxl" \ --prompt "A dog is running on the grass" \ --n-prompt "" \ --height 1024 \ --width 1024 \ --samples 1 \ --steps 30 \ --use-upscaler "True" \ --output-format "avif" ``` - prompt: Specifies the prompt. - n-prompt: Specifies a negative prompt. - height: Specifies the height of the image. - width: Specifies the width of the image. - samples: Specifies the number of images to generate. - steps: Specifies the number of steps. - seed: Specifies the seed. - use-upscaler: Enables the upscaler to increase the image resolution. - fix-by-controlnet-tile: Specifies whether to use ControlNet 1.1 Tile. If enabled, it will repair broken images and generate high-resolution images. Only sd15 is supported. - output-format: Specifies the output format. Only avif and png are supported. ### 5. Deploy an application Execute the below command. An application will be deployed on Modal. ```bash make app ``` ### 6. Run inference The txt2img inference is executed with the following command. ```bash make img_by_sd15_txt2img or make img_by_sdxl_txt2img ``` Thank you.