mirror of
				https://github.com/AbdBarho/stable-diffusion-webui-docker.git
				synced 2025-10-30 17:53:23 -04:00 
			
		
		
		
	Compare commits
	
		
			13 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 43a5e5e85f | ||
|  | 5bbc21ea3d | ||
|  | 09366ed955 | ||
|  | d4874e7c3a | ||
|  | 7638fb4e5e | ||
|  | 15a61a99d6 | ||
|  | 556a50f49b | ||
|  | b899f4e516 | ||
|  | a8c85b4699 | ||
|  | a96285d10b | ||
|  | 83b78fe504 | ||
|  | 84f9cb84e7 | ||
|  | 6a66ff6abb | 
							
								
								
									
										5
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.github/pull_request_template.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | ### Update versions | ||||||
|  |  | ||||||
|  | - auto: https://github.com/AUTOMATIC1111/stable-diffusion-webui/commit/ | ||||||
|  | - hlky: https://github.com/sd-webui/stable-diffusion-webui/commit/ | ||||||
|  | - lstein: https://github.com/lstein/stable-diffusion/commit/ | ||||||
							
								
								
									
										1
									
								
								.github/workflows/stale.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/stale.yml
									
									
									
									
										vendored
									
									
								
							| @@ -18,3 +18,4 @@ jobs: | |||||||
