Press "Enter" to skip to content

飞桨带你了解:基于百科类数据训练的 ELMo 中文预训练模型

在NLP世界里,有一支很重要的家族,英文叫做LARK(LAnguage Representations Kit),翻译成中文是语言表示工具箱。目前LARK家族最新最重要的三种算法,分别是ELMo,BERT和ERNIE。

 

你一定不知道,这三个普通的名字,竟然包含着一个有趣的秘密。

 

真相,即将揭开!

 

 

我们先从算法模型的名字寻找一些蛛丝马迹

 

第一位,ELMo:

 

来自英文Embedding from Language Models 的缩写,来自论文名为Deep contextualized word representation

 

第二位,BERT:

 

来自英文Bidirectional Encoder Representations from Transformers的缩写,来自论文名为Pre-training of Deep Bidirectional Transformers for LanguageUnderstanding

 

第三位,ERNIE:

 

来自英文Enhanced Representation through kNowledge IntEgration) 的缩,来自论文名为Enhanced Representation through Knowledge Integration

 

看完了,是不是,还是一头雾水,哪里有什幺秘密?

 

 

不卖关子了,直接上图!

 

 

What??

 

再回头看看,你还记得那三个算法的名字幺?

 

ELMo,BERT,ERNIE

 

竟然都是美国经典动画片,《Sesame Street(芝麻街)》里面的卡通人物!!!

 

好吧,如果你说,没看过这个动画片,没感觉啊。那我举个例子,如果把《芝麻街》类比成中文《舒克和贝塔》。那幺,第一篇论文把模型取做“舒克”,第二篇很有爱的就叫做“贝塔”,第三篇就硬把模型叫做“皮皮鲁”,也许不久的下一个模型就命名为“鲁西西”啦。

 

谁说科学家们很无聊,是不是也很童趣?

 

好了,扯远了,今天我们先给大家介绍LARK家族的ELMo! 提出它的论文获得2018年NAACL最佳paper,它在NLP领域可是有着响当当的名头,让我们来认识它!

 

ELMo 模型简介

 

ELMo(Embeddings from Language Models) 是重要的通用语义表示模型之一,以双向 LSTM 为网路基本组件,以 Language Model 为训练目标,通过预训练得到通用的语义表示,将通用的语义表示作为 Feature 迁移到下游 NLP 任务中,会显着提升下游任务的模型性能。

 

 

ELMo模型核心是一个双层双向的LSTM网络,与传统的word2vec算法中词向量一成不变相比,ELMo会根据上下文改变语义embedding。

 

一个简单的例子就是 “苹果”的词向量:

 

句子1:“我 买了 1斤 苹果”

 

句子2:“我 新 买了 1个 苹果 X”

 

在word2vec算法中,“苹果”的词向量固定,无法区分这两句话的区别,而ELMo可以解决语言中的二义性问题,可以带来性能的显着提升。

 

ELMo 项目的飞桨(Paddle Paddle )实现

 

为了方便广大的开发者,飞桨(PaddlePaddle) 完成了ELMo的开源实现(依赖于 Paddle Fluid 1.4),发布要点如下。

 

注意啦,下面划重点!!!

 

基于百科类数据训练的ELMo中文预训练模型。

 

完整支持ELMo多卡训练,底层算子优化,训练速度比主流实现快约1倍。

 

下游任务的性能明显提升:LAC 任务加入ELMo后 F1 可以提升 1.1%;阅读理解任务加入ELMo后 Rouge-L 提升 1%。

 

接下来,我们看看怎幺可以快速把ELMo用到我们的项目中来吧!

 

ELMo 训练过程介绍

 

(1)数据预处理

 

将文档按照句号、问号、感叹以及内容分词预处理。预处理后的数据文件,每行为一个分词后的句子。给出了训练数据 data/train 和测试数据 data/dev的数据示例如下:


本 书 介绍 了 中国 经济 发展 的 内外 平衡问题 、 亚洲 金融 危机 十 周年 回顾 与 反思 、 实践 中 的 城乡 统筹 发展 、 未来 十 年 中国 需要 研究 的 重大 课题 、 科学 发展 与新型 工业 化 等 方面 。


吴 敬 琏 曾经 提出 中国 股市 “ 赌场 论 ” , 主张 维护 市场 规则 , 保护 草根 阶层 生计, 被 誉 为 “ 中国 经济 学界 良心 ” , 是 媒体 和公众 眼中 的 学术 明星

(2)模型训练

 

利用提供的示例训练数据和测试数据,进行单机多卡预训练。在开始预训练之前,需要把 CUDA、cuDNN、NCCL2 等动态库路径加入到环境变量 LD_LIBRARY_PATH 之中,然后执行run.sh即可开始单机多卡预训练,run.sh文件内容如下:

 

<code>export CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7</code><code>python </code>
<code> train.py \</code><code>--train_path='data/train/sentence_file_*'  </code><code>\</code>
<code>--test_path='data/dev/sentence_file_*'  </code><code>\</code>
<code>--vocab_path data/vocabulary_min5k.txt </code><code>\</code>
<code>--learning_rate 0.2 </code><code>\</code>
<code>--use_gpu True </code><code>\</code>
<code>--all_train_tokens 35479</code><code> \</code>
<code>--local True $@</code>

 

其中,all_train_tokens为train和dev统计出来的tokens总量,训练过程中,默认每个epoch后,将模型参数写入到 checkpoints 路径下,可以用于迁移到下游NLP任务。

 

(3)ELMo模型迁移

 

以 LAC 任务为示例, 将ELMo预训练模型的语义表示迁移到 LAC 任务的主要步骤如下:

 

#step1:在已经搭建好的LAC 网络结构之后,加载ELMo预训练模型参数:

 

<code>from bilm import</code>
<code> </code><code>init_pretraining_params</code>
<code>init_pretraining_params(exe,args.pretrain_elmo_model_path, fluid.default_main_program())</code>

 

#step2: 基于ELMo字典 将输入数据转化为 word_ids,利用 elmo_encoder接口获取ELMoembedding:

 

<code>from bilm import</code>
<code> elmo_encoder</code><code>elmo_embedding = elmo_encoder(word_ids)</code>

 

#step3: ELMoembedding与 LAC 原有 word_embedding 拼接得到最终的 embedding:

 

word_embedding=fluid.layers.concat(input=[elmo_embedding, word_embedding], axis=1)

 

好的,到这里,模型的迁移就完成了,再来回顾一下加入ELMo后对性能的提升,心动不如行动,赶紧用起来吧!

 

 

ERNIE 模型简介

 

学习完了ELMo,我们再来了解一下LARK家族的学习成绩最好的重磅成员ERNIE,在多项NLP中文任务上表现非凡。

 

ERNIE通过建模海量数据中的实体概念等先验语义知识,学习真实世界的语义关系。具体来说,ERNIE 模型通过对词、实体等语义单元的掩码,使得模型学习完整概念的语义表示。相较于BERT 学习原始语言信号,ERNIE 直接对先验语义知识单元进行建模,增强了模型语义表示能力。

 

ERNIE在多个公开的中文数据集上进行了效果验证,包括语言推断、语义相似度、命名实体识别、情感分析、问答匹配等自然语言处理各类任务上,均超越了语义表示模型 BERT 的效果。

 

Be First to Comment

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注