所有的模型均采用tensorflow进行了实现,欢迎start,[代码地址]https://github.com/terrifyzhao/text_matching

简介

DRCN和DIIN的结构十分相似,包括输入层与特征提取层, DRCN在特征提取阶段结合了DenseNet的连接策略与Attention机制,在interaction阶段,也、采取了更加多样化的交互策略,接下来就为大家详细介绍一下。

结构

DRCN分为三层,word representation layer、attentively connected RNN与interaction and prediction layer,其最核心的结构还是在于attentively connected RNN,总体结构如下图所示

nlp文字相似度对比模型 文字相似度匹配_github

word representation layer

输入层包括四个部分,预训练的词向量,字向量与一个exact match flag,词向量采用w2v或glove,并且词向量还分为了静态与动态形式,静态形式即不修改预训练的词向量,动态形式是指根据当前任务动态调整embedding matrix,字向量采用的是embedding层来生成,然后过了一下卷积层和最大池化层,exact match flag是一个标志位,如果两个序列中有相同的词就标记位1,否则标记位0,最后将这四部分拼接起来。

nlp文字相似度对比模型 文字相似度匹配_特征提取_02

attentively connected RNN

本层也是该模型的关键所在,这里作者采用了5层BiLSTM堆叠在一起加上DenseNet的结构并循环了4次,我们详细看一下,nlp文字相似度对比模型 文字相似度匹配_nlp文字相似度对比模型_03表示的是BiLSTM的层数,nlp文字相似度对比模型 文字相似度匹配_特征提取_04表示的是时刻,其隐藏状态的值为:

nlp文字相似度对比模型 文字相似度匹配_github_05

我们知道这样的结构在结构很深的时候很容易出现梯度消失或者梯度爆炸的情况,因此提出来了ResNet来解决这个问题,隐藏状态的值也变为了:

nlp文字相似度对比模型 文字相似度匹配_特征提取_06

然而残缺网络的结构也存在一定的弊端,其会阻碍信息在网络间的传递,因此DenseNet应运而生,其尾部不是相加的结构,而是拼接,这样既不阻碍信息的传递,也能保留原有信息,即使是第一层的输出值也能有效传递到最后一层,避免了防止梯度消失等问题,其隐藏状态为:

nlp文字相似度对比模型 文字相似度匹配_github_07

除了DenseNet的结构以外,这一层还引入了attention机制,attention在很多领域都取得了不错的成绩包括nlp。设经过BiLSTM之后的值为nlp文字相似度对比模型 文字相似度匹配_nlp文字相似度对比模型_08nlp文字相似度对比模型 文字相似度匹配_特征提取_09,首先计算attention matrix,采用的是余弦相似度,然后经过softmax处理后计算出加权后的值,注意nlp文字相似度对比模型 文字相似度匹配_词向量_10加权后的值是和nlp文字相似度对比模型 文字相似度匹配_词向量_11相乘。

nlp文字相似度对比模型 文字相似度匹配_特征提取_12

此时,输入到下一层的值就是由三部分构成了,即下图红色部分所示,隐藏状态值为:

nlp文字相似度对比模型 文字相似度匹配_github_13

nlp文字相似度对比模型 文字相似度匹配_特征提取_14

此时得到的值其实维度是很大的,并且参数量也很大,作者为了压缩维度加入了一个200个节点的autoencoder来降低维度。

interaction and prediction layer

本层的内容就很简单了,首先把上一层得到的值经过最大池化层,然后池化后的结果做一个相关处理,作者采用了三种关联策略,分别是对位相加,对位相减,对位取模,并和原来的值拼接在一起。

nlp文字相似度对比模型 文字相似度匹配_nlp文字相似度对比模型_15

最后把得到的结果送入2个带relu激活函数的全连接层1个不带的全连接层和softmax层。

小结

DRCN在我看来就是DIIN的一个增强版本,把DIIN每一个模块的结构都变得更加复杂化。这也反应出了目前深度学习论文的一个现状,在没有理论支撑下,只要少量的结构改动参数就会变多,在保证不过拟合的情况下必然能对结果有进一步提升,希望在未来能看到更多像transformer这样的网络结构,而不是简单的组件模块堆砌。

参考文献

Semantic Sentence Matching with Densely-connected Recurrent and Co-attentive Information