Skip to content

Commit

Permalink
Merge pull request #257 from bmaltais/dev
Browse files Browse the repository at this point in the history
v21.0.1
  • Loading branch information
bmaltais committed Mar 2, 2023
2 parents 74cce23 + 7f0e568 commit f6b261d
Show file tree
Hide file tree
Showing 8 changed files with 173 additions and 16 deletions.
7 changes: 6 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,12 @@ This will store your a backup file with your current locally installed pip packa

## Change History

* 2023/02/24 (v20.8.2):
* 2023/03/01 (v21.0.1):
- Add warning to tensorboard start if the log information is missing
- Fix issue with 8bitadam on older config file load
* 2023/02/27 (v21.0.0):
- Add tensorboard start and stop support to the GUI
* 2023/02/26 (v20.8.2):
- Fix issue https://github.com/bmaltais/kohya_ss/issues/231
- Change default for seed to random
- Add support for --share argument to `kohya_gui.py` and `gui.ps1`
Expand Down
22 changes: 21 additions & 1 deletion dreambooth_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@
gradio_config,
gradio_source_model,
set_legacy_8bitadam,
update_optimizer,
)
from library.tensorboard_gui import (
gradio_tensorboard,
start_tensorboard,
stop_tensorboard,
)
from library.dreambooth_folder_creation_gui import (
gradio_dreambooth_folder_creation_tab,
Expand Down Expand Up @@ -203,6 +209,8 @@ def open_configuration(
with open(file_path, 'r') as f:
my_data_db = json.load(f)
print('Loading config...')
# Update values to fix deprecated use_8bit_adam checkbox and set appropriate optimizer if it is set to True
my_data = update_optimizer(my_data)
else:
file_path = original_file_path # In case a file_path was provided and the user decide to cancel the open action
my_data_db = {}
Expand Down Expand Up @@ -639,7 +647,19 @@ def dreambooth_tab(
logging_dir_input=logging_dir,
)

button_run = gr.Button('Train model')
button_run = gr.Button('Train model', variant='primary')

# Setup gradio tensorboard buttons
button_start_tensorboard, button_stop_tensorboard = gradio_tensorboard()

button_start_tensorboard.click(
start_tensorboard,
inputs=logging_dir,
)

button_stop_tensorboard.click(
stop_tensorboard,
)

settings_list = [
pretrained_model_name_or_path,
Expand Down
37 changes: 28 additions & 9 deletions finetune_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,12 @@
color_aug_changed,
run_cmd_training,
set_legacy_8bitadam,
update_optimizer,
)
from library.tensorboard_gui import (
gradio_tensorboard,
start_tensorboard,
stop_tensorboard,
)
from library.utilities import utilities_tab

Expand Down Expand Up @@ -198,21 +204,22 @@ def open_config_file(
original_file_path = file_path
file_path = get_file_path(file_path)

if file_path != '' and file_path != None:
print(f'Loading config file {file_path}')
if not file_path == '' and not file_path == None:
# load variables from JSON file
with open(file_path, 'r') as f:
my_data_ft = json.load(f)
my_data_db = json.load(f)
print('Loading config...')
# Update values to fix deprecated use_8bit_adam checkbox and set appropriate optimizer if it is set to True
my_data = update_optimizer(my_data)
else:
file_path = original_file_path # In case a file_path was provided and the user decide to cancel the open action
my_data_ft = {}
file_path = original_file_path # In case a file_path was provided and the user decide to cancel the open action
my_data_db = {}

values = [file_path]
for key, value in parameters:
# Set the value in the dictionary to the corresponding value in `my_data_ft`, or the default value if not found
# Set the value in the dictionary to the corresponding value in `my_data`, or the default value if not found
if not key in ['file_path']:
values.append(my_data_ft.get(key, value))
# print(values)
values.append(my_data_db.get(key, value))
return tuple(values)


Expand Down Expand Up @@ -623,7 +630,19 @@ def finetune_tab():
outputs=[optimizer, use_8bit_adam],
)

button_run = gr.Button('Train model')
button_run = gr.Button('Train model', variant='primary')

# Setup gradio tensorboard buttons
button_start_tensorboard, button_stop_tensorboard = gradio_tensorboard()

button_start_tensorboard.click(
start_tensorboard,
inputs=logging_dir,
)

button_stop_tensorboard.click(
stop_tensorboard,
)

settings_list = [
pretrained_model_name_or_path,
Expand Down
9 changes: 8 additions & 1 deletion library/common_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,12 @@
save_style_symbol = '\U0001f4be' # 💾
document_symbol = '\U0001F4C4' # 📄

def update_optimizer(my_data):
if my_data.get('use_8bit_adam', False):
my_data['optimizer'] = 'AdamW8bit'
my_data['use_8bit_adam'] = False
return my_data


def get_dir_and_file(file_path):
dir_path, file_name = os.path.split(file_path)
Expand Down Expand Up @@ -604,7 +610,8 @@ def gradio_advanced_training():
label='Memory efficient attention', value=False
)
with gr.Row():
use_8bit_adam = gr.Checkbox(label='Use 8bit adam', value=True)
# This use_8bit_adam element should be removed in a future release as it is no longer used
use_8bit_adam = gr.Checkbox(label='Use 8bit adam', value=False, visible=False)
xformers = gr.Checkbox(label='Use xformers', value=True)
color_aug = gr.Checkbox(label='Color augmentation', value=False)
flip_aug = gr.Checkbox(label='Flip augmentation', value=False)
Expand Down
46 changes: 46 additions & 0 deletions library/tensorboard_gui.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import os
import gradio as gr
from easygui import msgbox
import subprocess
import time

tensorboard_proc = None # I know... bad but heh

def start_tensorboard(logging_dir):
global tensorboard_proc

if not os.listdir(logging_dir):
print("Error: log folder is empty")
msgbox(msg="Error: log folder is empty")
return

run_cmd = f'tensorboard.exe --logdir "{logging_dir}"'

print(run_cmd)
if tensorboard_proc is not None:
print("Tensorboard is already running. Terminating existing process before starting new one...")
stop_tensorboard()

# Start background process
print('Starting tensorboard...')
tensorboard_proc = subprocess.Popen(run_cmd)

# Wait for some time to allow TensorBoard to start up
time.sleep(5)

# Open the TensorBoard URL in the default browser
print('Opening tensorboard url in browser...')
import webbrowser
webbrowser.open('http://localhost:6006')

def stop_tensorboard():
print('Stopping tensorboard process...')
tensorboard_proc.kill()
print('...process stopped')

def gradio_tensorboard():
with gr.Row():
button_start_tensorboard = gr.Button('Start tensorboard')
button_stop_tensorboard = gr.Button('Stop tensorboard')

return(button_start_tensorboard, button_stop_tensorboard)
25 changes: 22 additions & 3 deletions lora_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,16 @@
gradio_source_model,
run_cmd_training,
set_legacy_8bitadam,
update_optimizer,
)
from library.dreambooth_folder_creation_gui import (
gradio_dreambooth_folder_creation_tab,
)
from library.tensorboard_gui import (
gradio_tensorboard,
start_tensorboard,
stop_tensorboard,
)
from library.dataset_balancing_gui import gradio_dataset_balancing_tab
from library.utilities import utilities_tab
from library.merge_lora_gui import gradio_merge_lora_tab
Expand All @@ -41,7 +47,6 @@
save_style_symbol = '\U0001f4be' # 💾
document_symbol = '\U0001F4C4' # 📄


def save_configuration(
save_as,
file_path,
Expand Down Expand Up @@ -221,6 +226,8 @@ def open_configuration(
with open(file_path, 'r') as f:
my_data = json.load(f)
print('Loading config...')
# Update values to fix deprecated use_8bit_adam checkbox and set appropriate optimizer if it is set to True
my_data = update_optimizer(my_data)
else:
file_path = original_file_path # In case a file_path was provided and the user decide to cancel the open action
my_data = {}
Expand Down Expand Up @@ -745,7 +752,19 @@ def lora_tab(
gradio_resize_lora_tab()
gradio_verify_lora_tab()

button_run = gr.Button('Train model')
button_run = gr.Button('Train model', variant='primary')

# Setup gradio tensorboard buttons
button_start_tensorboard, button_stop_tensorboard = gradio_tensorboard()

button_start_tensorboard.click(
start_tensorboard,
inputs=logging_dir,
)

button_stop_tensorboard.click(
stop_tensorboard,
)

settings_list = [
pretrained_model_name_or_path,
Expand Down Expand Up @@ -894,4 +913,4 @@ def UI(**kwargs):

args = parser.parse_args()

UI(username=args.username, password=args.password, inbrowser=args.inbrowser, server_port=args.server_port)
UI(username=args.username, password=args.password, inbrowser=args.inbrowser, server_port=args.server_port)
22 changes: 21 additions & 1 deletion textual_inversion_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@
gradio_config,
gradio_source_model,
set_legacy_8bitadam,
update_optimizer,
)
from library.tensorboard_gui import (
gradio_tensorboard,
start_tensorboard,
stop_tensorboard,
)
from library.dreambooth_folder_creation_gui import (
gradio_dreambooth_folder_creation_tab,
Expand Down Expand Up @@ -213,6 +219,8 @@ def open_configuration(
with open(file_path, 'r') as f:
my_data_db = json.load(f)
print('Loading config...')
# Update values to fix deprecated use_8bit_adam checkbox and set appropriate optimizer if it is set to True
my_data = update_optimizer(my_data)
else:
file_path = original_file_path # In case a file_path was provided and the user decide to cancel the open action
my_data_db = {}
Expand Down Expand Up @@ -714,7 +722,19 @@ def ti_tab(
logging_dir_input=logging_dir,
)

button_run = gr.Button('Train TI')
button_run = gr.Button('Train model', variant='primary')

# Setup gradio tensorboard buttons
button_start_tensorboard, button_stop_tensorboard = gradio_tensorboard()

button_start_tensorboard.click(
start_tensorboard,
inputs=logging_dir,
)

button_stop_tensorboard.click(
stop_tensorboard,
)

settings_list = [
pretrained_model_name_or_path,
Expand Down
21 changes: 21 additions & 0 deletions tools/rename_depth_mask.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import os
import argparse

# Define the command line arguments
parser = argparse.ArgumentParser(description='Rename files in a folder')
parser.add_argument('folder', metavar='folder', type=str, help='the folder containing the files to rename')

# Parse the arguments
args = parser.parse_args()

# Get the list of files in the folder
files = os.listdir(args.folder)

# Loop through each file in the folder
for file in files:
# Check if the file has the expected format
if file.endswith('-0000.png'):
# Get the new file name
new_file_name = file[:-9] + '.mask'
# Rename the file
os.rename(os.path.join(args.folder, file), os.path.join(args.folder, new_file_name))

0 comments on commit f6b261d

Please sign in to comment.