mt5模型从spiece.model中找寻出vocab

mt5模型文件地址
mt5模型由于vocab词汇表中的词汇过多,采用从spiece.model之中读取的方式,读取过程如下

import sentencepiece as spm

spm_path = '/home/xiaoguzai/模型/mt5/spiece.model'
# 加载训练好的模型,切分文本
sp = spm.SentencePieceProcessor(model_file=spm_path)

# 编码 text -> id
result = sp.encode(['This is a test', 'Hello world'], out_type=int)
print(result)
result = sp.encode(['This is a test', 'Hello world'], out_type=str)
print(result)

# 解码 id -> text
result = sp.decode([285, 46, 10, 170, 382])
print(result)
result = sp.decode(['▁This', '▁is', '▁a', '▁t', 'est'])
print(result)

# 采样
for _ in range(10):
    result = sp.encode('This is a test', out_type=str, enable_sampling=True, alpha=0.1, nbest_size=-1)
    print(result)

# 其它常用方法
sp.get_piece_size()
sp.id_to_piece(2)
sp.id_to_piece([2, 3, 4])
sp.piece_to_id('<s>')
sp.piece_to_id(['</s>', '\r', '▁'])

其中sp.get_piece_size() = 250100,可以看出来词汇表的总词汇量为250100个,词汇量巨大,所以这里选用spiece.model模型的方式进行打包
使用spm进行切词操作

print(sp.EncodeAsPieces("食材上不会有这样的纠结"))

切分的结果

['▁', '食材', '上', '不会', '有', '这样的', '纠', '结']
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RoBERTa文预训练模型 概述 文预训练RoBERTa模型 RoBERTa是BERT的改进版,通过改进训练任务和数据生成方式、训练更久、使用更大批次、使用更多数据等获得了State of The Art的效果;可以用Bert直接加载。 本项目是用TensorFlow实现了在大规模文上RoBERTa的预训练,也会提供PyTorch的预训练模型和加载方式。 文预训练RoBERTa模型-下载 6层RoBERTa体验版 RoBERTa-zh-Layer6: Google Drive 或 百度网盘,TensorFlow版本,Bert 直接加载, 大小为200M 推荐 RoBERTa-zh-Large 通过验证 RoBERTa-zh-Large: Google Drive 或 百度网盘 ,TensorFlow版本,Bert 直接加载 RoBERTa-zh-Large: Google Drive 或 百度网盘 ,PyTorch版本,Bert的PyTorch版直接加载 RoBERTa 24/12层版训练数据:30G原始文本,近3亿个句子,100亿个文字(token),产生了2.5亿个训练数据(instance);覆盖新闻、社区问答、多个百科数据等; 本项目与文预训练24层XLNet模型 XLNet_zh项目,使用相同的训练数据。 RoBERTa_zh_L12: Google Drive 或 百度网盘 TensorFlow版本,Bert 直接加载 RoBERTa_zh_L12: Google Drive 或百度网盘 PyTorch版本,Bert的PyTorch版直接加载 Roberta_l24_zh_base TensorFlow版本,Bert 直接加载 24层base版训练数据:10G文本,包含新闻、社区问答、多个百科数据等 什么是RoBERTa: 一种强大的用于预训练自然语言处理(NLP)系统的优化方法,改进了Transformers或BERT的双向编码器表示形式,这是Google在2018年发布的自监督方法。 RoBERTa在广泛使用的NLP基准通用语言理解评估(GLUE)上产生最先进的结果。 该模型在MNLI,QNLI,RTE,STS-B和RACE任务上提供了最先进的性能,并在GLUE基准上提供了可观的性能改进。 RoBERTa得分88.5,在GLUE排行榜上排名第一,与之前的XLNet-Large的表现相当。 效果测试与对比 Performance 互联网新闻情感分析:CCF-Sentiment-Analysis 模型 线上F1 BERT 80.3 Bert-wwm-ext 80.5 XLNet 79.6 Roberta-mid 80.5 Roberta-large (max_seq_length=512, split_num=1) 81.25 注:数据来源于guoday的开源项目;数据集和任务介绍见:CCF互联网新闻情感分析 自然语言推断:XNLI 模型 开发集 测试集 BERT 77.8 (77.4) 77.8 (77.5) ERNIE 79.7 (79.4) 78.6 (78.2) BERT-wwm 79.0 (78.4) 78.2 (78.0) BERT-wwm-ext 79.4 (78.6) 78.7 (78.3) XLNet 79.2 78.7 RoBERTa-zh-base 79.8 78.8 RoBERTa-zh-Large 80.2 (80.0) 79.9 (79.5) 注:RoBERTa_l24_zh,只跑了两次,Performance可能还会提升; BERT-wwm-ext来自于这里;XLNet来自于这里; RoBERTa-zh-base,指12层RoBERTa模型 问题匹配语任务:LCQMC(Sentence Pair Matching) 模型 开发集(Dev) 测试集(Test) BERT 89.4(88.4) 86.9(86.4) ERNIE 89.8 (89.6) 87.2 (87.0) BERT-wwm 89.4 (89.2) 87.0 (86.8) BERT-wwm-ext - - RoBERTa-zh-base 88.7 87.0 RoBERTa-zh-Large 89.9(89.6) 87.2(86.7) RoBERTa-zh-Large(20w_steps) 89.7 87.0 注:RoBERTa_l24_zh,只跑了两次,Performance可能还会提升。保持训练轮次和论文一致: 阅读理解测试 目前阅读理解类问题bert和roberta最优参数均为epoch2, batch=32, lr=3e-5, warmup=0.1 cmrc20
`model.wv.vocab` 是用于获取 Word2Vec 模型的所有单词的词汇表。它返回一个字典对象,其包含模型所有单词的名称和对应的 Vocab 对象。每个 Vocab 对象包含了单词的词频、索引和其他属性。 下面是一个简单的例子,展示如何使用 `model.wv.vocab` 函数: ```python from gensim.models import Word2Vec # 加载模型 model = Word2Vec.load('model.bin') # 获取所有单词的词汇表 vocab = model.wv.vocab # 打印前 10 个单词及其对应的 Vocab 对象 for word in list(vocab)[:10]: print(word, vocab[word]) ``` 输出结果会类似于这样: ``` the <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1dd8> of <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1e10> and <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1e48> in <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1e80> to <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1eb8> a <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1ef0> that <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1f28> is <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1f60> was <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1f98> for <gensim.models.keyedvectors.Vocab object at 0x7f7f5e3e1fd0> ``` 注意,`model.wv.vocab` 函数返回的是一个字典对象,其的键是单词名,值是对应的 Vocab 对象。要访问 Vocab 对象的属性,可以通过键来获取相应的 Vocab 对象,然后再访问其属性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值