# tensorflow权重链接:https://github.com/ZhuiyiTechnology/GAU-alpha # 这里直接映射到GAU_alpha的结构上了,因此不需要mapping import torch import tensorflow as tf import json tf_path = 'E:/pretrain_ckpt/gau/sushen@chinese_GAU-alpha-char_L-24_H-768_tf/bert_model.ckpt' torch_state_dict = {} ts = tf.train.load_variable(tf_path, 'bert/embeddings/word_embeddings') torch_state_dict['embeddings.word_embeddings.weight'] = torch.from_numpy(ts) torch_state_dict['mlmDecoder.weight'] = torch.from_numpy(ts) ts = tf.train.load_variable(tf_path, 'bert/embeddings/token_type_embeddings') torch_state_dict['embeddings.segment_embeddings.weight'] = torch.from_numpy(ts) for i in range(24): ts = tf.train.load_variable(tf_path, f'GAU_alpha/encoder/layer_{i}/gau/i_dense/kernel') torch_state_dict[f'encoderLayer.{i}.gau.i_dense.weight'] = torch.from_numpy(ts.T) ts = tf.train.load_variable(tf_path, f'GAU_alpha/encoder/layer_{i}/gau/o_dense/kernel') torch_state_dict[f'encoderLayer.{i}.gau.o_dense.weight'] = torch.from_numpy(ts.T) ts1 = tf.train.load_variable(tf_path, f'GAU_alpha/encoder/layer_{i}/gau/q_scaleoffset/gamma') ts2 = tf.train.load_variable(tf_path, f'GAU_alpha/encoder/layer_{i}/gau/k_scaleoffset/gamma') ts = torch.stack([torch.from_numpy(ts1), torch.from_numpy(ts2)], dim=0) torch_state_dict[f'encoderLayer.{i}.gau.offsetscale.gamma'] = ts dir_path = 'E:/pretrain_ckpt/gau/sushen@chinese_GAU-alpha-char_L-24_H-768_torch/' torch.save(torch_state_dict, dir_path + 'pytorch_model.bin')