Fix model wasn't restored even when choosing "None"

This commit is contained in:
Muhammad Rizqi Nur 2022-11-02 22:54:09 +07:00
parent e5690d0bf2
commit 8ab4927452

View file

@ -50,8 +50,8 @@ def delete_base_vae():
def restore_base_vae(model): def restore_base_vae(model):
global base_vae, checkpoint_info
if base_vae is not None and checkpoint_info == model.sd_checkpoint_info: if base_vae is not None and checkpoint_info == model.sd_checkpoint_info:
print("Restoring base VAE")
load_vae_dict(model, base_vae) load_vae_dict(model, base_vae)
delete_base_vae() delete_base_vae()
@ -143,6 +143,7 @@ def load_vae(model, vae_file=None):
vae_ckpt = torch.load(vae_file, map_location=shared.weight_load_location) vae_ckpt = torch.load(vae_file, map_location=shared.weight_load_location)
vae_dict_1 = {k: v for k, v in vae_ckpt["state_dict"].items() if k[0:4] != "loss" and k not in vae_ignore_keys} vae_dict_1 = {k: v for k, v in vae_ckpt["state_dict"].items() if k[0:4] != "loss" and k not in vae_ignore_keys}
load_vae_dict(model, vae_dict_1) load_vae_dict(model, vae_dict_1)
store_base_vae(model)
# If vae used is not in dict, update it # If vae used is not in dict, update it
# It will be removed on refresh though # It will be removed on refresh though
@ -150,6 +151,9 @@ def load_vae(model, vae_file=None):
if vae_opt not in vae_dict: if vae_opt not in vae_dict:
vae_dict[vae_opt] = vae_file vae_dict[vae_opt] = vae_file
vae_list.append(vae_opt) vae_list.append(vae_opt)
# shared.opts.data['sd_vae'] = vae_opt
else:
restore_base_vae(model)
loaded_vae_file = vae_file loaded_vae_file = vae_file
@ -166,12 +170,8 @@ def load_vae(model, vae_file=None):
# don't call this from outside # don't call this from outside
def load_vae_dict(model, vae_dict_1=None): def load_vae_dict(model, vae_dict_1):
if vae_dict_1: model.first_stage_model.load_state_dict(vae_dict_1)
store_base_vae(model)
model.first_stage_model.load_state_dict(vae_dict_1)
else:
restore_base_vae()
model.first_stage_model.to(devices.dtype_vae) model.first_stage_model.to(devices.dtype_vae)