【NLP】ELMO语言模型

ELMO模型通过双向RNN捕捉单词的上下文信息,每个词的embedding是前向和后向RNN隐藏状态的加权和。这种加权和的方式使得每个词的表示都考虑了其在句子中的前后语境,从而提高了表示的丰富性和准确性。在不同的任务中,通过学习不同的权重来调整不同层的贡献,以适应具体任务的需求。
摘要由CSDN通过智能技术生成

ELMO的全称是Embedding from Language Model,出自Deep contextualized word representations这篇论文。这个模型是RNN-based模型,从大量的句子中进行训练。

举个简单的例子,给了一个句子:“潮水 退了 就知道 谁没穿裤子”,那么就要告诉模型输入< BOS >就要输出“潮水”,输入“潮水”就要输出“退了”…如下图所示:
在这里插入图片描述
通过这样的训练方式,就能将RNN输出的hidden state作为该输入所对应的contextual embedding(考虑了上下文语境的表达)。

为什么说得到的embedding是考虑了上下文的呢?举个例子,“高烧 退了”和“臣 退了”,模型一定会将第一个词考虑进去,才能得到下一个预测的词。同样都是“退了”,但是其包含的意思并不相同。
在这里插入图片描述
这样做只考虑到了前文,没有考虑到后文,那么再构建一个反向的RNN,通过后面的词来预测前面的词,这样就让每一个词的embedding考虑到了后文的语境。上下文不一样,就会得到不同的embedding。
在这里插入图片描述
现在的RNN模型可能是多层的,如下图,那么每一层都会得到这样的embedding,我们应该以什么为准?
在这里插入图片描述
在ELMO中,这些得到的embedding,它全都要。这里用到的方式是weighted-sum,也就是将两层RNN得到的embedding加权求和。
在这里插入图片描述
下面是weighted-sum,其中 α 1 , α 2 \alpha_1, \alpha_2 α1,α2都是从下游任务中学出来的!所以不同的下游任务,会有不同的参数权重。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr.zwX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值