2022-12-17 21:22:34 +00:00
import os
import re
2023-03-30 08:40:00 +00:00
2022-12-17 21:22:34 +00:00
import gradio as gr
2023-03-30 08:40:00 +00:00
from easygui import boolbox
2023-03-31 21:39:10 +00:00
from . common_gui_functions import get_folder_path
2022-12-17 21:22:34 +00:00
2023-03-30 08:40:00 +00:00
2022-12-17 21:22:34 +00:00
# def select_folder():
# # Open a file dialog to select a directory
# folder = filedialog.askdirectory()
# # Update the GUI to display the selected folder
# selected_folder_label.config(text=folder)
def dataset_balancing ( concept_repeats , folder , insecure ) :
2022-12-20 02:50:05 +00:00
2022-12-17 21:22:34 +00:00
if not concept_repeats > 0 :
# Display an error message if the total number of repeats is not a valid integer
2023-03-30 08:40:00 +00:00
show_message_box ( ' Please enter a valid integer for the total number of repeats. ' )
2022-12-17 21:22:34 +00:00
return
concept_repeats = int ( concept_repeats )
# Check if folder exist
if folder == ' ' or not os . path . isdir ( folder ) :
2023-03-30 08:40:00 +00:00
show_message_box ( ' Please enter a valid folder for balancing. ' )
2022-12-17 21:22:34 +00:00
return
pattern = re . compile ( r ' ^ \ d+_.+$ ' )
# Iterate over the subdirectories in the selected folder
for subdir in os . listdir ( folder ) :
if pattern . match ( subdir ) or insecure :
# Calculate the number of repeats for the current subdirectory
# Get a list of all the files in the folder
files = os . listdir ( os . path . join ( folder , subdir ) )
# Filter the list to include only image files
image_files = [
f
for f in files
if f . endswith ( ( ' .jpg ' , ' .jpeg ' , ' .png ' , ' .gif ' , ' .webp ' ) )
]
# Count the number of image files
images = len ( image_files )
# Check if the subdirectory name starts with a number inside braces,
# indicating that the repeats value should be multiplied
match = re . match ( r ' ^ \ { ( \ d+ \ .? \ d*) \ } ' , subdir )
if match :
# Multiply the repeats value by the number inside the braces
2022-12-21 16:02:49 +00:00
if not images == 0 :
2022-12-22 16:51:34 +00:00
repeats = max (
1 ,
round (
concept_repeats / images * float ( match . group ( 1 ) )
) ,
)
2022-12-21 16:02:49 +00:00
else :
repeats = 0
2022-12-17 21:22:34 +00:00
subdir = subdir [ match . end ( ) : ]
else :
2022-12-21 16:02:49 +00:00
if not images == 0 :
repeats = max ( 1 , round ( concept_repeats / images ) )
else :
repeats = 0
2022-12-17 21:22:34 +00:00
# Check if the subdirectory name already has a number at the beginning
match = re . match ( r ' ^ \ d+_ ' , subdir )
if match :
# Replace the existing number with the new number
old_name = os . path . join ( folder , subdir )
new_name = os . path . join (
folder , f ' { repeats } _ { subdir [ match . end ( ) : ] } '
)
else :
# Add the new number at the beginning of the name
old_name = os . path . join ( folder , subdir )
new_name = os . path . join ( folder , f ' { repeats } _ { subdir } ' )
os . rename ( old_name , new_name )
else :
2022-12-20 02:50:05 +00:00
print (
f ' Skipping folder { subdir } because it does not match kohya_ss expected syntax... '
)
2022-12-17 21:22:34 +00:00
2023-03-30 08:40:00 +00:00
show_message_box ( ' Dataset balancing completed... ' )
2022-12-17 21:22:34 +00:00
2022-12-20 02:50:05 +00:00
2022-12-17 21:22:34 +00:00
def warning ( insecure ) :
if insecure :
2022-12-20 02:50:05 +00:00
if boolbox (
f ' WARNING!!! You have asked to rename non kohya_ss <num>_<text> folders... \n \n Are you sure you want to do that? ' ,
choices = ( ' Yes, I like danger ' , ' No, get me out of here ' ) ,
) :
2022-12-17 21:22:34 +00:00
return True
else :
return False
2022-12-20 02:50:05 +00:00
2022-12-17 21:22:34 +00:00
def gradio_dataset_balancing_tab ( ) :
2022-12-30 02:17:41 +00:00
with gr . Tab ( ' Dreambooth/LoRA Dataset balancing ' ) :
2022-12-20 02:50:05 +00:00
gr . Markdown (
' This utility will ensure that each concept folder in the dataset folder is used equally during the training process of the dreambooth machine learning model, regardless of the number of images in each folder. It will do this by renaming the concept folders to indicate the number of times they should be repeated during training. '
)
gr . Markdown (
' WARNING! The use of this utility on the wrong folder can lead to unexpected folder renaming!!! '
)
2022-12-17 21:22:34 +00:00
with gr . Row ( ) :
2022-12-20 02:50:05 +00:00
select_dataset_folder_input = gr . Textbox (
label = ' Dataset folder ' ,
2022-12-17 21:22:34 +00:00
placeholder = ' Folder containing the concepts folders to balance... ' ,
interactive = True ,
)
select_dataset_folder_button = gr . Button (
' 📂 ' , elem_id = ' open_folder_small '
)
select_dataset_folder_button . click (
2023-03-04 23:56:22 +00:00
get_folder_path ,
outputs = select_dataset_folder_input ,
show_progress = False ,
2022-12-17 21:22:34 +00:00
)
total_repeats_number = gr . Number (
value = 1000 ,
interactive = True ,
label = ' Training steps per concept per epoch ' ,
)
with gr . Accordion ( ' Advanced options ' , open = False ) :
2022-12-20 02:50:05 +00:00
insecure = gr . Checkbox (
value = False ,
label = ' DANGER!!! -- Insecure folder renaming -- DANGER!!! ' ,
)
2022-12-17 21:22:34 +00:00
insecure . change ( warning , inputs = insecure , outputs = insecure )
balance_button = gr . Button ( ' Balance dataset ' )
balance_button . click (
dataset_balancing ,
2022-12-20 02:50:05 +00:00
inputs = [
total_repeats_number ,
select_dataset_folder_input ,
insecure ,
] ,
2023-03-04 23:56:22 +00:00
show_progress = False ,
2022-12-17 21:22:34 +00:00
)