WebUI/modules/hypernetworks/ui.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

39 lines
1.5 KiB
Python
Raw Normal View History

2022-10-07 20:22:22 +00:00
import html
import gradio as gr
2022-12-24 23:02:22 +00:00
import modules.hypernetworks.hypernetwork
2022-10-22 11:07:00 +00:00
from modules import devices, sd_hijack, shared
2022-10-07 20:22:22 +00:00
not_available = ["hardswish", "multiheadattention"]
2023-05-10 18:21:32 +00:00
keys = [x for x in modules.hypernetworks.hypernetwork.HypernetworkModule.activation_dict if x not in not_available]
2022-10-07 20:22:22 +00:00
def create_hypernetwork(name, enable_sizes, overwrite_old, layer_structure=None, activation_func=None, weight_init=None, add_layer_norm=False, use_dropout=False, dropout_structure=None):
filename = modules.hypernetworks.hypernetwork.create_hypernetwork(name, enable_sizes, overwrite_old, layer_structure, activation_func, weight_init, add_layer_norm, use_dropout, dropout_structure)
2022-10-21 09:11:12 +00:00
2023-05-10 18:21:32 +00:00
return gr.Dropdown.update(choices=sorted(shared.hypernetworks)), f"Created: {filename}", ""
2022-10-07 20:22:22 +00:00
def train_hypernetwork(*args):
shared.loaded_hypernetworks = []
2022-10-07 20:22:22 +00:00
assert not shared.cmd_opts.lowvram, 'Training models with lowvram is not possible'
2022-10-07 20:22:22 +00:00
try:
sd_hijack.undo_optimizations()
2022-10-11 12:54:34 +00:00
hypernetwork, filename = modules.hypernetworks.hypernetwork.train_hypernetwork(*args)
2022-10-07 20:22:22 +00:00
res = f"""
Training {'interrupted' if shared.state.interrupted else 'finished'} at {hypernetwork.step} steps.
Hypernetwork saved to {html.escape(filename)}
"""
return res, ""
except Exception:
raise
finally:
shared.sd_model.cond_stage_model.to(devices.device)
shared.sd_model.first_stage_model.to(devices.device)
2022-10-07 20:22:22 +00:00
sd_hijack.apply_optimizations()