pytorch中文语言模型bert预训练代码

2020 年 7 月 22 日 AINLP

ACL2020 Best Paper有一篇论文提名奖,Don’t Stop Pretraining: Adapt Language Models to Domains and Tasks》。这篇论文做了很多语言模型预训练的实验,系统的分析了语言模型预训练对子任务的效果提升情况。有几个主要结论:

  • 在目标领域的数据集上继续预训练(DAPT)可以提升效果;目标领域的语料与RoBERTa的原始预训练语料越不相关,DAPT效果则提升更明显。

  • 在具体任务的数据集上继续预训练(TAPT)可以十分“廉价”地提升效果。

  • 结合二者(先进行DAPT,再进行TAPT)可以进一步提升效果。

  • 如果能获取更多的、任务相关的无标注数据继续预训练(Curated-TAPT),效果则最佳。

  • 如果无法获取更多的、任务相关的无标注数据,采取一种十分轻量化的简单数据选择策略,效果也会提升。

知乎专栏《高能NLP》

https://zhuanlan.zhihu.com/p/149210123


虽然在bert上语言模型预训练在算法比赛中已经是一个稳定的上分操作。但是上面这篇文章难能可贵的是对这个操作进行了系统分析。大部分中文语言模型都是在tensorflow上训练的,一个常见例子是中文roberta项目。可以参考

https://github.com/brightmart/roberta_zh


使用pytorch进行中文bert语言模型预训练的例子比较少。在huggingface的Transformers中,有一部分代码支持语言模型预训练(不是很丰富,很多功能都不支持比如wwm)。为了用最少的代码成本完成bert语言模型预训练,本文借鉴了里面的一些现成代码。也尝试分享一下使用pytorch进行语言模型预训练的一些经验。主要有三个常见的中文bert语言模型

  1. bert-base-chinese

  2. roberta-wwm-ext

  3. ernie


1 bert-base-chinese


