From d2c1204d91d7c98be7998e3966bd82e22750293b Mon Sep 17 00:00:00 2001
From: zhifu gao <zhifu.gzf@alibaba-inc.com>
Date: 星期一, 04 三月 2024 17:50:29 +0800
Subject: [PATCH] Revert "Dev yf" (#1418)

---
 funasr/train_utils/load_pretrained_model.py |   12 +++++++-----
 1 files changed, 7 insertions(+), 5 deletions(-)

diff --git a/funasr/train_utils/load_pretrained_model.py b/funasr/train_utils/load_pretrained_model.py
index 7a8c374..ea23725 100644
--- a/funasr/train_utils/load_pretrained_model.py
+++ b/funasr/train_utils/load_pretrained_model.py
@@ -68,9 +68,9 @@
 	else:
 		buffer = BytesIO(oss_bucket.get_object(path).read())
 		src_state = torch.load(buffer, map_location=map_location)
-	if "state_dict" in src_state:
-		src_state = src_state["state_dict"]
-	
+		
+	src_state = src_state["state_dict"] if "state_dict" in src_state else src_state
+	src_state = src_state["model_state_dict"] if "model_state_dict" in src_state else src_state
 	src_state = src_state["model"] if "model" in src_state else src_state
 	
 	if isinstance(scope_map, str):
@@ -90,10 +90,12 @@
 				
 				if dst_prefix == "" and (src_prefix + k) in src_state.keys():
 					k_src = src_prefix + k
-					print(f"init param, map: {k} from {k_src} in ckpt")
+					if not k_src.startswith("module."):
+						print(f"init param, map: {k} from {k_src} in ckpt")
 				elif k.startswith(dst_prefix) and k.replace(dst_prefix, src_prefix, 1) in src_state.keys():
 					k_src = k.replace(dst_prefix, src_prefix, 1)
-					print(f"init param, map: {k} from {k_src} in ckpt")
+					if not k_src.startswith("module."):
+						print(f"init param, map: {k} from {k_src} in ckpt")
 					
 		if k_src in src_state.keys():
 			if ignore_init_mismatch and dst_state[k].shape != src_state[k_src].shape:

--
Gitblit v1.9.1