7b5639cff5
This is a massive WIP and should not be trusted or used right now. However, major milestones have been crossed. Both message boxes and file dialogs are now properly subprocessed and work on macOS. I think by extension, it may work on runpod environments as well, but that remains to be tested.
190 lines
5.3 KiB
Python
190 lines
5.3 KiB
Python
import os
|
|
import subprocess
|
|
|
|
import gradio as gr
|
|
|
|
from .common_gui import (
|
|
get_file_path, get_saveasfile_path,
|
|
)
|
|
|
|
folder_symbol = '\U0001f4c2' # 📂
|
|
refresh_symbol = '\U0001f504' # 🔄
|
|
save_style_symbol = '\U0001f4be' # 💾
|
|
document_symbol = '\U0001F4C4' # 📄
|
|
PYTHON = 'python3' if os.name == 'posix' else './venv/Scripts/python.exe'
|
|
|
|
|
|
def svd_merge_lora(
|
|
lora_a_model,
|
|
lora_b_model,
|
|
ratio,
|
|
save_to,
|
|
precision,
|
|
save_precision,
|
|
new_rank,
|
|
new_conv_rank,
|
|
device,
|
|
):
|
|
# Check for caption_text_input
|
|
if lora_a_model == '':
|
|
show_message_box('Invalid model A file')
|
|
return
|
|
|
|
if lora_b_model == '':
|
|
show_message_box('Invalid model B file')
|
|
return
|
|
|
|
# Check if source model exist
|
|
if not os.path.isfile(lora_a_model):
|
|
show_message_box('The provided model A is not a file')
|
|
return
|
|
|
|
if not os.path.isfile(lora_b_model):
|
|
show_message_box('The provided model B is not a file')
|
|
return
|
|
|
|
ratio_a = ratio
|
|
ratio_b = 1 - ratio
|
|
|
|
run_cmd = f'{PYTHON} "{os.path.join("networks","svd_merge_lora.py")}"'
|
|
run_cmd += f' --save_precision {save_precision}'
|
|
run_cmd += f' --precision {precision}'
|
|
run_cmd += f' --save_to "{save_to}"'
|
|
run_cmd += f' --models "{lora_a_model}" "{lora_b_model}"'
|
|
run_cmd += f' --ratios {ratio_a} {ratio_b}'
|
|
run_cmd += f' --device {device}'
|
|
run_cmd += f' --new_rank "{new_rank}"'
|
|
run_cmd += f' --new_conv_rank "{new_conv_rank}"'
|
|
|
|
print(run_cmd)
|
|
|
|
# Run the command
|
|
if os.name == 'posix':
|
|
os.system(run_cmd)
|
|
else:
|
|
subprocess.run(run_cmd)
|
|
|
|
|
|
###
|
|
# Gradio UI
|
|
###
|
|
|
|
|
|
def gradio_svd_merge_lora_tab():
|
|
with gr.Tab('Merge LoRA (SVD)'):
|
|
gr.Markdown('This utility can merge two LoRA networks together.')
|
|
|
|
lora_ext = gr.Textbox(value='*.safetensors *.pt', visible=False)
|
|
lora_ext_name = gr.Textbox(value='LoRA model types', visible=False)
|
|
|
|
with gr.Row():
|
|
lora_a_model = gr.Textbox(
|
|
label='LoRA model "A"',
|
|
placeholder='Path to the LoRA A model',
|
|
interactive=True,
|
|
)
|
|
button_lora_a_model_file = gr.Button(
|
|
folder_symbol, elem_id='open_folder_small'
|
|
)
|
|
button_lora_a_model_file.click(
|
|
get_file_path,
|
|
inputs=[lora_a_model, lora_ext, lora_ext_name],
|
|
outputs=lora_a_model,
|
|
show_progress=False,
|
|
)
|
|
|
|
lora_b_model = gr.Textbox(
|
|
label='LoRA model "B"',
|
|
placeholder='Path to the LoRA B model',
|
|
interactive=True,
|
|
)
|
|
button_lora_b_model_file = gr.Button(
|
|
folder_symbol, elem_id='open_folder_small'
|
|
)
|
|
button_lora_b_model_file.click(
|
|
get_file_path,
|
|
inputs=[lora_b_model, lora_ext, lora_ext_name],
|
|
outputs=lora_b_model,
|
|
show_progress=False,
|
|
)
|
|
with gr.Row():
|
|
ratio = gr.Slider(
|
|
label='Merge ratio (eg: 0.7 mean 70% of model A and 30% of model B',
|
|
minimum=0,
|
|
maximum=1,
|
|
step=0.01,
|
|
value=0.5,
|
|
interactive=True,
|
|
)
|
|
new_rank = gr.Slider(
|
|
label='New Rank',
|
|
minimum=1,
|
|
maximum=1024,
|
|
step=1,
|
|
value=128,
|
|
interactive=True,
|
|
)
|
|
new_conv_rank = gr.Slider(
|
|
label='New Conv Rank',
|
|
minimum=1,
|
|
maximum=1024,
|
|
step=1,
|
|
value=128,
|
|
interactive=True,
|
|
)
|
|
|
|
with gr.Row():
|
|
save_to = gr.Textbox(
|
|
label='Save to',
|
|
placeholder='path for the file to save...',
|
|
interactive=True,
|
|
)
|
|
button_save_to = gr.Button(
|
|
folder_symbol, elem_id='open_folder_small'
|
|
)
|
|
button_save_to.click(
|
|
get_saveasfile_path,
|
|
inputs=[save_to, lora_ext, lora_ext_name],
|
|
outputs=save_to,
|
|
show_progress=False,
|
|
)
|
|
precision = gr.Dropdown(
|
|
label='Merge precision',
|
|
choices=['fp16', 'bf16', 'float'],
|
|
value='float',
|
|
interactive=True,
|
|
)
|
|
save_precision = gr.Dropdown(
|
|
label='Save precision',
|
|
choices=['fp16', 'bf16', 'float'],
|
|
value='float',
|
|
interactive=True,
|
|
)
|
|
device = gr.Dropdown(
|
|
label='Device',
|
|
choices=[
|
|
'cpu',
|
|
'cuda',
|
|
],
|
|
value='cuda',
|
|
interactive=True,
|
|
)
|
|
|
|
convert_button = gr.Button('Merge model')
|
|
|
|
convert_button.click(
|
|
svd_merge_lora,
|
|
inputs=[
|
|
lora_a_model,
|
|
lora_b_model,
|
|
ratio,
|
|
save_to,
|
|
precision,
|
|
save_precision,
|
|
new_rank,
|
|
new_conv_rank,
|
|
device,
|
|
],
|
|
show_progress=False,
|
|
)
|