extra_networks_lora.py 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. from modules import extra_networks, shared
  2. import networks
  3. class ExtraNetworkLora(extra_networks.ExtraNetwork):
  4. def __init__(self):
  5. super().__init__('lora')
  6. self.errors = {}
  7. """mapping of network names to the number of errors the network had during operation"""
  8. def activate(self, p, params_list):
  9. additional = shared.opts.sd_lora
  10. self.errors.clear()
  11. if additional != "None" and additional in networks.available_networks and not any(x for x in params_list if x.items[0] == additional):
  12. p.all_prompts = [x + f"<lora:{additional}:{shared.opts.extra_networks_default_multiplier}>" for x in p.all_prompts]
  13. params_list.append(extra_networks.ExtraNetworkParams(items=[additional, shared.opts.extra_networks_default_multiplier]))
  14. names = []
  15. te_multipliers = []
  16. unet_multipliers = []
  17. dyn_dims = []
  18. for params in params_list:
  19. assert params.items
  20. names.append(params.positional[0])
  21. te_multiplier = float(params.positional[1]) if len(params.positional) > 1 else 1.0
  22. te_multiplier = float(params.named.get("te", te_multiplier))
  23. unet_multiplier = float(params.positional[2]) if len(params.positional) > 2 else te_multiplier
  24. unet_multiplier = float(params.named.get("unet", unet_multiplier))
  25. dyn_dim = int(params.positional[3]) if len(params.positional) > 3 else None
  26. dyn_dim = int(params.named["dyn"]) if "dyn" in params.named else dyn_dim
  27. te_multipliers.append(te_multiplier)
  28. unet_multipliers.append(unet_multiplier)
  29. dyn_dims.append(dyn_dim)
  30. networks.load_networks(names, te_multipliers, unet_multipliers, dyn_dims)
  31. if shared.opts.lora_add_hashes_to_infotext:
  32. network_hashes = []
  33. for item in networks.loaded_networks:
  34. shorthash = item.network_on_disk.shorthash
  35. if not shorthash:
  36. continue
  37. alias = item.mentioned_name
  38. if not alias:
  39. continue
  40. alias = alias.replace(":", "").replace(",", "")
  41. network_hashes.append(f"{alias}: {shorthash}")
  42. if network_hashes:
  43. p.extra_generation_params["Lora hashes"] = ", ".join(network_hashes)
  44. def deactivate(self, p):
  45. if self.errors:
  46. p.comment("Networks with errors: " + ", ".join(f"{k} ({v})" for k, v in self.errors.items()))
  47. self.errors.clear()