2025-01-22 14:47:50 +08:00
|
|
|
import copy
|
2025-05-23 15:21:41 +08:00
|
|
|
from transformers import __version__ as TRANSFORMERS_VERSION
|
2025-01-22 14:47:50 +08:00
|
|
|
|
|
|
|
|
class ModelMapper:
|
|
|
|
|
def __init__(self):
|
|
|
|
|
self.attrs = []
|
|
|
|
|
self.mapper = dict()
|
2025-04-28 11:38:44 +08:00
|
|
|
self.init_models()
|
2025-01-22 14:47:50 +08:00
|
|
|
|
|
|
|
|
def get_map(self, config):
|
|
|
|
|
model_type = config.model_type
|
|
|
|
|
if model_type == 'chatglm':
|
|
|
|
|
if hasattr(config, 'vocab_size') and config.vocab_size == 130528:
|
|
|
|
|
model_type = 'chatglm'
|
|
|
|
|
else:
|
|
|
|
|
model_type = 'chatglm2'
|
|
|
|
|
if model_type in self.mapper:
|
|
|
|
|
return model_type, self.mapper[model_type]
|
|
|
|
|
return model_type, self.default_map
|
|
|
|
|
|
|
|
|
|
def regist(self, model_type, model_map):
|
|
|
|
|
assert('config' in model_map and
|
|
|
|
|
'decoder' in model_map and
|
|
|
|
|
'attention' in model_map)
|
|
|
|
|
self.mapper[model_type] = model_map
|
|
|
|
|
|
2025-04-28 11:38:44 +08:00
|
|
|
def init_models(self):
|
2025-01-22 14:47:50 +08:00
|
|
|
self.defualt_map()
|
2025-04-28 11:38:44 +08:00
|
|
|
for method_name in dir(self):
|
|
|
|
|
if callable(getattr(self, method_name)) and method_name.startswith("regist_"):
|
|
|
|
|
method = getattr(self, method_name)
|
|
|
|
|
method()
|
2025-01-22 14:47:50 +08:00
|
|
|
|
|
|
|
|
def regist_llama(self):
|
|
|
|
|
llama_map = self.default_map
|
|
|
|
|
self.regist('llama', llama_map)
|
|
|
|
|
self.regist('qwen2', llama_map)
|
|
|
|
|
self.regist('internlm', llama_map)
|
|
|
|
|
self.regist('mobilellm', llama_map)
|
|
|
|
|
# baichuan
|
|
|
|
|
baichuan_map = copy.deepcopy(self.default_map)
|
|
|
|
|
baichuan_map[self.attention_key] = {
|
|
|
|
|
'qkv_proj': 'W_pack',
|
|
|
|
|
'o_proj': 'o_proj'
|
|
|
|
|
}
|
|
|
|
|
self.regist('baichuan', baichuan_map)
|
2025-05-23 15:21:41 +08:00
|
|
|
def regist_deepseek_vl(self):
|
|
|
|
|
deepseek_vlmap = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'language_config.hidden_size',
|
|
|
|
|
'num_attention_heads': 'language_config.num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'language_config.num_hidden_layers',
|
|
|
|
|
'rope_theta': 'language_config.rope_theta',
|
|
|
|
|
'head_dim': 'language_config.head_dim',
|
|
|
|
|
'num_key_value_heads': 'language_config.num_key_value_heads',
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'language_model.lm_head',
|
|
|
|
|
'embed_': 'language_model.model.embed_tokens',
|
|
|
|
|
'blocks_': 'language_model.model.layers',
|
|
|
|
|
'final_layernorm_': 'language_model.model.norm',
|
|
|
|
|
'visual': 'vision_model'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('deepseek-vl', deepseek_vlmap)
|
2025-01-22 14:47:50 +08:00
|
|
|
|
|
|
|
|
def regist_mllama(self):
|
|
|
|
|
mllama_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'text_config.hidden_size',
|
|
|
|
|
'num_attention_heads': 'text_config.num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'text_config.num_hidden_layers',
|
|
|
|
|
'num_key_value_heads': 'text_config.num_key_value_heads',
|
|
|
|
|
'rope_theta': 'text_config.rope_theta'
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'language_model.lm_head',
|
|
|
|
|
'embed_': 'language_model.model.embed_tokens',
|
|
|
|
|
'blocks_': 'language_model.model.layers',
|
|
|
|
|
'final_layernorm_': 'language_model.model.norm',
|
|
|
|
|
'visual': 'vision_model',
|
|
|
|
|
'multi_modal_projector': 'multi_modal_projector'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'cross_attn': 'cross_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj',
|
|
|
|
|
'q_norm': 'q_norm',
|
|
|
|
|
'k_norm': 'k_norm',
|
|
|
|
|
'cross_attn_attn_gate': 'cross_attn_attn_gate',
|
|
|
|
|
'cross_attn_mlp_gate': 'cross_attn_mlp_gate'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('mllama', mllama_map)
|
|
|
|
|
|
2025-05-08 12:39:44 +08:00
|
|
|
def regist_qwen_omni(self):
|
|
|
|
|
omni_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'thinker_config.text_config.hidden_size',
|
|
|
|
|
'head_dim': 'thinker_config.text_config.head_dim',
|
|
|
|
|
'num_attention_heads': 'thinker_config.text_config.num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'thinker_config.text_config.num_hidden_layers',
|
|
|
|
|
'num_key_value_heads': 'thinker_config.text_config.num_key_value_heads',
|
|
|
|
|
'rope_theta': 'thinker_config.text_config.rope_theta',
|
|
|
|
|
'rope_scaling': 'thinker_config.text_config.rope_scaling'
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'thinker.lm_head',
|
|
|
|
|
'embed_': 'thinker.model.embed_tokens',
|
|
|
|
|
'blocks_': 'thinker.model.layers',
|
|
|
|
|
'final_layernorm_': 'thinker.model.norm',
|
|
|
|
|
'visual': 'thinker.visual',
|
|
|
|
|
'audio': 'thinker.audio_tower',
|
|
|
|
|
'talker': 'talker',
|
|
|
|
|
'token2wav': 'token2wav'
|
|
|
|
|
},
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': self.default_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('qwen2_5_omni', omni_map)
|
|
|
|
|
|
2025-01-22 14:47:50 +08:00
|
|
|
def regist_qwen(self):
|
|
|
|
|
qwen_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'hidden_size',
|
|
|
|
|
'num_attention_heads': 'num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'num_hidden_layers',
|
|
|
|
|
'rope_theta': 'rotary_emb_base',
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'transformer.wte',
|
|
|
|
|
'blocks_': 'transformer.h',
|
|
|
|
|
'final_layernorm_': 'transformer.ln_f',
|
|
|
|
|
'visual': 'transformer.visual'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'ln_1',
|
|
|
|
|
'post_attention_layernorm': 'ln_2'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'qkv_proj': 'c_attn',
|
|
|
|
|
'o_proj': 'c_proj'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('qwen', qwen_map)
|
|
|
|
|
|
2025-04-28 11:38:44 +08:00
|
|
|
def regist_qwen3(self):
|
|
|
|
|
qwen3_attention = {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj',
|
|
|
|
|
'q_norm': 'q_norm',
|
|
|
|
|
'k_norm': 'k_norm'
|
|
|
|
|
}
|
|
|
|
|
qwen3_map = {
|
|
|
|
|
'config': self.default_config,
|
|
|
|
|
'model': self.defualt_model,
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': qwen3_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('qwen3', qwen3_map)
|
|
|
|
|
|
2025-05-23 15:21:41 +08:00
|
|
|
def regist_qwen3_moe(self):
|
|
|
|
|
qwen3_attention = {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj',
|
|
|
|
|
'q_norm': 'q_norm',
|
|
|
|
|
'k_norm': 'k_norm'
|
|
|
|
|
}
|
|
|
|
|
qwen3_mlp = {
|
|
|
|
|
'num_experts': 'num_experts',
|
|
|
|
|
'top_k': 'top_k',
|
|
|
|
|
'norm_topk_prob': 'norm_topk_prob',
|
|
|
|
|
'gate': 'gate',
|
|
|
|
|
'experts': 'experts'
|
|
|
|
|
}
|
|
|
|
|
qwen3_moe_map = {
|
|
|
|
|
'config': self.default_config,
|
|
|
|
|
'model': self.defualt_model,
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': qwen3_attention,
|
|
|
|
|
'mlp': qwen3_mlp,
|
|
|
|
|
}
|
|
|
|
|
self.regist('qwen3_moe', qwen3_moe_map)
|
|
|
|
|
|
2025-01-22 14:47:50 +08:00
|
|
|
def regist_glm(self):
|
|
|
|
|
glm_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'hidden_size',
|
|
|
|
|
'num_attention_heads': 'num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'num_layers'
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'transformer.word_embeddings',
|
|
|
|
|
'blocks_': 'transformer.layers',
|
|
|
|
|
'final_layernorm_': 'transformer.final_layernorm',
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'attention',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'qkv_proj': 'query_key_value',
|
|
|
|
|
'o_proj': 'dense'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('chatglm', glm_map)
|
|
|
|
|
|
|
|
|
|
def regist_glm2(self):
|
|
|
|
|
glm2_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'hidden_size',
|
|
|
|
|
'num_attention_heads': 'num_attention_heads',
|
|
|
|
|
'num_key_value_heads': 'multi_query_group_num',
|
|
|
|
|
'num_hidden_layers': 'num_layers',
|
2025-03-17 21:44:35 +08:00
|
|
|
'rope_ratio': 'rope_ratio'
|
2025-01-22 14:47:50 +08:00
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'transformer.output_layer',
|
|
|
|
|
'embed_': 'transformer.embedding.word_embeddings',
|
|
|
|
|
'blocks_': 'transformer.encoder.layers',
|
|
|
|
|
'final_layernorm_': 'transformer.encoder.final_layernorm',
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attention',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'qkv_proj': 'query_key_value',
|
|
|
|
|
'o_proj': 'dense'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('chatglm2', glm2_map)
|
|
|
|
|
|
|
|
|
|
def regist_phi(self):
|
|
|
|
|
phi_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'n_embd',
|
|
|
|
|
'num_attention_heads': 'n_head',
|
|
|
|
|
'num_hidden_layers': 'n_layer',
|
|
|
|
|
'rotary_dim': 'rotary_dim'
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'lm_head.linear',
|
|
|
|
|
'embed_': 'transformer.embd.wte',
|
|
|
|
|
'blocks_': 'transformer.h',
|
|
|
|
|
'final_layernorm_': 'lm_head.ln',
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'mixer',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'ln',
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'qkv_proj': 'Wqkv',
|
|
|
|
|
'o_proj': 'out_proj'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('phi-msft', phi_map)
|
2025-05-23 15:21:41 +08:00
|
|
|
|
|
|
|
|
def regist_phi3(self):
|
|
|
|
|
phi3_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'hidden_size',
|
|
|
|
|
'num_attention_heads': 'num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'num_hidden_layers',
|
|
|
|
|
'rope_theta': 'rope_theta',
|
|
|
|
|
'head_dim': 'head_dim',
|
|
|
|
|
'num_key_value_heads': 'num_key_value_heads',
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'model.embed_tokens',
|
|
|
|
|
'blocks_': 'model.layers',
|
|
|
|
|
'final_layernorm_': 'model.norm'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'qkv_proj': 'qkv_proj',
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
# self.regist('phi3', phi3_map)
|
|
|
|
|
|
2025-04-28 11:38:44 +08:00
|
|
|
def regist_intervl(self):
|
|
|
|
|
intervl_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'llm_config.hidden_size',
|
|
|
|
|
'num_attention_heads': 'llm_config.num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'llm_config.num_hidden_layers',
|
|
|
|
|
'rope_theta': 'llm_config.rope_theta',
|
|
|
|
|
'head_dim': 'llm_config.head_dim',
|
|
|
|
|
'num_key_value_heads': 'llm_config.num_key_value_heads',
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'language_model.lm_head',
|
|
|
|
|
'embed_': 'language_model.model.embed_tokens',
|
|
|
|
|
'blocks_': 'language_model.model.layers',
|
|
|
|
|
'final_layernorm_': 'language_model.model.norm',
|
|
|
|
|
'visual': 'vision_model'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('internvl_chat', intervl_map)
|
2025-01-22 14:47:50 +08:00
|
|
|
|
|
|
|
|
def regist_gemma2(self):
|
|
|
|
|
gemma2_decoder = copy.deepcopy(self.default_decoder)
|
|
|
|
|
gemma2_decoder['pre_feedforward_layernorm'] = 'pre_feedforward_layernorm'
|
|
|
|
|
gemma2_decoder['post_feedforward_layernorm'] = 'post_feedforward_layernorm'
|
|
|
|
|
gemma2_map = {
|
2025-02-24 11:44:27 +08:00
|
|
|
'config': self.default_config,
|
2025-01-22 14:47:50 +08:00
|
|
|
'model': self.defualt_model,
|
|
|
|
|
'decoder': gemma2_decoder,
|
|
|
|
|
'attention': self.default_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('gemma2', gemma2_map)
|
|
|
|
|
|
2025-05-23 15:21:41 +08:00
|
|
|
def regist_gemma3(self):
|
|
|
|
|
gemma3_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'text_config.hidden_size',
|
|
|
|
|
'head_dim': 'text_config.head_dim',
|
|
|
|
|
'num_attention_heads': 'text_config.num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'text_config.num_hidden_layers',
|
|
|
|
|
'num_key_value_heads': 'text_config.num_key_value_heads',
|
|
|
|
|
'rope_theta': 'text_config.rope_theta',
|
|
|
|
|
|
|
|
|
|
'image_size': 'vision_config.image_size',
|
|
|
|
|
'num_channels': 'vision_config.num_channels',
|
|
|
|
|
|
|
|
|
|
'model_type': 'model_type',
|
|
|
|
|
'image_token_index': 'image_token_index', #'<image_soft_token>'
|
|
|
|
|
'boi_token_index': 'boi_token_index', #'<start_of_image>'
|
|
|
|
|
'eoi_token_index': 'eoi_token_index', #'<end_of_image>'
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'language_model.lm_head',
|
|
|
|
|
'embed_': 'language_model.model.embed_tokens',
|
|
|
|
|
'blocks_': 'language_model.model.layers',
|
|
|
|
|
'final_layernorm_': 'language_model.model.norm',
|
|
|
|
|
'vision_tower': 'vision_tower',
|
|
|
|
|
'visual': 'vision_tower.vision_model',
|
|
|
|
|
'multi_modal_projector': 'multi_modal_projector'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm',
|
|
|
|
|
'pre_feedforward_layernorm': 'pre_feedforward_layernorm',
|
|
|
|
|
'post_feedforward_layernorm': 'post_feedforward_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj',
|
|
|
|
|
'q_norm': 'q_norm',
|
|
|
|
|
'k_norm': 'k_norm'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('gemma3', gemma3_map)
|
|
|
|
|
|
|
|
|
|
def regist_gemma3_text(self):
|
|
|
|
|
gemma3_text_map = {
|
|
|
|
|
'config': {
|
|
|
|
|
'hidden_size': 'hidden_size',
|
|
|
|
|
'head_dim': 'head_dim',
|
|
|
|
|
'num_attention_heads': 'num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'num_hidden_layers',
|
|
|
|
|
'num_key_value_heads': 'num_key_value_heads',
|
|
|
|
|
'rope_theta': 'rope_theta',
|
|
|
|
|
'max_position_embeddings': 'max_position_embeddings',
|
|
|
|
|
'model_type': 'model_type',
|
|
|
|
|
'vocab_size': 'vocab_size',
|
|
|
|
|
'bos_token_id': 'bos_token_id',
|
|
|
|
|
'eos_token_id': 'eos_token_id',
|
|
|
|
|
'max_position_embeddings': 'max_position_embeddings',
|
|
|
|
|
'pad_token_id': 'pad_token_id',
|
|
|
|
|
},
|
|
|
|
|
'model': {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'model.embed_tokens',
|
|
|
|
|
'blocks_': 'model.layers',
|
|
|
|
|
'final_layernorm_': 'model.norm',
|
|
|
|
|
'rotary_emb': 'model.rotary_emb',
|
|
|
|
|
'rotary_emb_local': 'model.rotary_emb_local'
|
|
|
|
|
},
|
|
|
|
|
'decoder': {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm',
|
|
|
|
|
'pre_feedforward_layernorm': 'pre_feedforward_layernorm',
|
|
|
|
|
'post_feedforward_layernorm': 'post_feedforward_layernorm'
|
|
|
|
|
},
|
|
|
|
|
'attention': {
|
|
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj',
|
|
|
|
|
'q_norm': 'q_norm',
|
|
|
|
|
'k_norm': 'k_norm'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self.regist('gemma3_text', gemma3_text_map)
|
|
|
|
|
|
2025-01-22 14:47:50 +08:00
|
|
|
def register_openelm(self):
|
|
|
|
|
openelm_config = {
|
|
|
|
|
'hidden_size': 'model_dim',
|
|
|
|
|
'head_dim': 'head_dim',
|
|
|
|
|
'num_attention_heads': 'num_query_heads',
|
|
|
|
|
'num_hidden_layers': 'num_transformer_layers',
|
|
|
|
|
'num_key_value_heads': 'num_kv_heads',
|
|
|
|
|
'rope_theta': 'rope_freq_constant'
|
|
|
|
|
}
|
|
|
|
|
openelm_model = {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'transformer.token_embeddings',
|
|
|
|
|
'blocks_': 'transformer.layers',
|
|
|
|
|
'final_layernorm_': 'transformer.norm'
|
|
|
|
|
}
|
|
|
|
|
openelm_decoder = {
|
|
|
|
|
'self_attn': 'attn',
|
|
|
|
|
'mlp': 'ffn',
|
|
|
|
|
'input_layernorm': 'attn_norm',
|
|
|
|
|
'post_attention_layernorm': 'ffn_norm'
|
|
|
|
|
}
|
|
|
|
|
openelm_attention = {
|
|
|
|
|
'qkv_proj': 'qkv_proj',
|
|
|
|
|
'o_proj': 'out_proj',
|
|
|
|
|
'q_norm': 'q_norm',
|
|
|
|
|
'k_norm': 'k_norm'
|
|
|
|
|
}
|
|
|
|
|
openelm_map = {
|
|
|
|
|
'config': openelm_config,
|
|
|
|
|
'model': openelm_model,
|
|
|
|
|
'decoder': openelm_decoder,
|
|
|
|
|
'attention': openelm_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('openelm', openelm_map)
|
|
|
|
|
|
2025-05-23 15:21:41 +08:00
|
|
|
def regist_idefics3(self):
|
|
|
|
|
idefics3_config = {
|
|
|
|
|
'hidden_size': 'text_config.hidden_size',
|
|
|
|
|
'head_dim': 'text_config.head_dim',
|
|
|
|
|
'num_attention_heads': 'text_config.num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'text_config.num_hidden_layers',
|
|
|
|
|
'num_key_value_heads': 'text_config.num_key_value_heads',
|
|
|
|
|
'rope_theta': 'text_config.rope_theta',
|
|
|
|
|
'rope_scaling': 'text_config.rope_scaling'
|
|
|
|
|
}
|
|
|
|
|
idefics3_model = {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'model.text_model.embed_tokens',
|
|
|
|
|
'blocks_': 'model.text_model.layers',
|
|
|
|
|
'final_layernorm_': 'model.text_model.norm',
|
|
|
|
|
'visual': 'model.vision_model'
|
|
|
|
|
}
|
|
|
|
|
idefics3_map = {
|
|
|
|
|
'config': idefics3_config,
|
|
|
|
|
'model': idefics3_model,
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': self.default_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('idefics3', idefics3_map)
|
|
|
|
|
self.regist('smolvlm', idefics3_map)
|
|
|
|
|
|
|
|
|
|
def regist_fastvlm(self):
|
|
|
|
|
fastvlm_model = copy.deepcopy(self.defualt_model)
|
|
|
|
|
fastvlm_model['visual'] = 'model.vision_tower'
|
|
|
|
|
fastvlm_map = {
|
|
|
|
|
'config': self.default_config,
|
|
|
|
|
'model': fastvlm_model,
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': self.default_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('llava_qwen2', fastvlm_map)
|
|
|
|
|
|
|
|
|
|
def regist_qwen2vl(self):
|
|
|
|
|
if TRANSFORMERS_VERSION <= '4.52.1':
|
|
|
|
|
return
|
|
|
|
|
qwen2vl_model = {
|
|
|
|
|
'lm_': 'model.lm_head',
|
|
|
|
|
'embed_': 'model.language_model.embed_tokens',
|
|
|
|
|
'blocks_': 'model.language_model.layers',
|
|
|
|
|
'final_layernorm_': 'model.language_model.norm',
|
|
|
|
|
'visual': 'model.visual'
|
|
|
|
|
}
|
|
|
|
|
qwen2vl_map = {
|
|
|
|
|
'config': self.default_config,
|
|
|
|
|
'model': qwen2vl_model,
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': self.default_attention
|
|
|
|
|
}
|
|
|
|
|
self.regist('qwen2_vl', qwen2vl_map)
|
|
|
|
|
self.regist('qwen2_5_vl', qwen2vl_map)
|
|
|
|
|
|
2025-01-22 14:47:50 +08:00
|
|
|
def defualt_map(self):
|
|
|
|
|
# default map is `LlamaForCausalLM`
|
|
|
|
|
self.config_key = 'config'
|
|
|
|
|
self.model_key = 'model'
|
|
|
|
|
self.decoder_key = 'decoder'
|
|
|
|
|
self.attention_key = 'attention'
|
|
|
|
|
self.default_config = {
|
|
|
|
|
'hidden_size': 'hidden_size',
|
2025-02-24 11:44:27 +08:00
|
|
|
'head_dim': 'head_dim',
|
2025-01-22 14:47:50 +08:00
|
|
|
'num_attention_heads': 'num_attention_heads',
|
|
|
|
|
'num_hidden_layers': 'num_hidden_layers',
|
|
|
|
|
'num_key_value_heads': 'num_key_value_heads',
|
2025-05-08 12:39:44 +08:00
|
|
|
'rope_theta': 'rope_theta',
|
|
|
|
|
'rope_scaling': 'rope_scaling'
|
2025-01-22 14:47:50 +08:00
|
|
|
}
|
|
|
|
|
self.defualt_model = {
|
|
|
|
|
'lm_': 'lm_head',
|
|
|
|
|
'embed_': 'model.embed_tokens',
|
|
|
|
|
'blocks_': 'model.layers',
|
|
|
|
|
'final_layernorm_': 'model.norm',
|
|
|
|
|
'visual': 'visual'
|
|
|
|
|
}
|
|
|
|
|
self.default_decoder = {
|
|
|
|
|
'self_attn': 'self_attn',
|
|
|
|
|
'mlp': 'mlp',
|
|
|
|
|
'input_layernorm': 'input_layernorm',
|
|
|
|
|
'post_attention_layernorm': 'post_attention_layernorm'
|
|
|
|
|
}
|
|
|
|
|
self.default_attention = {
|
2025-05-23 15:21:41 +08:00
|
|
|
'qkv_proj': 'qkv_proj',
|
2025-01-22 14:47:50 +08:00
|
|
|
'q_proj': 'q_proj',
|
|
|
|
|
'k_proj': 'k_proj',
|
|
|
|
|
'v_proj': 'v_proj',
|
|
|
|
|
'o_proj': 'o_proj'
|
|
|
|
|
}
|
|
|
|
|
self.default_map = {
|
|
|
|
|
'config': self.default_config,
|
|
|
|
|
'model': self.defualt_model,
|
|
|
|
|
'decoder': self.default_decoder,
|
|
|
|
|
'attention': self.default_attention
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def do_map(dst, src, map):
|
|
|
|
|
for dst_attr, src_attr in map.items():
|
|
|
|
|
attributes = src_attr.split('.')
|
|
|
|
|
obj = src
|
|
|
|
|
for attr in attributes:
|
|
|
|
|
if hasattr(obj, attr):
|
|
|
|
|
obj = getattr(obj, attr)
|
|
|
|
|
else:
|
|
|
|
|
obj = None
|
|
|
|
|
break
|
|
|
|
|
setattr(dst, dst_attr, obj)
|