(https://huggingface.co/bert-base-chinese)


这是最常见的中文bert语言模型,基于中文维基百科相关语料进行预训练。把它作为baseline,在领域内无监督数据进行语言模型预训练很简单。只需要使用官方给的例子就好。

https://github.com/huggingface/transformers/tree/master/examples/language-modeling

(本文使用的transformers更新到3.0.2)

方法就是

python run_language_modeling.py \    --output_dir=output \    --model_type=bert \    --model_name_or_path=bert-base-chinese \    --do_train \    --train_data_file=$TRAIN_FILE \    --do_eval \    --eval_data_file=$TEST_FILE \    --mlm

其中$TRAIN_FILE 代表领域相关中文语料地址。


2 roberta-wwm-ext

(https://github.com/ymcui/Chinese-BERT-wwm)


哈工大讯飞联合实验室发布的预训练语言模型。预训练的方式是采用roberta类似的方法,比如动态mask,更多的训练数据等等。在很多任务中,该模型效果要优于bert-base-chinese。


对于中文roberta类的pytorch模型,使用方法如下

import torchfrom transformers import BertTokenizer, BertModeltokenizer = BertTokenizer.from_pretrained("hfl/chinese-roberta-wwm-ext")roberta = BertModel.from_pretrained("hfl/chinese-roberta-wwm-ext")

切记不可使用官方推荐的

tokenizer = AutoTokenizer.from_pretrained("hfl/chinese-roberta-wwm-ext")model = AutoModel.from_pretrained("hfl/chinese-roberta-wwm-ext")


因为中文roberta类的配置文件比如vocab.txt,都是采用bert的方法设计的。英文roberta模型读取配置文件的格式默认是vocab.json。对于一些英文roberta模型,倒是可以通过AutoModel自动读取。这就解释了huggingface的模型库的中文roberta示例代码为什么跑不通。https://huggingface.co/models?


如果要基于上面的代码run_language_modeling.py继续预训练roberta。还需要做两个改动。

  • 下载roberta-wwm-ext到本地目录hflroberta,在config.json中修改“model_type”:"roberta"为"model_type":"bert"。

  • 对上面的run_language_modeling.py中的AutoModel和AutoTokenizer都进行替换为BertModel和BertTokenizer。



    再运行命令

    python run_language_modeling_roberta.py \    --output_dir=output \    --model_type=bert \    --model_name_or_path=hflroberta \    --do_train \    --train_data_file=$TRAIN_FILE \    --do_eval \    --eval_data_file=$TEST_FILE \    --mlm


    3 ernie

    (https://github.com/nghuyong/ERNIE-Pytorch)


    ernie是百度发布的基于百度知道贴吧等中文语料结合实体预测等任务生成的预训练模型。这个模型的准确率在某些任务上要优于bert-base-chinese和roberta。如果基于ernie1.0模型做领域数据预训练的话只需要一步修改。

    • 下载ernie1.0到本地目录ernie,在config.json中增加字段"model_type":"bert"。

    python run_language_modeling.py \    --output_dir=output \    --model_type=bert \    --model_name_or_path=ernie \    --do_train \    --train_data_file=$TRAIN_FILE \    --do_eval \    --eval_data_file=$TEST_FILE \    --mlm


    最后,huggingface项目中语言模型预训练用mask方式如下。仍是按照15%的数据随机mask然后预测自身。如果要做一些高级操作比如whole word masking或者实体预测,可以自行修改transformers.DataCollatorForLanguageModeling。



    本文实验代码库。拿来即用!

    https://github.com/zhusleep/pytorch_chinese_lm_pretrain


    推荐阅读

    这个NLP工具,玩得根本停不下来

    征稿启示| 200元稿费+5000DBC(价值20个小时GPU算力)

    完结撒花!李宏毅老师深度学习与人类语言处理课程视频及课件(附下载)

    从数据到模型,你可能需要1篇详实的pytorch踩坑指南

    如何让Bert在finetune小数据集时更“稳”一点

    模型压缩实践系列之——bert-of-theseus,一个非常亲民的bert压缩方法

    文本自动摘要任务的“不完全”心得总结番外篇——submodular函数优化

    Node2Vec 论文+代码笔记

    模型压缩实践收尾篇——模型蒸馏以及其他一些技巧实践小结

    中文命名实体识别工具(NER)哪家强?

    学自然语言处理,其实更应该学好英语

    斯坦福大学NLP组Python深度学习自然语言处理工具Stanza试用

    关于AINLP

    AINLP 是一个有趣有AI的自然语言处理社区,专注于 AI、NLP、机器学习、深度学习、推荐算法等相关技术的分享,主题包括文本摘要、智能问答、聊天机器人、机器翻译、自动生成、知识图谱、预训练模型、推荐系统、计算广告、招聘信息、求职经验分享等,欢迎关注!加技术交流群请添加AINLPer(id:ainlper),备注工作/研究方向+加群目的。


    阅读至此了,分享、点赞、在看三选一吧🙏

    登录查看更多
    3

    相关内容

    【ICML2020】统一预训练伪掩码语言模型
    专知会员服务
    25+阅读 · 2020年7月23日
    【北航】面向自然语言处理的预训练技术研究综述
    专知会员服务
    112+阅读 · 2020年4月23日
    Transformer文本分类代码
    专知会员服务
    116+阅读 · 2020年2月3日
    【文章|BERT三步使用NLP迁移学习】NLP Transfer Learning In 3 Steps
    计算机视觉最佳实践、代码示例和相关文档
    专知会员服务
    18+阅读 · 2019年10月9日
    【Github】GPT2-Chinese:中文的GPT2训练代码
    AINLP
    52+阅读 · 2019年8月23日
    一大批中文(BERT等)预训练模型等你认领!
    PaperWeekly
    14+阅读 · 2019年6月25日
    使用 Bert 预训练模型文本分类(内附源码)
    数据库开发
    102+阅读 · 2019年3月12日
    NLP - 基于 BERT 的中文命名实体识别(NER)
    AINLP
    466+阅读 · 2019年2月10日
    资源 | 最强预训练模型BERT的Pytorch实现(非官方)
    全球人工智能
    7+阅读 · 2018年10月18日
    Arxiv
    6+阅读 · 2019年8月22日
    Arxiv
    11+阅读 · 2019年6月19日
    Arxiv
    21+阅读 · 2019年3月25日
    Arxiv
    4+阅读 · 2019年2月18日
    Conditional BERT Contextual Augmentation
    Arxiv
    8+阅读 · 2018年12月17日
    Music Transformer
    Arxiv
    5+阅读 · 2018年12月12日
    VIP会员
    相关论文
    Arxiv
    6+阅读 · 2019年8月22日
    Arxiv
    11+阅读 · 2019年6月19日
    Arxiv
    21+阅读 · 2019年3月25日
    Arxiv
    4+阅读 · 2019年2月18日
    Conditional BERT Contextual Augmentation
    Arxiv
    8+阅读 · 2018年12月17日
    Music Transformer
    Arxiv
    5+阅读 · 2018年12月12日
    Top
    微信扫码咨询专知VIP会员