lora_script.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. import torch
  2. import gradio as gr
  3. from fastapi import FastAPI
  4. import lora
  5. import extra_networks_lora
  6. import ui_extra_networks_lora
  7. from modules import script_callbacks, ui_extra_networks, extra_networks, shared
  8. def unload():
  9. torch.nn.Linear.forward = torch.nn.Linear_forward_before_lora
  10. torch.nn.Linear._load_from_state_dict = torch.nn.Linear_load_state_dict_before_lora
  11. torch.nn.Conv2d.forward = torch.nn.Conv2d_forward_before_lora
  12. torch.nn.Conv2d._load_from_state_dict = torch.nn.Conv2d_load_state_dict_before_lora
  13. torch.nn.MultiheadAttention.forward = torch.nn.MultiheadAttention_forward_before_lora
  14. torch.nn.MultiheadAttention._load_from_state_dict = torch.nn.MultiheadAttention_load_state_dict_before_lora
  15. def before_ui():
  16. ui_extra_networks.register_page(ui_extra_networks_lora.ExtraNetworksPageLora())
  17. extra_networks.register_extra_network(extra_networks_lora.ExtraNetworkLora())
  18. if not hasattr(torch.nn, 'Linear_forward_before_lora'):
  19. torch.nn.Linear_forward_before_lora = torch.nn.Linear.forward
  20. if not hasattr(torch.nn, 'Linear_load_state_dict_before_lora'):
  21. torch.nn.Linear_load_state_dict_before_lora = torch.nn.Linear._load_from_state_dict
  22. if not hasattr(torch.nn, 'Conv2d_forward_before_lora'):
  23. torch.nn.Conv2d_forward_before_lora = torch.nn.Conv2d.forward
  24. if not hasattr(torch.nn, 'Conv2d_load_state_dict_before_lora'):
  25. torch.nn.Conv2d_load_state_dict_before_lora = torch.nn.Conv2d._load_from_state_dict
  26. if not hasattr(torch.nn, 'MultiheadAttention_forward_before_lora'):
  27. torch.nn.MultiheadAttention_forward_before_lora = torch.nn.MultiheadAttention.forward
  28. if not hasattr(torch.nn, 'MultiheadAttention_load_state_dict_before_lora'):
  29. torch.nn.MultiheadAttention_load_state_dict_before_lora = torch.nn.MultiheadAttention._load_from_state_dict
  30. torch.nn.Linear.forward = lora.lora_Linear_forward
  31. torch.nn.Linear._load_from_state_dict = lora.lora_Linear_load_state_dict
  32. torch.nn.Conv2d.forward = lora.lora_Conv2d_forward
  33. torch.nn.Conv2d._load_from_state_dict = lora.lora_Conv2d_load_state_dict
  34. torch.nn.MultiheadAttention.forward = lora.lora_MultiheadAttention_forward
  35. torch.nn.MultiheadAttention._load_from_state_dict = lora.lora_MultiheadAttention_load_state_dict
  36. script_callbacks.on_model_loaded(lora.assign_lora_names_to_compvis_modules)
  37. script_callbacks.on_script_unloaded(unload)
  38. script_callbacks.on_before_ui(before_ui)
  39. script_callbacks.on_infotext_pasted(lora.infotext_pasted)
  40. shared.options_templates.update(shared.options_section(('extra_networks', "Extra Networks"), {
  41. "sd_lora": shared.OptionInfo("None", "Add Lora to prompt", gr.Dropdown, lambda: {"choices": ["None", *lora.available_loras]}, refresh=lora.list_available_loras),
  42. }))
  43. shared.options_templates.update(shared.options_section(('compatibility', "Compatibility"), {
  44. "lora_functional": shared.OptionInfo(False, "Lora: use old method that takes longer when you have multiple Loras active and produces same results as kohya-ss/sd-webui-additional-networks extension"),
  45. }))
  46. def create_lora_json(obj: lora.LoraOnDisk):
  47. return {
  48. "name": obj.name,
  49. "alias": obj.alias,
  50. "path": obj.filename,
  51. "metadata": obj.metadata,
  52. }
  53. def api_loras(_: gr.Blocks, app: FastAPI):
  54. @app.get("/sdapi/v1/loras")
  55. async def get_loras():
  56. return [create_lora_json(obj) for obj in lora.available_loras.values()]
  57. script_callbacks.on_app_started(api_loras)