|           days-before-pr-stale: 14 |           days-before-pr-stale: 14 | ||||||
|           days-before-issue-close: 7 |           days-before-issue-close: 7 | ||||||
|           days-before-pr-close: 7 |           days-before-pr-close: 7 | ||||||
|  |           ignore-updates:  true | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,2 +1,3 @@ | |||||||
| /dev | /dev | ||||||
| /.devcontainer | /.devcontainer | ||||||
|  | embeddings/* | ||||||
							
								
								
									
										7
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -87,3 +87,10 @@ processes, such as predicting an individual will commit fraud/crime | |||||||
| commitment (e.g. by text profiling, drawing causal relationships between | commitment (e.g. by text profiling, drawing causal relationships between | ||||||
| assertions made in documents, indiscriminate and arbitrarily-targeted | assertions made in documents, indiscriminate and arbitrarily-targeted | ||||||
| use). | use). | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | By using this software, you also agree to the following licenses: | ||||||
|  | https://github.com/CompVis/stable-diffusion/blob/main/LICENSE | ||||||
|  | https://github.com/TencentARC/GFPGAN/blob/master/LICENSE | ||||||
|  | https://github.com/xinntao/Real-ESRGAN/blob/master/LICENSE | ||||||
|   | |||||||
| @@ -16,6 +16,7 @@ This repository provides multiple UIs for you to play around with stable diffusi | |||||||
| - Loopback, prompt weighting, prompt matrix, X/Y plot | - Loopback, prompt weighting, prompt matrix, X/Y plot | ||||||
| - Live preview of the generated images. | - Live preview of the generated images. | ||||||
| - Highly optimized 4GB GPU support, or even CPU only! | - Highly optimized 4GB GPU support, or even CPU only! | ||||||
|  | - Textual inversion allows you to use pretrained textual inversion embeddings | ||||||
| - [Full feature list here](https://github.com/AUTOMATIC1111/stable-diffusion-webui-feature-showcase) | - [Full feature list here](https://github.com/AUTOMATIC1111/stable-diffusion-webui-feature-showcase) | ||||||
|  |  | ||||||
| | Text to image                                                                                              | Image to image                                                                                             | Extras                                                                                                     | | | Text to image                                                                                              | Image to image                                                                                             | Extras                                                                                                     | | ||||||
|   | |||||||
| @@ -38,8 +38,9 @@ services: | |||||||
|       - *v1 |       - *v1 | ||||||
|       - *v2 |       - *v2 | ||||||
|       - ./services/AUTOMATIC1111/config.json:/stable-diffusion-webui/config.json |       - ./services/AUTOMATIC1111/config.json:/stable-diffusion-webui/config.json | ||||||
|  |       - ./embeddings:/stable-diffusion-webui/embeddings | ||||||
|     environment: |     environment: | ||||||
|       - CLI_ARGS=--medvram --opt-split-attention |       - CLI_ARGS=--allow-code --medvram | ||||||
|  |  | ||||||
|   automatic1111-cpu: |   automatic1111-cpu: | ||||||
|     <<: *automatic |     <<: *automatic | ||||||
|   | |||||||
| @@ -1,13 +1,19 @@ | |||||||
| # syntax=docker/dockerfile:1 | # syntax=docker/dockerfile:1 | ||||||
|  |  | ||||||
| FROM alpine/git:2.36.2 as download | FROM alpine/git:2.36.2 as download | ||||||
|  |  | ||||||
|  |  | ||||||
|  | RUN git clone https://github.com/CompVis/stable-diffusion.git repositories/stable-diffusion && cd repositories/stable-diffusion && git reset --hard 69ae4b35e0a0f6ee1af8bb9a5d0016ccb27e36dc | ||||||
|  |  | ||||||
|  | RUN git clone https://github.com/sczhou/CodeFormer.git repositories/CodeFormer && cd repositories/CodeFormer && git reset --hard c5b4593074ba6214284d6acd5f1719b6c5d739af | ||||||
|  | RUN git clone https://github.com/salesforce/BLIP.git repositories/BLIP && cd repositories/BLIP && git reset --hard 48211a1594f1321b00f14c9f7a5b4813144b2fb9 | ||||||
|  | RUN git clone https://github.com/Hafiidz/latent-diffusion.git repositories/latent-diffusion && cd repositories/latent-diffusion && git reset --hard abf33e7002d59d9085081bce93ec798dcabd49af | ||||||
|  |  | ||||||
| RUN <<EOF | RUN <<EOF | ||||||
| # because taming-transformers is huge | # because taming-transformers is huge | ||||||
| git config --global http.postBuffer 1048576000 | git config --global http.postBuffer 1048576000 | ||||||
| git clone https://github.com/sczhou/CodeFormer.git repositories/CodeFormer |  | ||||||
| git clone https://github.com/CompVis/stable-diffusion.git repositories/stable-diffusion |  | ||||||
| git clone https://github.com/salesforce/BLIP.git repositories/BLIP |  | ||||||
| git clone https://github.com/CompVis/taming-transformers.git repositories/taming-transformers | git clone https://github.com/CompVis/taming-transformers.git repositories/taming-transformers | ||||||
|  | git reset --hard 24268930bf1dce879235a7fddd0b2355b84d7ea6 | ||||||
| rm -rf repositories/taming-transformers/data repositories/taming-transformers/assets | rm -rf repositories/taming-transformers/data repositories/taming-transformers/assets | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| @@ -27,27 +33,27 @@ RUN apt-get update && apt install fonts-dejavu-core rsync -y && apt-get clean | |||||||
| RUN <<EOF | RUN <<EOF | ||||||
| git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git | git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git | ||||||
| cd stable-diffusion-webui | cd stable-diffusion-webui | ||||||
| git reset --hard 13eec4f3d4081fdc43883c5ef02e471a2b6c7212 | git reset --hard 7e77938230d4fefb6edccdba0b80b61d8416673e | ||||||
| conda env update --file environment-wsl2.yaml -n base |  | ||||||
| conda clean -a -y |  | ||||||
| pip install --prefer-binary --no-cache-dir -r requirements.txt | pip install --prefer-binary --no-cache-dir -r requirements.txt | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| ENV ROOT=/stable-diffusion-webui \ | ENV ROOT=/stable-diffusion-webui \ | ||||||
|   WORKDIR=/stable-diffusion-webui/repositories/stable-diffusion |   WORKDIR=/stable-diffusion-webui/repositories/stable-diffusion | ||||||
|  |  | ||||||
|  |  | ||||||
| COPY --from=download /git/ ${ROOT} | COPY --from=download /git/ ${ROOT} | ||||||
| RUN pip install --prefer-binary --no-cache-dir -r ${ROOT}/repositories/CodeFormer/requirements.txt | RUN pip install --prefer-binary --no-cache-dir -r ${ROOT}/repositories/CodeFormer/requirements.txt | ||||||
|  |  | ||||||
| # Note: don't update the sha of previous versions because the install will take forever | # Note: don't update the sha of previous versions because the install will take forever | ||||||
| # instead, update the repo state in a later step | # instead, update the repo state in a later step | ||||||
|  |  | ||||||
| ARG SHA=99585b3514e2d7e987651d5c6a0806f933af012b | ARG SHA=ca3e5519e8b6dc020c5e7ae508738afb5dc6f3ec | ||||||
| RUN <<EOF | RUN <<EOF | ||||||
| cd stable-diffusion-webui | cd stable-diffusion-webui | ||||||
| git pull --rebase | git pull --rebase | ||||||
| git reset --hard ${SHA} | git reset --hard ${SHA} | ||||||
| pip install --prefer-binary --no-cache-dir -r requirements.txt | pip install --prefer-binary --no-cache-dir -r requirements.txt | ||||||
|  | pip install --prefer-binary --no-cache-dir -r requirements_versions.txt | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| RUN pip install --prefer-binary -U --no-cache-dir opencv-python-headless | RUN pip install --prefer-binary -U --no-cache-dir opencv-python-headless | ||||||
| @@ -55,11 +61,15 @@ RUN pip install --prefer-binary -U --no-cache-dir opencv-python-headless | |||||||
| ENV TRANSFORMERS_CACHE=/cache/transformers TORCH_HOME=/cache/torch CLI_ARGS="" | ENV TRANSFORMERS_CACHE=/cache/transformers TORCH_HOME=/cache/torch CLI_ARGS="" | ||||||
|  |  | ||||||
| COPY . /docker | COPY . /docker | ||||||
| RUN chmod +x /docker/mount.sh && python3 /docker/info.py ${ROOT}/modules/ui.py | RUN <<EOF | ||||||
|  | chmod +x /docker/mount.sh && python3 /docker/info.py ${ROOT}/modules/ui.py | ||||||
|  | # hackiest of hacks, change default cache dir of clip #88 | ||||||
|  | # https://github.com/openai/CLIP/blob/d50d76daa670286dd6cacf3bcd80b5e4823fc8e1/clip/clip.py#L94 | ||||||
|  | sed -i -- 's/download_root: str = None/download_root: str = "\/cache\/weights"/' /opt/conda/lib/python3.8/site-packages/clip/clip.py | ||||||
|  | EOF | ||||||
|  |  | ||||||
| WORKDIR ${WORKDIR} | WORKDIR ${WORKDIR} | ||||||
| EXPOSE 7860 | EXPOSE 7860 | ||||||
| # run, -u to not buffer stdout / stderr | # run, -u to not buffer stdout / stderr | ||||||
| CMD /docker/mount.sh && \ | CMD /docker/mount.sh && \ | ||||||
|   python3 -u ../../webui.py --listen --port 7860 --hide-ui-dir-config --ckpt-dir /cache/custom-models --ckpt /cache/models/model.ckpt ${CLI_ARGS} |   python3 -u ../../webui.py --listen --port 7860 --hide-ui-dir-config --ckpt-dir /cache/custom-models --ckpt /cache/models/model.ckpt --gfpgan-model /cache/models/GFPGANv1.3.pth ${CLI_ARGS} | ||||||
|   | |||||||
| @@ -9,50 +9,71 @@ | |||||||
|   "font": "DejaVuSans.ttf", |   "font": "DejaVuSans.ttf", | ||||||
|   "__WARNING__": "DON'T CHANGE ANYTHING BEFORE THIS", |   "__WARNING__": "DON'T CHANGE ANYTHING BEFORE THIS", | ||||||
|  |  | ||||||
|   "samples_filename_format": "", |  | ||||||
|   "outdir_grids": "", |  | ||||||
|   "save_to_dirs": false, |  | ||||||
|   "grid_save_to_dirs": false, |  | ||||||
|   "save_to_dirs_prompt_len": 10, |  | ||||||
|   "samples_save": true, |  | ||||||
|   "samples_format": "png", |  | ||||||
|   "grid_save": true, |  | ||||||
|   "return_grid": true, |  | ||||||
|   "grid_format": "png", |  | ||||||
|   "grid_extended_filename": false, |  | ||||||
|   "grid_only_if_multiple": true, |  | ||||||
|   "n_rows": -1, |  | ||||||
|   "jpeg_quality": 80, |  | ||||||
|   "export_for_4chan": true, |  | ||||||
|   "enable_pnginfo": true, |  | ||||||
|   "add_model_hash_to_info": false, |   "add_model_hash_to_info": false, | ||||||
|  |   "code_former_weight": 0.5, | ||||||
|  |   "directories_filename_pattern": "", | ||||||
|  |   "directories_max_prompt_words": 8, | ||||||
|  |   "enable_batch_seeds": true, | ||||||
|   "enable_emphasis": true, |   "enable_emphasis": true, | ||||||
|   "save_txt": false, |   "enable_pnginfo": true, | ||||||
|  |   "enable_quantization": false, | ||||||
|   "ESRGAN_tile": 192, |   "ESRGAN_tile": 192, | ||||||
|   "ESRGAN_tile_overlap": 8, |   "ESRGAN_tile_overlap": 8, | ||||||
|   "random_artist_categories": [], |   "export_for_4chan": true, | ||||||
|   "upscale_at_full_resolution_padding": 16, |  | ||||||
|   "show_progressbar": true, |  | ||||||
|   "show_progress_every_n_steps": 7, |  | ||||||
|   "multiple_tqdm": true, |  | ||||||
|   "face_restoration_model": null, |   "face_restoration_model": null, | ||||||
|   "code_former_weight": 0.5, |  | ||||||
|   "save_images_before_face_restoration": false, |  | ||||||
|   "face_restoration_unload": false, |   "face_restoration_unload": false, | ||||||
|   "interrogate_keep_models_in_memory": false, |  | ||||||
|   "interrogate_use_builtin_artists": true, |  | ||||||
|   "interrogate_clip_num_beams": 1, |  | ||||||
|   "interrogate_clip_min_length": 24, |  | ||||||
|   "interrogate_clip_max_length": 48, |  | ||||||
|   "interrogate_clip_dict_limit": 1500.0, |  | ||||||
|   "samples_filename_pattern": "", |  | ||||||
|   "directories_filename_pattern": "", |  | ||||||
|   "save_selected_only": false, |  | ||||||
|   "filter_nsfw": false, |   "filter_nsfw": false, | ||||||
|  |   "grid_extended_filename": false, | ||||||
|  |   "grid_format": "png", | ||||||
|  |   "grid_only_if_multiple": true, | ||||||
|  |   "grid_save": true, | ||||||
|  |   "grid_save_to_dirs": false, | ||||||
|   "img2img_color_correction": false, |   "img2img_color_correction": false, | ||||||
|   "img2img_fix_steps": false, |   "img2img_fix_steps": false, | ||||||
|   "enable_quantization": false, |   "interrogate_clip_dict_limit": 1500, | ||||||
|   "enable_batch_seeds": true, |   "interrogate_clip_max_length": 48, | ||||||
|  |   "interrogate_clip_min_length": 24, | ||||||
|  |   "interrogate_clip_num_beams": 1, | ||||||
|  |   "interrogate_keep_models_in_memory": false, | ||||||
|  |   "interrogate_use_builtin_artists": true, | ||||||
|  |   "jpeg_quality": 80, | ||||||
|  |   "js_modal_lightbox": true, | ||||||
|  |   "js_modal_lightbox_initialy_zoomed": true, | ||||||
|  |   "ldsr_post_down": 1, | ||||||
|  |   "ldsr_pre_down": 1, | ||||||
|  |   "ldsr_steps": 30, | ||||||
|   "memmon_poll_rate": 8, |   "memmon_poll_rate": 8, | ||||||
|   "sd_model_checkpoint": null |   "multiple_tqdm": true, | ||||||
|  |   "n_rows": -1, | ||||||
|  |   "outdir_grids": "", | ||||||
|  |   "random_artist_categories": [], | ||||||
|  |   "realesrgan_enabled_models": [ | ||||||
|  |     "Real-ESRGAN 4x plus", | ||||||
|  |     "Real-ESRGAN 4x plus anime 6B", | ||||||
|  |     "Real-ESRGAN 2x plus", | ||||||
|  |     "Real-ESRGAN AnimeVideo", | ||||||
|  |     "Real-ESRGAN General WDN x4x3", | ||||||
|  |     "Real-ESRGAN General x4x3" | ||||||
|  |   ], | ||||||
|  |   "return_grid": true, | ||||||
|  |   "samples_filename_format": "", | ||||||
|  |   "samples_filename_pattern": "", | ||||||
|  |   "samples_format": "png", | ||||||
|  |   "samples_log_stdout": false, | ||||||
|  |   "samples_save": true, | ||||||
|  |   "save_images_before_color_correction": false, | ||||||
|  |   "save_images_before_face_restoration": false, | ||||||
|  |   "save_selected_only": false, | ||||||
|  |   "save_to_dirs": false, | ||||||
|  |   "save_to_dirs_prompt_len": 10, | ||||||
|  |   "save_txt": false, | ||||||
|  |   "sd_model_checkpoint": null, | ||||||
|  |   "show_progress_every_n_steps": 7, | ||||||
|  |   "show_progressbar": true, | ||||||
|  |   "SWIN_tile": 192, | ||||||
|  |   "SWIN_tile_overlap": 8, | ||||||
|  |   "upscale_at_full_resolution_padding": 16, | ||||||
|  |   "upscaler_for_hires_fix": null, | ||||||
|  |   "upscaler_for_img2img": null, | ||||||
|  |   "use_original_name_batch": false | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,8 +4,9 @@ set -e | |||||||
|  |  | ||||||
| declare -A MODELS | declare -A MODELS | ||||||
|  |  | ||||||
| MODELS["${WORKDIR}/models/ldm/stable-diffusion-v1/model.ckpt"]=model.ckpt |  | ||||||
| MODELS["${ROOT}/GFPGANv1.3.pth"]=GFPGANv1.3.pth | MODELS["${ROOT}/GFPGANv1.3.pth"]=GFPGANv1.3.pth | ||||||
|  | MODELS["${WORKDIR}/repositories/latent-diffusion/experiments/pretrained_models/model.chkpt"]=LDSR.ckpt | ||||||
|  | MODELS["${WORKDIR}/repositories/latent-diffusion/experiments/pretrained_models/project.yaml"]=LDSR.yaml | ||||||
|  |  | ||||||
| MODELS_DIR=/cache/models | MODELS_DIR=/cache/models | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,6 +4,13 @@ set -Eeuo pipefail | |||||||
|  |  | ||||||
| mkdir -p /cache/torch /cache/transformers /cache/weights /cache/models /cache/custom-models | mkdir -p /cache/torch /cache/transformers /cache/weights /cache/models /cache/custom-models | ||||||
|  |  | ||||||
|  | cat <<EOF | ||||||
|  | By using this software, you agree to the following licenses: | ||||||
|  | https://github.com/CompVis/stable-diffusion/blob/main/LICENSE | ||||||
|  | https://github.com/TencentARC/GFPGAN/blob/master/LICENSE | ||||||
|  | https://github.com/xinntao/Real-ESRGAN/blob/master/LICENSE | ||||||
|  | EOF | ||||||
|  |  | ||||||
| echo "Downloading, this might take a while..." | echo "Downloading, this might take a while..." | ||||||
|  |  | ||||||
| aria2c --input-file /docker/links.txt --dir /cache/models --continue | aria2c --input-file /docker/links.txt --dir /cache/models --continue | ||||||
|   | |||||||
| @@ -21,15 +21,11 @@ conda env update --file environment.yaml -n base | |||||||
| conda clean -a -y | conda clean -a -y | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| # new dependency, should be added to the environment.yaml |  | ||||||
| RUN pip install -U --no-cache-dir pyperclip |  | ||||||
|  |  | ||||||
| # Note: don't update the sha of previous versions because the install will take forever | # Note: don't update the sha of previous versions because the install will take forever | ||||||
| # instead, update the repo state in a later step | # instead, update the repo state in a later step | ||||||
| ARG BRANCH=master | # ARG BRANCH=master  SHA=d0bb60a139d60e6c2b9be4e18e0e29a86aa5af59 | ||||||
| ARG SHA=833a91047df999302f699637768741cecee9c37b | ARG BRANCH=dev SHA=1fd28eed1ebc3aa04b9b00e2a899f3bf07f64bdc | ||||||
| # ARG BRANCH=dev |  | ||||||
| # ARG SHA=5f3d7facdea58fc4f89b8c584d22a4639615a2f8 |  | ||||||
| RUN <<EOF | RUN <<EOF | ||||||
| cd stable-diffusion | cd stable-diffusion | ||||||
| git fetch | git fetch | ||||||
| @@ -39,26 +35,16 @@ conda env update --file environment.yaml -n base | |||||||
| conda clean -a -y | conda clean -a -y | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| # Latent diffusion | RUN pip install -U --no-cache-dir pyperclip | ||||||
| RUN <<EOF |  | ||||||
| git clone https://github.com/Hafiidz/latent-diffusion.git |  | ||||||
| cd latent-diffusion |  | ||||||
| git reset --hard e1a84a89fcbb49881546cf2acf1e7e250923dba0 |  | ||||||
| # hacks all the way down |  | ||||||
| mv ldm ldm_latent && |  | ||||||
| sed -i -- 's/from ldm/from ldm_latent/g' *.py |  | ||||||
| # dont forget to update the yaml!! |  | ||||||
| EOF |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # add info | # add info | ||||||
| COPY . /docker/ | COPY . /docker/ | ||||||
| RUN python /docker/info.py /stable-diffusion/frontend/frontend.py && chmod +x /docker/mount.sh | RUN python /docker/info.py /stable-diffusion/frontend/frontend.py && chmod +x /docker/mount.sh | ||||||
|  |  | ||||||
| WORKDIR /stable-diffusion | WORKDIR /stable-diffusion | ||||||
| ENV TRANSFORMERS_CACHE=/cache/transformers TORCH_HOME=/cache/torch CLI_ARGS="" | ENV TRANSFORMERS_CACHE=/cache/transformers TORCH_HOME=/cache/torch PYTHONPATH="${PYTHONPATH}:${PWD}" CLI_ARGS="" | ||||||
| EXPOSE 7860 | EXPOSE 7860 | ||||||
| # run, -u to not buffer stdout / stderr | # run, -u to not buffer stdout / stderr | ||||||
| CMD /docker/mount.sh && \ | CMD /docker/mount.sh && \ | ||||||
|   python3 -u scripts/webui.py --outdir /output --ckpt /cache/models/model.ckpt --ldsr-dir /latent-diffusion --inbrowser ${CLI_ARGS} |   python3 -u scripts/webui.py --outdir /output --ckpt /cache/models/model.ckpt ${CLI_ARGS} | ||||||
| # STREAMLIT_SERVER_PORT=7860 python -m streamlit run scripts/webui_streamlit.py |   # STREAMLIT_SERVER_PORT=7860 python -m streamlit run scripts/webui_streamlit.py  --theme.base dark | ||||||
|   | |||||||
| @@ -9,8 +9,8 @@ ROOT=/stable-diffusion/src | |||||||
| MODELS["${ROOT}/gfpgan/experiments/pretrained_models/GFPGANv1.3.pth"]=GFPGANv1.3.pth | MODELS["${ROOT}/gfpgan/experiments/pretrained_models/GFPGANv1.3.pth"]=GFPGANv1.3.pth | ||||||
| MODELS["${ROOT}/realesrgan/experiments/pretrained_models/RealESRGAN_x4plus.pth"]=RealESRGAN_x4plus.pth | MODELS["${ROOT}/realesrgan/experiments/pretrained_models/RealESRGAN_x4plus.pth"]=RealESRGAN_x4plus.pth | ||||||
| MODELS["${ROOT}/realesrgan/experiments/pretrained_models/RealESRGAN_x4plus_anime_6B.pth"]=RealESRGAN_x4plus_anime_6B.pth | MODELS["${ROOT}/realesrgan/experiments/pretrained_models/RealESRGAN_x4plus_anime_6B.pth"]=RealESRGAN_x4plus_anime_6B.pth | ||||||
| MODELS["/latent-diffusion/experiments/pretrained_models/model.ckpt"]=LDSR.ckpt | MODELS["${ROOT}/latent-diffusion/experiments/pretrained_models/model.ckpt"]=LDSR.ckpt | ||||||
| # MODELS["/latent-diffusion/experiments/pretrained_models/project.yaml"]=LDSR.yaml | MODELS["${ROOT}/latent-diffusion/experiments/pretrained_models/project.yaml"]=LDSR.yaml | ||||||
|  |  | ||||||
| MODELS_DIR=/cache/models | MODELS_DIR=/cache/models | ||||||
|  |  | ||||||
| @@ -25,14 +25,9 @@ for path in "${!MODELS[@]}"; do | |||||||
|   fi |   fi | ||||||
| done | done | ||||||
|  |  | ||||||
| # hack for latent-diffusion |  | ||||||
| if test -f "${MODELS_DIR}/LDSR.yaml"; then |  | ||||||
|   sed 's/ldm\./ldm_latent\./g' "${MODELS_DIR}/LDSR.yaml" >/latent-diffusion/experiments/pretrained_models/project.yaml |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| # force facexlib cache | # force facexlib cache | ||||||
| mkdir -p /cache/weights/ /stable-diffusion/gfpgan/ | mkdir -p /cache/weights/ /stable-diffusion/gfpgan/ | ||||||
| ln -sf /cache/weights/ /stable-diffusion/gfpgan/ | ln -sf /cache/weights/ /stable-diffusion/gfpgan/ | ||||||
|  |  | ||||||
| # streamlit config | # streamlit config | ||||||
| ln -sf /docker/webui_streamlit.yaml /stable-diffusion/configs/webui/webui_streamlit.yaml | ln -sf /docker/userconfig_streamlit.yaml /stable-diffusion/configs/webui/userconfig_streamlit.yaml | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								services/hlky/userconfig_streamlit.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								services/hlky/userconfig_streamlit.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | general: | ||||||
|  |   outdir: /outputs | ||||||
|  |   default_model: "Stable Diffusion v1.4" | ||||||
|  |   default_model_path: /cache/models/model.ckpt | ||||||
|  |   outdir_txt2img: /outputs/txt2img-samples | ||||||
|  |   outdir_img2img: /outputs/img2img-samples | ||||||
|  |   optimized: True | ||||||
|  |   optimized_turbo: True | ||||||
| @@ -1,155 +0,0 @@ | |||||||
| # UI defaults configuration file. It is automatically loaded if located at configs/webui/webui_streamlit.yaml. |  | ||||||
| general: |  | ||||||
|   gpu: 0 |  | ||||||
|   outdir: /outputs |  | ||||||
|  |  | ||||||
|   default_model: "Stable Diffusion v1.4" |  | ||||||
|   default_model_config: "configs/stable-diffusion/v1-inference.yaml" |  | ||||||
|   default_model_path: "/cache/models/model.ckpt" |  | ||||||
|   fp: |  | ||||||
|     name: |  | ||||||
|   GFPGAN_dir: "./src/gfpgan" |  | ||||||
|   RealESRGAN_dir: "./src/realesrgan" |  | ||||||
|   RealESRGAN_model: "RealESRGAN_x4plus" |  | ||||||
|   outdir_txt2img: /outputs/txt2img-samples |  | ||||||
|   outdir_img2img: /outputs/img2img-samples |  | ||||||
|   gfpgan_cpu: False |  | ||||||
|   esrgan_cpu: False |  | ||||||
|   extra_models_cpu: False |  | ||||||
|   extra_models_gpu: False |  | ||||||
|   save_metadata: True |  | ||||||
|   save_format: "png" |  | ||||||
|   skip_grid: False |  | ||||||
|   skip_save: False |  | ||||||
|   grid_format: "jpg:95" |  | ||||||
|   n_rows: -1 |  | ||||||
|   no_verify_input: False |  | ||||||
|   no_half: False |  | ||||||
|   use_float16: False |  | ||||||
|   precision: "autocast" |  | ||||||
|   optimized: False |  | ||||||
|   optimized_turbo: True |  | ||||||
|   optimized_config: "optimizedSD/v1-inference.yaml" |  | ||||||
|   update_preview: True |  | ||||||
|   update_preview_frequency: 5 |  | ||||||
|  |  | ||||||
| txt2img: |  | ||||||
|   prompt: |  | ||||||
|   height: 512 |  | ||||||
|   width: 512 |  | ||||||
|   cfg_scale: 7.5 |  | ||||||
|   seed: "" |  | ||||||
|   batch_count: 1 |  | ||||||
|   batch_size: 1 |  | ||||||
|   sampling_steps: 30 |  | ||||||
|   default_sampler: "k_euler" |  | ||||||
|   separate_prompts: False |  | ||||||
|   update_preview: True |  | ||||||
|   update_preview_frequency: 5 |  | ||||||
|   normalize_prompt_weights: True |  | ||||||
|   save_individual_images: True |  | ||||||
|   save_grid: True |  | ||||||
|   group_by_prompt: True |  | ||||||
|   save_as_jpg: False |  | ||||||
|   use_GFPGAN: False |  | ||||||
|   use_RealESRGAN: False |  | ||||||
|   RealESRGAN_model: "RealESRGAN_x4plus" |  | ||||||
|   variant_amount: 0.0 |  | ||||||
|   variant_seed: "" |  | ||||||
|   write_info_files: True |  | ||||||
|  |  | ||||||
| txt2vid: |  | ||||||
|   default_model: "CompVis/stable-diffusion-v1-4" |  | ||||||
|   custom_models_list: |  | ||||||
|     [ |  | ||||||
|       "CompVis/stable-diffusion-v1-4", |  | ||||||
|       "naclbit/trinart_stable_diffusion_v2", |  | ||||||
|       "hakurei/waifu-diffusion", |  | ||||||
|       "osanseviero/BigGAN-deep-128", |  | ||||||
|     ] |  | ||||||
|   prompt: |  | ||||||
|   height: 512 |  | ||||||
|   width: 512 |  | ||||||
|   cfg_scale: 7.5 |  | ||||||
|   seed: "" |  | ||||||
|   batch_count: 1 |  | ||||||
|   batch_size: 1 |  | ||||||
|   sampling_steps: 30 |  | ||||||
|   num_inference_steps: 200 |  | ||||||
|   default_sampler: "k_euler" |  | ||||||
|   scheduler_name: "klms" |  | ||||||
|   separate_prompts: False |  | ||||||
|   update_preview: True |  | ||||||
|   update_preview_frequency: 5 |  | ||||||
|   dynamic_preview_frequency: True |  | ||||||
|   normalize_prompt_weights: True |  | ||||||
|   save_individual_images: True |  | ||||||
|   save_video: True |  | ||||||
|   group_by_prompt: True |  | ||||||
|   write_info_files: True |  | ||||||
|   do_loop: False |  | ||||||
|   save_as_jpg: False |  | ||||||
|   use_GFPGAN: False |  | ||||||
|   use_RealESRGAN: False |  | ||||||
|   RealESRGAN_model: "RealESRGAN_x4plus" |  | ||||||
|   variant_amount: 0.0 |  | ||||||
|   variant_seed: "" |  | ||||||
|   beta_start: 0.00085 |  | ||||||
|   beta_end: 0.012 |  | ||||||
|   beta_scheduler_type: "linear" |  | ||||||
|   max_frames: 1000 |  | ||||||
|  |  | ||||||
| img2img: |  | ||||||
|   prompt: |  | ||||||
|   sampling_steps: 30 |  | ||||||
|   # Adding an int to toggles enables the corresponding feature. |  | ||||||
|   # 0: Create prompt matrix (separate multiple prompts using |, and get all combinations of them) |  | ||||||
|   # 1: Normalize Prompt Weights (ensure sum of weights add up to 1.0) |  | ||||||
|   # 2: Loopback (use images from previous batch when creating next batch) |  | ||||||
|   # 3: Random loopback seed |  | ||||||
|   # 4: Save individual images |  | ||||||
|   # 5: Save grid |  | ||||||
|   # 6: Sort samples by prompt |  | ||||||
|   # 7: Write sample info files |  | ||||||
|   # 8: jpg samples |  | ||||||
|   # 9: Fix faces using GFPGAN |  | ||||||
|   # 10: Upscale images using Real-ESRGAN |  | ||||||
|   sampler_name: "k_euler" |  | ||||||
|   denoising_strength: 0.45 |  | ||||||
|   # 0: Keep masked area |  | ||||||
|   # 1: Regenerate only masked area |  | ||||||
|   mask_mode: 0 |  | ||||||
|   mask_restore: False |  | ||||||
|   # 0: Just resize |  | ||||||
|   # 1: Crop and resize |  | ||||||
|   # 2: Resize and fill |  | ||||||
|   resize_mode: 0 |  | ||||||
|   # Leave blank for random seed: |  | ||||||
|   seed: "" |  | ||||||
|   ddim_eta: 0.0 |  | ||||||
|   cfg_scale: 7.5 |  | ||||||
|   batch_count: 1 |  | ||||||
|   batch_size: 1 |  | ||||||
|   height: 512 |  | ||||||
|   width: 512 |  | ||||||
|   # Textual inversion embeddings file path: |  | ||||||
|   fp: "" |  | ||||||
|   loopback: True |  | ||||||
|   random_seed_loopback: True |  | ||||||
|   separate_prompts: False |  | ||||||
|   update_preview: True |  | ||||||
|   update_preview_frequency: 5 |  | ||||||
|   normalize_prompt_weights: True |  | ||||||
|   save_individual_images: True |  | ||||||
|   save_grid: True |  | ||||||
|   group_by_prompt: True |  | ||||||
|   save_as_jpg: False |  | ||||||
|   use_GFPGAN: False |  | ||||||
|   use_RealESRGAN: False |  | ||||||
|   RealESRGAN_model: "RealESRGAN_x4plus" |  | ||||||
|   variant_amount: 0.0 |  | ||||||
|   variant_seed: "" |  | ||||||
|   write_info_files: True |  | ||||||
|  |  | ||||||
| gfpgan: |  | ||||||
|   strength: 100 |  | ||||||
| @@ -6,39 +6,51 @@ SHELL ["/bin/bash", "-ceuxo", "pipefail"] | |||||||
|  |  | ||||||
| ENV DEBIAN_FRONTEND=noninteractive | ENV DEBIAN_FRONTEND=noninteractive | ||||||
|  |  | ||||||
| RUN conda install python=3.8.5 && conda clean -a -y | # now it requires python3.9 | ||||||
|  | RUN conda install python=3.9 && conda clean -a -y | ||||||
| RUN conda install pytorch==1.11.0 torchvision==0.12.0 cudatoolkit=11.3 -c pytorch && conda clean -a -y | RUN conda install pytorch==1.11.0 torchvision==0.12.0 cudatoolkit=11.3 -c pytorch && conda clean -a -y | ||||||
|  |  | ||||||
| RUN apt-get update && apt install fonts-dejavu-core rsync gcc -y && apt-get clean | RUN apt-get update && apt install fonts-dejavu-core rsync gcc -y && apt-get clean | ||||||
|  |  | ||||||
|  |  | ||||||
| RUN <<EOF | RUN <<EOF | ||||||
| git clone https://github.com/lstein/stable-diffusion.git | git clone https://github.com/invoke-ai/InvokeAI.git stable-diffusion | ||||||
| cd stable-diffusion | cd stable-diffusion | ||||||
| git reset --hard 751283a2de81bee4bb571fbabe4adb19f1d85b97 | git reset --hard a1739a73b48bfe98b6abcb67f5a0197a9ad270e0 | ||||||
|  | sed -i -- 's/python=3.8.5/python=3.9/g' environment.yaml | ||||||
| conda env update --file environment.yaml -n base | conda env update --file environment.yaml -n base | ||||||
| conda clean -a -y | conda clean -a -y | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
|  |  | ||||||
| ARG BRANCH=development SHA=45af30f3a4c98b50c755717831c5fff75a3a8b43 | ARG BRANCH=development SHA=b40bfb5116b7fc618f78a0d152005ceb46153443 | ||||||
| # ARG BRANCH=main SHA=89da371f4841f7e05da5a1672459d700c3920784 | # this breaks on generation: | ||||||
|  | # there is a new UI anyway, but it is not by any means ready. | ||||||
|  | # ARG BRANCH=development SHA=bdbc76fcd4bd3362312dc91b087d9af66de423b1 | ||||||
| RUN <<EOF | RUN <<EOF | ||||||
| cd stable-diffusion | cd stable-diffusion | ||||||
| git fetch | git fetch | ||||||
|  | git reset --hard | ||||||
| git checkout ${BRANCH} | git checkout ${BRANCH} | ||||||
| git reset --hard ${SHA} | git reset --hard ${SHA} | ||||||
| conda env update --file environment.yaml -n base | conda env update --file environment.yaml -n base | ||||||
| conda clean -a -y | conda clean -a -y | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| RUN pip uninstall opencv-python -y && pip install --prefer-binary --upgrade --force-reinstall --no-cache-dir opencv-python-headless | RUN pip uninstall opencv-python -y && pip install --prefer-binary --force-reinstall --no-cache-dir opencv-python-headless transformers==4.19.2 | ||||||
|  |  | ||||||
| COPY . /docker/ | COPY . /docker/ | ||||||
| RUN python3 /docker/info.py /stable-diffusion/static/dream_web/index.html && chmod +x /docker/mount.sh | RUN <<EOF | ||||||
|  | python3 /docker/info.py /stable-diffusion/static/dream_web/index.html | ||||||
|  | chmod +x /docker/mount.sh | ||||||
|  | sed -i -- 's/outputs\//\/output/g' /stable-diffusion/backend/server.py | ||||||
|  | EOF | ||||||
|  |  | ||||||
|  |  | ||||||
| ENV TRANSFORMERS_CACHE=/cache/transformers TORCH_HOME=/cache/torch PRELOAD=false CLI_ARGS="" | ENV TRANSFORMERS_CACHE=/cache/transformers TORCH_HOME=/cache/torch PRELOAD=false CLI_ARGS="" | ||||||
| WORKDIR /stable-diffusion | WORKDIR /stable-diffusion | ||||||
| EXPOSE 7860 | EXPOSE 7860 | ||||||
|  |  | ||||||
| CMD /docker/mount.sh && python3 -u scripts/dream.py --outdir /output --web --host 0.0.0.0 --port 7860 ${CLI_ARGS} | CMD /docker/mount.sh && \ | ||||||
|  |   python3 -u scripts/dream.py --outdir /output --web --host 0.0.0.0 --port 7860 ${CLI_ARGS} | ||||||
|  | # python3 -u backend/server.py --host 0.0.0.0 --port 9090 | ||||||
|   | |||||||
| @@ -7,20 +7,23 @@ ROOT=/stable-diffusion | |||||||
| mkdir -p "${ROOT}/models/ldm/stable-diffusion-v1/" | mkdir -p "${ROOT}/models/ldm/stable-diffusion-v1/" | ||||||
| ln -sf /cache/models/model.ckpt "${ROOT}/models/ldm/stable-diffusion-v1/model.ckpt" | ln -sf /cache/models/model.ckpt "${ROOT}/models/ldm/stable-diffusion-v1/model.ckpt" | ||||||
|  |  | ||||||
| if test -f /cache/models/GFPGANv1.3.pth; then | base="${ROOT}/src/gfpgan/experiments/pretrained_models/" | ||||||
|   base="${ROOT}/src/gfpgan/experiments/pretrained_models/" | mkdir -p "${base}" | ||||||
|   mkdir -p "${base}" | # TODO: "real" GFPGANv1.4.pth | ||||||
|   ln -sf /cache/models/GFPGANv1.3.pth "${base}/GFPGANv1.3.pth" | ln -sf /cache/models/GFPGANv1.3.pth "${base}/GFPGANv1.4.pth" | ||||||
|   echo "Mounted GFPGANv1.3.pth" | echo "Mounted GFPGANv1.3.pth" | ||||||
| fi |  | ||||||
|  |  | ||||||
| # facexlib | # facexlib | ||||||
| FACEX_WEIGHTS=/opt/conda/lib/python3.8/site-packages/facexlib/weights | FACEX_WEIGHTS=/opt/conda/lib/python3.9/site-packages/facexlib/weights | ||||||
|  |  | ||||||
| rm -rf "${FACEX_WEIGHTS}" | rm -rf "${FACEX_WEIGHTS}" | ||||||
| mkdir -p /cache/weights | mkdir -p /cache/weights | ||||||
| ln -sf -T /cache/weights "${FACEX_WEIGHTS}" | ln -sf -T /cache/weights "${FACEX_WEIGHTS}" | ||||||
|  |  | ||||||
|  | REALESRGAN_WEIGHTS=/opt/conda/lib/python3.9/site-packages/realesrgan/weights | ||||||
|  | rm -rf "${REALESRGAN_WEIGHTS}" | ||||||
|  | ln -sf -T /cache/weights "${REALESRGAN_WEIGHTS}" | ||||||
|  |  | ||||||
| if "${PRELOAD}" == "true"; then | if "${PRELOAD}" == "true"; then | ||||||
|   python3 -u scripts/preload_models.py |   python3 -u scripts/preload_models.py | ||||||
| fi | fi | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user