Compare commits

..

14 Commits

Author SHA1 Message Date
bmaltais
9c8c480f8e
Merge pull request #527 from bmaltais/dev
v21.4.2
2023-04-02 19:12:32 -04:00
bmaltais
adad3272dc Update readme 2023-04-02 19:12:09 -04:00
bmaltais
0fd5fbc0f8 Merge branch 'dev' of https://github.com/bmaltais/kohya_ss into dev 2023-04-02 19:09:25 -04:00
bmaltais
12010c2c9c Update readme 2023-04-02 19:09:20 -04:00
bmaltais
affce575a0
Merge pull request #524 from jstayco/macOS_x86_detection
macOS arm64 vs x86 detection
2023-04-02 19:08:24 -04:00
JSTayco
6b5b131775 Tiny README typo fix 2023-04-02 12:42:04 -07:00
JSTayco
a59fdbcd59 Typo fixes
Makes the SAST happy.
2023-04-02 12:35:47 -07:00
JSTayco
f32ce0aead Removed tensorflow from requirements.txt for macOS
Added CPU architecture detection for packages
2023-04-02 12:32:56 -07:00
bmaltais
720dcd76df
Merge pull request #518 from bmaltais/dev
Fix .gitignore
2023-04-01 22:23:35 -04:00
bmaltais
37137fae32 Fix .gitignore 2023-04-01 22:22:55 -04:00
bmaltais
6c5773b0e4
Merge pull request #517 from bmaltais/dev
Fix type for linux install
2023-04-01 22:21:17 -04:00
bmaltais
5fa8a58a1a
Merge pull request #516 from jstayco/linux_dl_fix
Typo fix preventing Linux pip install
2023-04-01 22:20:39 -04:00
JSTayco
1875bccab8 Typo fix preventing Linux pip install 2023-04-01 18:51:24 -07:00
bmaltais
1e645deebe
Merge pull request #512 from bmaltais/dev
v21.4.0
2023-04-01 16:52:37 -04:00
5 changed files with 44 additions and 19 deletions

1
.gitignore vendored
View File

@ -9,4 +9,3 @@ wd14_tagger_model
locon locon
gui-user.bat gui-user.bat
gui-user.ps1 gui-user.ps1
library/__init__.py

View File

