2022-09-09 17:32:33 +02:00
#!/bin/bash
2023-02-14 09:00:02 +01:00
cp sd-ui-files/scripts/functions.sh scripts/
2022-09-09 10:36:37 +02:00
cp sd-ui-files/scripts/on_env_start.sh scripts/
2022-10-22 19:54:13 +02:00
cp sd-ui-files/scripts/bootstrap.sh scripts/
2022-12-24 09:26:05 +01:00
cp sd-ui-files/scripts/check_modules.py scripts/
2022-09-07 16:31:39 +02:00
2023-02-14 09:00:02 +01:00
source ./scripts/functions.sh
2022-10-26 08:45:58 +02:00
# activate the installer env
CONDA_BASEPATH = $( conda info --base)
source " $CONDA_BASEPATH /etc/profile.d/conda.sh " # avoids the 'shell not initialized' error
2022-11-05 18:59:59 +01:00
conda activate || fail "Failed to activate conda"
2022-10-26 08:45:58 +02:00
2022-10-22 19:54:13 +02:00
# remove the old version of the dev console script, if it's still present
2022-10-07 16:22:31 +02:00
if [ -e "open_dev_console.sh" ] ; then
rm "open_dev_console.sh"
fi
2022-10-07 15:20:07 +02:00
2022-11-05 18:59:59 +01:00
python -c "import os; import shutil; frm = 'sd-ui-files/ui/hotfix/9c24e6cd9f499d02c4f21a033736dabd365962dc80fe3aeb57a8f85ea45a20a3.26fead7ea4f0f843f6eb4055dfd25693f1a71f3c6871b184042d4b126244e142'; dst = os.path.join(os.path.expanduser('~'), '.cache', 'huggingface', 'transformers', '9c24e6cd9f499d02c4f21a033736dabd365962dc80fe3aeb57a8f85ea45a20a3.26fead7ea4f0f843f6eb4055dfd25693f1a71f3c6871b184042d4b126244e142'); shutil.copyfile(frm, dst) if os.path.exists(dst) else print(''); print('Hotfixed broken JSON file from OpenAI');"
2022-09-09 21:07:04 +02:00
2022-09-09 17:35:24 +02:00
# Caution, this file will make your eyes and brain bleed. It's such an unholy mess.
# Note to self: Please rewrite this in Python. For the sake of your own sanity.
2022-12-24 09:07:50 +01:00
# set the correct installer path (current vs legacy)
if [ -e "installer_files/env" ] ; then
export INSTALL_ENV_DIR = " $( pwd ) /installer_files/env "
2022-11-25 07:47:44 +01:00
fi
2022-12-24 09:07:50 +01:00
if [ -e "stable-diffusion/env" ] ; then
export INSTALL_ENV_DIR = " $( pwd ) /stable-diffusion/env "
2022-09-02 18:24:32 +02:00
fi
2022-12-24 09:07:50 +01:00
# create the stable-diffusion folder, to work with legacy installations
if [ ! -e "stable-diffusion" ] ; then mkdir stable-diffusion; fi
2022-09-02 18:24:32 +02:00
cd stable-diffusion
2022-12-24 09:07:50 +01:00
# activate the old stable-diffusion env, if it exists
if [ -e "env" ] ; then
2022-11-05 18:59:59 +01:00
conda activate ./env || fail "conda activate failed"
2022-12-24 09:07:50 +01:00
fi
2022-12-24 09:31:33 +01:00
# disable the legacy src and ldm folder (otherwise this prevents installing gfpgan and realesrgan)
if [ -e "src" ] ; then mv src src-old; fi
if [ -e "ldm" ] ; then mv ldm ldm-old; fi
2022-12-28 15:10:08 +01:00
mkdir -p "../models/stable-diffusion"
mkdir -p "../models/gfpgan"
mkdir -p "../models/realesrgan"
mkdir -p "../models/vae"
2022-12-28 14:38:39 +01:00
# migrate the legacy models to the correct path (if already downloaded)
if [ -e "sd-v1-4.ckpt" ] ; then mv sd-v1-4.ckpt ../models/stable-diffusion/; fi
if [ -e "custom-model.ckpt" ] ; then mv custom-model.ckpt ../models/stable-diffusion/; fi
if [ -e "GFPGANv1.3.pth" ] ; then mv GFPGANv1.3.pth ../models/gfpgan/; fi
if [ -e "RealESRGAN_x4plus.pth" ] ; then mv RealESRGAN_x4plus.pth ../models/realesrgan/; fi
if [ -e "RealESRGAN_x4plus_anime_6B.pth" ] ; then mv RealESRGAN_x4plus_anime_6B.pth ../models/realesrgan/; fi
2023-03-17 08:50:37 +01:00
OS_NAME = $( uname -s)
case " ${ OS_NAME } " in
Linux*) OS_NAME = "linux" ; ;
Darwin*) OS_NAME = "macos" ; ;
*) echo " Unknown OS: $OS_NAME ! This script runs only on Linux or Mac " && exit
esac
2022-12-24 09:07:50 +01:00
# install torch and torchvision
if python ../scripts/check_modules.py torch torchvision; then
2023-03-17 09:03:13 +01:00
# temp fix for installations that installed torch 2.0 by mistake
if [ " $OS_NAME " = = "linux" ] ; then
python -m pip install --upgrade torch = = 1.13.1+cu116 torchvision = = 0.14.1+cu116 --extra-index-url https://download.pytorch.org/whl/cu116 -q
elif [ " $OS_NAME " = = "macos" ] ; then
2023-03-17 08:57:44 +01:00
python -m pip install --upgrade torch = = 1.13.1 torchvision = = 0.14.1 -q
fi
2022-12-24 09:07:50 +01:00
echo "torch and torchvision have already been installed."
2022-09-02 18:24:32 +02:00
else
2022-12-24 09:07:50 +01:00
echo "Installing torch and torchvision.."
2022-09-02 18:24:32 +02:00
2022-09-12 13:09:23 +02:00
export PYTHONNOUSERSITE = 1
2022-12-24 09:07:50 +01:00
export PYTHONPATH = " $INSTALL_ENV_DIR /lib/python3.8/site-packages "
2022-09-12 13:09:23 +02:00
2023-03-17 08:50:37 +01:00
if [ " $OS_NAME " = = "linux" ] ; then
if python -m pip install --upgrade torch = = 1.13.1+cu116 torchvision = = 0.14.1+cu116 --extra-index-url https://download.pytorch.org/whl/cu116 ; then
echo "Installed."
else
fail "torch install failed"
fi
elif [ " $OS_NAME " = = "macos" ] ; then
if python -m pip install --upgrade torch = = 1.13.1 torchvision = = 0.14.1 ; then
echo "Installed."
else
fail "torch install failed"
fi
2022-10-25 13:08:08 +02:00
fi
2022-09-06 15:31:21 +02:00
fi
2022-09-02 18:24:32 +02:00
2022-12-24 09:07:50 +01:00
# install/upgrade sdkit
if python ../scripts/check_modules.py sdkit sdkit.models ldm transformers numpy antlr4 gfpgan realesrgan ; then
echo "sdkit is already installed."
2022-09-09 17:35:24 +02:00
2022-12-26 16:30:46 +01:00
# skip sdkit upgrade if in developer-mode
if [ ! -e "../src/sdkit" ] ; then
export PYTHONNOUSERSITE = 1
export PYTHONPATH = " $INSTALL_ENV_DIR /lib/python3.8/site-packages "
2022-09-09 17:35:24 +02:00
2023-03-27 12:59:55 +02:00
python -m pip install --upgrade sdkit = = 1.0.58 -q
2022-12-26 16:30:46 +01:00
fi
2022-09-09 17:35:24 +02:00
else
2022-12-24 09:07:50 +01:00
echo "Installing sdkit: https://pypi.org/project/sdkit/"
2022-09-09 17:35:24 +02:00
2022-09-12 13:09:23 +02:00
export PYTHONNOUSERSITE = 1
2022-12-24 09:07:50 +01:00
export PYTHONPATH = " $INSTALL_ENV_DIR /lib/python3.8/site-packages "
2022-09-12 13:09:23 +02:00
2023-03-27 12:59:55 +02:00
if python -m pip install sdkit = = 1.0.58 ; then
2022-12-24 09:07:50 +01:00
echo "Installed."
else
fail "sdkit install failed"
2022-09-09 17:35:24 +02:00
fi
fi
2022-12-25 12:08:37 +01:00
python -c "from importlib.metadata import version; print('sdkit version:', version('sdkit'))"
2022-12-28 14:49:53 +01:00
# upgrade stable-diffusion-sdkit
2023-03-17 05:30:34 +01:00
python -m pip install --upgrade stable-diffusion-sdkit= = 2.1.4 -q
2022-12-28 14:49:53 +01:00
python -c "from importlib.metadata import version; print('stable-diffusion version:', version('stable-diffusion-sdkit'))"
2022-12-24 10:40:46 +01:00
# install rich
if python ../scripts/check_modules.py rich; then
echo "rich has already been installed."
else
echo "Installing rich.."
export PYTHONNOUSERSITE = 1
export PYTHONPATH = " $INSTALL_ENV_DIR /lib/python3.8/site-packages "
2023-02-07 11:09:02 +01:00
if python -m pip install rich ; then
2022-12-24 10:40:46 +01:00
echo "Installed."
else
fail "Install failed for rich"
fi
fi
2022-12-24 09:07:50 +01:00
if python ../scripts/check_modules.py uvicorn fastapi ; then
2023-02-14 09:00:02 +01:00
echo "Packages necessary for Easy Diffusion were already installed"
2022-09-02 18:24:32 +02:00
else
2023-02-14 09:00:02 +01:00
printf "\n\nDownloading packages necessary for Easy Diffusion..\n\n"
2022-09-02 18:24:32 +02:00
2022-09-12 13:09:23 +02:00
export PYTHONNOUSERSITE = 1
2022-12-24 09:07:50 +01:00
export PYTHONPATH = " $INSTALL_ENV_DIR /lib/python3.8/site-packages "
2022-09-12 13:09:23 +02:00
2022-12-24 09:07:50 +01:00
if conda install -c conda-forge -y uvicorn fastapi ; then
2022-09-06 15:31:21 +02:00
echo "Installed. Testing.."
2022-09-02 18:24:32 +02:00
else
2022-11-05 18:59:59 +01:00
fail "'conda install uvicorn' failed"
2022-09-02 18:24:32 +02:00
fi
2022-09-06 15:31:21 +02:00
if ! command -v uvicorn & > /dev/null; then
2022-11-05 18:59:59 +01:00
fail "UI packages not found!"
2022-09-06 15:31:21 +02:00
fi
2022-11-16 22:34:02 +01:00
fi
2022-12-28 14:38:39 +01:00
if [ -f "../models/stable-diffusion/sd-v1-4.ckpt" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/stable-diffusion/sd-v1-4.ckpt" `
2022-09-06 15:31:21 +02:00
2022-09-12 18:14:16 +02:00
if [ " $model_size " -eq "4265380512" ] || [ " $model_size " -eq "7703807346" ] || [ " $model_size " -eq "7703810927" ] ; then
2022-09-06 15:31:21 +02:00
echo "Data files (weights) necessary for Stable Diffusion were already downloaded"
else
2022-12-28 14:38:39 +01:00
printf " \n\nThe model file present at models/stable-diffusion/sd-v1-4.ckpt is invalid. It is only $model_size bytes in size. Re-downloading.. "
rm ../models/stable-diffusion/sd-v1-4.ckpt
2022-09-06 15:31:21 +02:00
fi
fi
2022-12-28 14:38:39 +01:00
if [ ! -f "../models/stable-diffusion/sd-v1-4.ckpt" ] ; then
2022-09-02 18:24:32 +02:00
echo "Downloading data files (weights) for Stable Diffusion.."
2022-12-28 14:38:39 +01:00
curl -L -k https://huggingface.co/CompVis/stable-diffusion-v-1-4-original/resolve/main/sd-v1-4.ckpt > ../models/stable-diffusion/sd-v1-4.ckpt
2022-09-02 18:24:32 +02:00
2022-12-28 14:38:39 +01:00
if [ -f "../models/stable-diffusion/sd-v1-4.ckpt" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/stable-diffusion/sd-v1-4.ckpt" `
2022-09-12 18:14:16 +02:00
if [ ! " $model_size " = = "4265380512" ] ; then
2022-11-05 18:59:59 +01:00
fail " The downloaded model file was invalid! Bytes downloaded: $model_size "
2022-09-06 15:31:21 +02:00
fi
else
2022-11-05 18:59:59 +01:00
fail "Error downloading the data files (weights) for Stable Diffusion"
2022-09-02 18:24:32 +02:00
fi
2022-09-09 17:35:24 +02:00
fi
2022-12-28 14:38:39 +01:00
if [ -f "../models/gfpgan/GFPGANv1.3.pth" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/gfpgan/GFPGANv1.3.pth" `
2022-09-09 17:35:24 +02:00
if [ " $model_size " -eq "348632874" ] ; then
echo "Data files (weights) necessary for GFPGAN (Face Correction) were already downloaded"
else
2022-12-28 14:38:39 +01:00
printf " \n\nThe model file present at models/gfpgan/GFPGANv1.3.pth is invalid. It is only $model_size bytes in size. Re-downloading.. "
rm ../models/gfpgan/GFPGANv1.3.pth
2022-09-09 17:35:24 +02:00
fi
fi
2022-12-28 14:38:39 +01:00
if [ ! -f "../models/gfpgan/GFPGANv1.3.pth" ] ; then
2022-09-09 17:35:24 +02:00
echo "Downloading data files (weights) for GFPGAN (Face Correction).."
2022-12-28 14:38:39 +01:00
curl -L -k https://github.com/TencentARC/GFPGAN/releases/download/v1.3.0/GFPGANv1.3.pth > ../models/gfpgan/GFPGANv1.3.pth
2022-09-09 17:35:24 +02:00
2022-12-28 14:38:39 +01:00
if [ -f "../models/gfpgan/GFPGANv1.3.pth" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/gfpgan/GFPGANv1.3.pth" `
2022-09-09 17:35:24 +02:00
if [ ! " $model_size " -eq "348632874" ] ; then
2022-11-05 18:59:59 +01:00
fail " The downloaded GFPGAN model file was invalid! Bytes downloaded: $model_size "
2022-09-09 17:35:24 +02:00
fi
else
2022-11-05 18:59:59 +01:00
fail "Error downloading the data files (weights) for GFPGAN (Face Correction)."
2022-09-09 17:35:24 +02:00
fi
fi
2022-12-28 14:38:39 +01:00
if [ -f "../models/realesrgan/RealESRGAN_x4plus.pth" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/realesrgan/RealESRGAN_x4plus.pth" `
2022-09-09 17:35:24 +02:00
if [ " $model_size " -eq "67040989" ] ; then
echo "Data files (weights) necessary for ESRGAN (Resolution Upscaling) x4plus were already downloaded"
else
2022-12-28 14:38:39 +01:00
printf " \n\nThe model file present at models/realesrgan/RealESRGAN_x4plus.pth is invalid. It is only $model_size bytes in size. Re-downloading.. "
rm ../models/realesrgan/RealESRGAN_x4plus.pth
2022-09-09 17:35:24 +02:00
fi
fi
2022-12-28 14:38:39 +01:00
if [ ! -f "../models/realesrgan/RealESRGAN_x4plus.pth" ] ; then
2022-09-09 17:35:24 +02:00
echo "Downloading data files (weights) for ESRGAN (Resolution Upscaling) x4plus.."
2022-12-28 14:38:39 +01:00
curl -L -k https://github.com/xinntao/Real-ESRGAN/releases/download/v0.1.0/RealESRGAN_x4plus.pth > ../models/realesrgan/RealESRGAN_x4plus.pth
2022-09-09 17:35:24 +02:00
2022-12-28 14:38:39 +01:00
if [ -f "../models/realesrgan/RealESRGAN_x4plus.pth" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/realesrgan/RealESRGAN_x4plus.pth" `
2022-09-09 17:35:24 +02:00
if [ ! " $model_size " -eq "67040989" ] ; then
2022-11-05 18:59:59 +01:00
fail " The downloaded ESRGAN x4plus model file was invalid! Bytes downloaded: $model_size "
2022-09-09 17:35:24 +02:00
fi
else
2022-11-05 18:59:59 +01:00
fail "Error downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus"
2022-09-09 17:35:24 +02:00
fi
fi
2022-12-28 14:38:39 +01:00
if [ -f "../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth" `
2022-09-09 17:35:24 +02:00
if [ " $model_size " -eq "17938799" ] ; then
echo "Data files (weights) necessary for ESRGAN (Resolution Upscaling) x4plus_anime were already downloaded"
else
2022-12-28 14:38:39 +01:00
printf " \n\nThe model file present at models/realesrgan/RealESRGAN_x4plus_anime_6B.pth is invalid. It is only $model_size bytes in size. Re-downloading.. "
rm ../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth
2022-09-09 17:35:24 +02:00
fi
fi
2022-12-28 14:38:39 +01:00
if [ ! -f "../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth" ] ; then
2022-09-09 17:35:24 +02:00
echo "Downloading data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime.."
2022-12-28 14:38:39 +01:00
curl -L -k https://github.com/xinntao/Real-ESRGAN/releases/download/v0.2.2.4/RealESRGAN_x4plus_anime_6B.pth > ../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth
2022-09-09 17:35:24 +02:00
2022-12-28 14:38:39 +01:00
if [ -f "../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/realesrgan/RealESRGAN_x4plus_anime_6B.pth" `
2022-09-09 17:35:24 +02:00
if [ ! " $model_size " -eq "17938799" ] ; then
2022-11-05 18:59:59 +01:00
fail " The downloaded ESRGAN x4plus_anime model file was invalid! Bytes downloaded: $model_size "
2022-09-09 17:35:24 +02:00
fi
else
2022-11-05 18:59:59 +01:00
fail "Error downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime."
2022-10-28 16:36:44 +02:00
fi
fi
2022-11-08 12:24:15 +01:00
if [ -f "../models/vae/vae-ft-mse-840000-ema-pruned.ckpt" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/vae/vae-ft-mse-840000-ema-pruned.ckpt" `
2022-10-28 16:36:44 +02:00
if [ " $model_size " -eq "334695179" ] ; then
echo "Data files (weights) necessary for the default VAE (sd-vae-ft-mse-original) were already downloaded"
else
2022-11-08 12:24:15 +01:00
printf " \n\nThe model file present at models/vae/vae-ft-mse-840000-ema-pruned.ckpt is invalid. It is only $model_size bytes in size. Re-downloading.. "
rm ../models/vae/vae-ft-mse-840000-ema-pruned.ckpt
2022-10-28 16:36:44 +02:00
fi
fi
2022-11-08 12:24:15 +01:00
if [ ! -f "../models/vae/vae-ft-mse-840000-ema-pruned.ckpt" ] ; then
2022-10-28 16:36:44 +02:00
echo "Downloading data files (weights) for the default VAE (sd-vae-ft-mse-original).."
2022-11-08 12:24:15 +01:00
curl -L -k https://huggingface.co/stabilityai/sd-vae-ft-mse-original/resolve/main/vae-ft-mse-840000-ema-pruned.ckpt > ../models/vae/vae-ft-mse-840000-ema-pruned.ckpt
2022-10-28 16:36:44 +02:00
2022-11-08 12:24:15 +01:00
if [ -f "../models/vae/vae-ft-mse-840000-ema-pruned.ckpt" ] ; then
2023-02-10 22:34:52 +01:00
model_size = ` filesize "../models/vae/vae-ft-mse-840000-ema-pruned.ckpt" `
2022-10-28 16:36:44 +02:00
if [ ! " $model_size " -eq "334695179" ] ; then
printf " \n\nError: The downloaded default VAE (sd-vae-ft-mse-original) file was invalid! Bytes downloaded: $model_size \n\n "
printf "\n\nError downloading the data files (weights) for the default VAE (sd-vae-ft-mse-original). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/wiki/Troubleshooting\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
read -p "Press any key to continue"
exit
fi
else
printf "\n\nError downloading the data files (weights) for the default VAE (sd-vae-ft-mse-original). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/wiki/Troubleshooting\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
2022-09-09 17:35:24 +02:00
read -p "Press any key to continue"
exit
fi
fi
if [ ` grep -c sd_install_complete ../scripts/install_status.txt` -gt "0" ] ; then
2022-09-02 18:24:32 +02:00
echo sd_weights_downloaded >> ../scripts/install_status.txt
echo sd_install_complete >> ../scripts/install_status.txt
fi
2023-02-14 09:00:02 +01:00
printf "\n\nEasy Diffusion installation complete, starting the server!\n\n"
2022-09-02 18:24:32 +02:00
2022-09-13 07:06:50 +02:00
SD_PATH = ` pwd `
2022-12-24 09:07:50 +01:00
2023-03-07 22:57:37 +01:00
export PYTORCH_ENABLE_MPS_FALLBACK = 1
2022-12-24 09:07:50 +01:00
export PYTHONPATH = " $INSTALL_ENV_DIR /lib/python3.8/site-packages "
2022-09-13 07:06:50 +02:00
echo " PYTHONPATH= $PYTHONPATH "
2022-10-26 12:30:21 +02:00
which python
python --version
2022-09-05 12:00:04 +02:00
cd ..
export SD_UI_PATH = ` pwd ` /ui
cd stable-diffusion
2022-09-02 18:24:32 +02:00
2022-12-24 10:59:49 +01:00
uvicorn main:server_api --app-dir " $SD_UI_PATH " --port ${ SD_UI_BIND_PORT :- 9000 } --host ${ SD_UI_BIND_IP :- 0 .0.0.0 } --log-level error
2022-09-02 18:24:32 +02:00
2022-09-12 13:09:23 +02:00
read -p "Press any key to continue"