Unverified Commit f108782e authored by AUTOMATIC1111's avatar AUTOMATIC1111 Committed by GitHub
Browse files

Merge pull request #4930 from Narsil/allow_to_load_safetensors_file

Supporting `*.safetensors` format.
parents a89d7f4f 0efffbb4
Loading
Loading
Loading
Loading
+9 −2
Original line number Diff line number Diff line
@@ -45,7 +45,7 @@ def checkpoint_tiles():

def list_models():
    checkpoints_list.clear()
    model_list = modelloader.load_models(model_path=model_path, command_path=shared.cmd_opts.ckpt_dir, ext_filter=[".ckpt"])
    model_list = modelloader.load_models(model_path=model_path, command_path=shared.cmd_opts.ckpt_dir, ext_filter=[".ckpt", ".safetensors"])

    def modeltitle(path, shorthash):
        abspath = os.path.abspath(path)
@@ -173,6 +173,13 @@ def load_model_weights(model, checkpoint_info, vae_file="auto"):
        # load from file
        print(f"Loading weights [{sd_model_hash}] from {checkpoint_file}")

        if checkpoint_file.endswith(".safetensors"):
            try:
                from safetensors.torch import load_file
            except ImportError as e:
                raise ImportError(f"The model is in safetensors format and it is not installed, use `pip install safetensors`: {e}")
            pl_sd = load_file(checkpoint_file, device=shared.weight_load_location)
        else:
            pl_sd = torch.load(checkpoint_file, map_location=shared.weight_load_location)
        if "global_step" in pl_sd:
            print(f"Global Step: {pl_sd['global_step']}")