@ -253,10 +253,15 @@ pip freeze > uninstall.txt
pip uninstall -r uninstall.txt pip uninstall -r uninstall.txt
``` ```
This will store your a backup file with your current locally installed pip packages and then uninstall them. Then, redo the installation instructions within the kohya_ss venv. This will store a backup file with your current locally installed pip packages and then uninstall them. Then, redo the installation instructions within the kohya_ss venv.
## Change History ## Change History
* 2024/04/02 (v21.4.2)
- removes TensorFlow from requirements.txt for Darwin platforms as pip does not support advanced conditionals like CPU architecture. The logic is now defined in setup.sh to avoid version bump headaches, and the selection logic is in the pre-existing pip function. Additionally, the release includes the addition of the tensorflow-metal package for M1+ Macs, which enables GPU acceleration per Apple's documentation. Thanks @jstayco
* 2023/04/01 (v21.4.1)
- Fix type for linux install by @bmaltais in https://github.com/bmaltais/kohya_ss/pull/517
- Fix .gitignore by @bmaltais in https://github.com/bmaltais/kohya_ss/pull/518
* 2024/04/01 (v21.4.0) * 2024/04/01 (v21.4.0)
- Improved linux and macos installation and updates script. See README for more details. Many thanks to @jstayco and @Galunid for the great PR! - Improved linux and macos installation and updates script. See README for more details. Many thanks to @jstayco and @Galunid for the great PR!
- Fix issue with "missing library" error. - Fix issue with "missing library" error.
@ -275,7 +280,7 @@ This will store your a backup file with your current locally installed pip packa
- Fix an issue that images are loaded twice in Windows environment. - Fix an issue that images are loaded twice in Windows environment.
- Add Min-SNR Weighting strategy. Details are in [#308](https://github.com/kohya-ss/sd-scripts/pull/308). Thank you to AI-Casanova for this great work! - Add Min-SNR Weighting strategy. Details are in [#308](https://github.com/kohya-ss/sd-scripts/pull/308). Thank you to AI-Casanova for this great work!
- Add `--min_snr_gamma` option to training scripts, 5 is recommended by paper. - Add `--min_snr_gamma` option to training scripts, 5 is recommended by paper.
- The Min SNR gamma fiels can be found unser the advanced training tab in all trainers. - The Min SNR gamma fields can be found under the advanced training tab in all trainers.
- Fixed the error while images are ended with capital image extensions. Thanks to @kvzn. https://github.com/bmaltais/kohya_ss/pull/454 - Fixed the error while images are ended with capital image extensions. Thanks to @kvzn. https://github.com/bmaltais/kohya_ss/pull/454
* 2023/03/26 (v21.3.5) * 2023/03/26 (v21.3.5)
- Fix for https://github.com/bmaltais/kohya_ss/issues/230 - Fix for https://github.com/bmaltais/kohya_ss/issues/230
@ -283,11 +288,11 @@ This will store your a backup file with your current locally installed pip packa
* 2023/03/25 (v21.3.4) * 2023/03/25 (v21.3.4)
- Added untested support for MacOS base on this gist: https://gist.github.com/jstayco/9f5733f05b9dc29de95c4056a023d645 - Added untested support for MacOS base on this gist: https://gist.github.com/jstayco/9f5733f05b9dc29de95c4056a023d645
Let me know how this work. From the look of it it appear to be well tought out. I modified a few things to make it fit better with the rest of the code in the repo. Let me know how this work. From the look of it it appear to be well thought out. I modified a few things to make it fit better with the rest of the code in the repo.
- Fix for issue https://github.com/bmaltais/kohya_ss/issues/433 by implementing default of 0. - Fix for issue https://github.com/bmaltais/kohya_ss/issues/433 by implementing default of 0.
- Removed non applicable save_model_as choices for LoRA and TI. - Removed non applicable save_model_as choices for LoRA and TI.
* 2023/03/24 (v21.3.3) * 2023/03/24 (v21.3.3)
- Add support for custom user gui files. THey will be created at installation time or when upgrading is missing. You will see two files in the root of the folder. One named `gui-user.bat` and the other `gui-user.ps1`. Edit the file based on your prefered terminal. Simply add the parameters you want to pass the gui in there and execute it to start the gui with them. Enjoy! - Add support for custom user gui files. THey will be created at installation time or when upgrading is missing. You will see two files in the root of the folder. One named `gui-user.bat` and the other `gui-user.ps1`. Edit the file based on your preferred terminal. Simply add the parameters you want to pass the gui in there and execute it to start the gui with them. Enjoy!
* 2023/03/23 (v21.3.2) * 2023/03/23 (v21.3.2)
- Fix issue reported: https://github.com/bmaltais/kohya_ss/issues/439 - Fix issue reported: https://github.com/bmaltais/kohya_ss/issues/439
* 2023/03/23 (v21.3.1) * 2023/03/23 (v21.3.1)

0
library/__init__.py Normal file
View File

View File

@ -27,7 +27,6 @@ timm==0.6.12
huggingface-hub==0.12.0; sys_platform != 'darwin' huggingface-hub==0.12.0; sys_platform != 'darwin'
huggingface-hub==0.13.0; sys_platform == 'darwin' huggingface-hub==0.13.0; sys_platform == 'darwin'
tensorflow==2.10.1; sys_platform != 'darwin' tensorflow==2.10.1; sys_platform != 'darwin'
tensorflow-macos==2.12.0; sys_platform == 'darwin'
# For locon support # For locon support
lycoris-lora @ git+https://github.com/KohakuBlueleaf/LyCORIS.git@c3d925421209a22a60d863ffa3de0b3e7e89f047 lycoris-lora @ git+https://github.com/KohakuBlueleaf/LyCORIS.git@c3d925421209a22a60d863ffa3de0b3e7e89f047
# lycoris_lora==0.1.4 # lycoris_lora==0.1.4

View File

@ -2,6 +2,12 @@
# This file will be the host environment setup file for all operating systems other than base Windows. # This file will be the host environment setup file for all operating systems other than base Windows.
# Set the required package versions here.
# They will be appended to the requirements.txt file in the installation directory.
TENSORFLOW_VERSION="2.12.0"
TENSORFLOW_MACOS_VERSION="2.12.0"
TENSORFLOW_METAL_VERSION="0.8.0"
display_help() { display_help() {
cat <<EOF cat <<EOF
Kohya_SS Installation Script for POSIX operating systems. Kohya_SS Installation Script for POSIX operating systems.
@ -232,7 +238,7 @@ install_python_dependencies() {
"linux-gnu"*) pip install torch==1.12.1+cu116 torchvision==0.13.1+cu116 \ "linux-gnu"*) pip install torch==1.12.1+cu116 torchvision==0.13.1+cu116 \
--extra-index-url https://download.pytorch.org/whl/cu116 >&3 && --extra-index-url https://download.pytorch.org/whl/cu116 >&3 &&
pip install -U -I --no-deps \ pip install -U -I --no-deps \
https://github.com/C43H66N12O12S2/stable-diffusion-webui/releases/downloadlinux/xformers-0.0.14.dev0-cp310-cp310-linux_x86_64.whl >&3 ;; https://github.com/C43H66N12O12S2/stable-diffusion-webui/releases/download/linux/xformers-0.0.14.dev0-cp310-cp310-linux_x86_64.whl >&3 ;;
"darwin"*) pip install torch==2.0.0 torchvision==0.15.1 \ "darwin"*) pip install torch==2.0.0 torchvision==0.15.1 \
-f https://download.pytorch.org/whl/cpu/torch_stable.html >&3 ;; -f https://download.pytorch.org/whl/cpu/torch_stable.html >&3 ;;
"cygwin") "cygwin")
@ -251,19 +257,35 @@ install_python_dependencies() {
# DEBUG ONLY (Update this version number to whatever PyCharm recommends) # DEBUG ONLY (Update this version number to whatever PyCharm recommends)
# pip install pydevd-pycharm~=223.8836.43 # pip install pydevd-pycharm~=223.8836.43
#This will copy our requirements.txt file out, make the khoya_ss lib a dynamic location then cleanup. #This will copy our requirements.txt file out and make the khoya_ss lib a dynamic location then cleanup.
echo "Copying $DIR/requirements.txt to /tmp/requirements_tmp.txt" >&3 local TEMP_REQUIREMENTS_FILE="$DIR/requirements_tmp_for_setup.txt"
echo "Replacing the . for lib to our DIR variable in tmp/requirements_tmp.txt." >&3 echo "Copying $DIR/requirements.txt to $TEMP_REQUIREMENTS_FILE" >&3
awk -v dir="$DIR" '/#.*kohya_ss.*library/{print; getline; sub(/^\.$/, dir)}1' "$DIR/requirements.txt" >/tmp/requirements_tmp.txt echo "Replacing the . for lib to our DIR variable in $TEMP_REQUIREMENTS_FILE." >&3
awk -v dir="$DIR" '/#.*kohya_ss.*library/{print; getline; sub(/^\.$/, dir)}1' "$DIR/requirements.txt" >"$TEMP_REQUIREMENTS_FILE"
# This will check if macOS is running then determine if M1+ or Intel CPU.
# It will append the appropriate packages to the requirements.txt file.
# Other OSs won't be affected and the version variables are at the top of this file.
if [[ "$(uname)" == "Darwin" ]]; then
# Check if the processor is Apple Silicon (arm64)
if [[ "$(uname -m)" == "arm64" ]]; then
echo "tensorflow-macos==$TENSORFLOW_MACOS_VERSION" >>"$TEMP_REQUIREMENTS_FILE"
echo "tensorflow-metal==$TENSORFLOW_METAL_VERSION" >>"$TEMP_REQUIREMENTS_FILE"
# Check if the processor is Intel (x86_64)
elif [[ "$(uname -m)" == "x86_64" ]]; then
echo "tensorflow==$TENSORFLOW_VERSION" >>"$TEMP_REQUIREMENTS_FILE"
fi
fi
if [ $VERBOSITY == 2 ]; then if [ $VERBOSITY == 2 ]; then
python -m pip install --quiet --use-pep517 --upgrade -r /tmp/requirements_tmp.txt >&3 python -m pip install --quiet --use-pep517 --upgrade -r "$TEMP_REQUIREMENTS_FILE" >&3
else else
python -m pip install --use-pep517 --upgrade -r /tmp/requirements_tmp.txt >&3 python -m pip install --use-pep517 --upgrade -r "$TEMP_REQUIREMENTS_FILE" >&3
fi fi
echo "Removing the temp requirements file." echo "Removing the temp requirements file."
if [ -f /tmp/requirements_tmp.txt ]; then if [ -f "$TEMP_REQUIREMENTS_FILE" ]; then
rm /tmp/requirements_tmp.txt rm -f "$TEMP_REQUIREMENTS_FILE"
fi fi
if [ -n "$VIRTUAL_ENV" ]; then if [ -n "$VIRTUAL_ENV" ]; then
@ -578,10 +600,10 @@ elif [[ "$OSTYPE" == "darwin"* ]]; then
configure_accelerate configure_accelerate
echo -e "Setup finished! Run ./gui.sh to start." echo -e "Setup finished! Run ./gui.sh to start."
elif [[ "$OSTYPE" == "cygwin" ]]; then elif [[ "$OSTYPE" == "cygwin" ]]; then
# Cygwin is a standalone suite of Linux utilies on Windows # Cygwin is a standalone suite of Linux utilities on Windows
echo "This hasn't been validated on cygwin yet." echo "This hasn't been validated on cygwin yet."
elif [[ "$OSTYPE" == "msys" ]]; then elif [[ "$OSTYPE" == "msys" ]]; then
# MinGW has the msys environment which is a standalone suite of Linux utilies on Windows # MinGW has the msys environment which is a standalone suite of Linux utilities on Windows
# "git bash" on Windows may also be detected as msys. # "git bash" on Windows may also be detected as msys.
echo "This hasn't been validated in msys (mingw) on Windows yet." echo "This hasn't been validated in msys (mingw) on Windows yet."
fi fi