卷积神经网络(CNN)在句子建模上的应用

之前的博文已经介绍了CNN的基本原理,本文将大概总结一下最近CNN在NLP中的句子建模(或者句子表示)方面的应用情况,主要阅读了以下的文献:

Kim Y. Convolutional neural networks for sentence classification[J]. arXiv preprint arXiv:1408.5882, 2014.

Kalchbrenner N, Grefenstette E, Blunsom P. A convolutional neural network for modelling sentences[J]. arXiv preprint arXiv:1404.2188, 2014.

Hu B, Lu Z, Li H, et al. Convolutional neural network architectures for matching natural language sentences[C]//Advances in Neural Information Processing Systems. 2014: 2042-2050.

He H, Gimpel K, Lin J. Multi-perspective sentence similarity modeling with convolutional neural networks[C]//Proceedings of the 2015 Conference on Empirical Methods in Natural Language Processing. 2015: 1576-1586.

Wenpeng Yin, Hinrich Schütze. Convolutional Neural Network for Paraphrase Identification. The 2015 Conference of the North American Chapter of the Association for Computational Linguistics

Zhang Y, Wallace B. A Sensitivity Analysis of (and Practitioners’ Guide to) Convolutional Neural Networks for Sentence Classification[J]. arXiv preprint arXiv:1510.03820, 2015.

下面对文献中CNN的结构和细节进行梳理。


Kim Y’s Paper

模型结构及原理

模型的结构如下:

说明如下:

  • 输入层

如图所示,输入层是句子中的词语对应的word vector依次(从上到下)排列的矩阵,假设句子有 个词,vector的维数为 k ,那么这个矩阵就是 n×k 的。

这个矩阵的类型可以是静态的(static),也可以是动态的(non static)。静态就是word vector是固定不变的,而动态则是在模型训练过程中,word vector也当做是可优化的参数,通常把反向误差传播导致word vector中值发生变化的这一过程称为Fine tune

对于未登录词的vector,可以用0或者随机小的正数来填充。

  • 第一层卷积层

输入层通过卷积操作得到若干个Feature Map,卷积窗口的大小为 h×k ,其中 h 表示纵向词语的个数,而 k 表示word vector的维数。通过这样一个大型的卷积窗口,将得到若干个列数为1的Feature Map

  • 池化层

接下来的池化层,文中用了一种称为Max-over-time Pooling的方法。这种方法就是简单地从之前一维的Feature Map中提出最大的值,文中解释最大值代表着最重要的信号。可以看出,这种Pooling方式可以解决可变长度的句子输入问题(因为不管Feature Map中有多少个值,只需要提取其中的最大值)。

最终池化层的输出为各个Feature Map的最大值们,即一个一维的向量。

  • 全连接 + Softmax层

池化层的一维向量的输出通过全连接的方式,连接一个Softmax层,Softmax层可根据任务的需要设置(通常反映着最终类别上的概率分布)。

最终实现时,我们可以在倒数第二层的全连接部分上使用Dropout技术,即对全连接层上的权值参数给予L2正则化的限制。这样做的好处是防止隐藏层单元自适应(或者对称),从而减轻过拟合的程度。

实验部分

1. 数据

实验用到的数据集如下(具体的名称和来源可以参考论文):

2. 模型训练和调参

  • 修正线性单元(Rectified linear units)
  • 滤波器的h大小:3,4,5;对应的Feature Map的数量为100;
  • Dropout率为0.5,L2正则化限制权值大小不超过3;
  • mini-batch的大小为50;

这些参数的选择都是基于SST-2 dev数据集,通过网格搜索方法(Grid Search)得到的最优参数。另外,训练过程中采用随机梯度下降方法,基于shuffled mini-batches之上的,使用了Adadelta update rule(Zeiler, 2012)。

3. 预训练的Word Vector

这里的word vector使用的是公开的数据,即连续词袋模型(COW)在Google News上的训练结果。未登录次的vector值是随机初始化的。

4. 实验结果

实验结果如下图:

其中,前四个模型是上文中所提出的基本模型的各个变种:

  • CNN-rand: 所有的word vector都是随机初始化的,同时当做训练过程中优化的参数;
  • CNN-static: 所有的word vector直接使用无监督学习即Google的Word2Vector工具(COW模型)得到的结果,并且是固定不变的;
  • CNN-non-static: 所有的word vector直接使用无监督学习即Google的Word2Vector工具(COW模型)得到的结果,但是会在训练过程中被Fine tuned
  • CNN-multichannel: CNN-static和CNN-non-static的混合版本,即两种类型的输入;

博主自己下载了论文作者的实现程序(Github地址),最终在MR数据集上的运行结果如下:

  • CNN-rand: 0.7669
  • CNN-static: 0.8076
  • CNN-non-static: 0.8151

和论文中的结果差不多。

5. 结论

  • CNN-static较与CNN-rand好,说明pre-training的word vector确实有较大的提升作用(这也难怪,因为pre-training的word vector显然利用了更大规模的文本数据信息);
  • CNN-non-static较于CNN-static大部分要好,说明适当的Fine tune也是有利的,是因为使得vectors更加贴近于具体的任务
  • CNN-multichannel较于CNN-single在小规模的数据集上有更好的表现,实际上CNN-multichannel体现了一种折中思想,即既不希望Fine tuned的vector距离原始值太远,但同时保留其一定的变化空间。

值得注意的是,static的vector和non-static的相比,有一些有意思的现象如下表格:

  • 原始的word2vector训练结果中,bad对应的最相近词为good,原因是这两个词在句法上的使用是极其类似的(可以简单替换,不会出现语句毛病);而在non-static的版本中,bad对应的最相近词为terrible,这是因为在Fune tune的过程中,vector的值发生改变从而更加贴切数据集(是一个情感分类的数据集),所以在情感表达的角度这两个词会更加接近;
  • 句子中的!最接近一些表达形式较为激进的词汇,如lush等;而,则接近于一些连接词,这和我们的主观感受也是相符的。

Kim Y的这个模型很简单,但是却有着很好的性能。后续Denny用TensorFlow实现了这个模型的简单版本,可参考这篇博文;以及Ye Zhang等人对这个模型进行了大量的实验,并给出了调参的建议,可参考这篇论文

下面总结一下Ye Zhang等人基于Kim Y的模型做了大量的调参实验之后的结论:

  • 由于模型训练过程中的随机性因素,如随机初始化的权重参数,mini-batch,随机梯度下降优化算法等,造成模型在数据集上的结果有一定的浮动,如准确率(accuracy)能达到1.5%的浮动,而AUC则有3.4%的浮动;
  • 词向量是使用word2vec还是GloVe,对实验结果有一定的影响,具体哪个更好依赖于任务本身;
  • Filter的大小对模型性能有较大的影响,并且Filter的参数应该是可以更新的;
  • Feature Map的数量也有一定影响,但是需要兼顾模型的训练效率;
  • 1-max pooling的方式已经足够好了,相比于其他的pooling方式而言;
  • 正则化的作用微乎其微。

Ye Zhang等人给予模型调参者的建议如下:

  • 使用non-static版本的word2vec或者GloVe要比单纯的one-hot representation取得的效果好得多;
  • 为了找到最优的过滤器(Filter)大小,可以使用线性搜索的方法。通常过滤器的大小范围在1-10之间,当然对于长句,使用更大的过滤器也是有必要的;
  • Feature Map的数量在100-600之间;
  • 可以尽量多尝试激活函数,实验发现ReLUtanh两种激活函数表现较佳;
  • 使用简单的1-max pooling就已经足够了,可以没必要设置太复杂的pooling方式;
  • 当发现增加Feature Map的数量使得模型的性能下降时,可以考虑增大正则的力度,如调高dropout的概率;
  • 为了检验模型的性能水平,多次反复的交叉验证是必要的,这可以确保模型的高性能并不是偶然。

论文附录中还附上了各种调参结果,感兴趣的可以前往阅读之。

Kalchbrenner’s Paper

Kal的这篇文章引用次数较高,他提出了一种名为DCNN(Dynamic Convolutional Neural Network)的网络模型,在上一篇(Kim’s Paper)中的实验结果部分也验证了这种模型的有效性。这个模型的精妙之处在于Pooling的方式,使用了一种称为动态Pooling的方法。

下图是这个模型对句子语义建模的过程,可以看到底层通过组合邻近的词语信息,逐步向上传递,上层则又组合新的Phrase信息,从而使得句子中即使相离较远的词语也有交互行为(或者某种语义联系)。从直观上来看,这个模型能够通过词语的组合,提取出句子中重要的语义信息(通过Pooling),某种意义上来说,层次结构的feature graph的作用类似于一棵语法解析树。

DCNN能够处理可变长度的输入,网络中包含两种类型的层,分别是一维的卷积层动态k-max的池化层(Dynamic k-max pooling)。其中,动态k-max池化是最大化池化更一般的形式。之前LeCun将CNN的池化操作定义为一种非线性的抽样方式,返回一堆数中的最大值,原话如下:

The max pooling operator is a non-linear subsampling function that returns the maximum of a set of values (LuCun et al., 1998).

而文中的k-max pooling方式的一般化体现在:

  • pooling的结果不是返回一个最大值,而是返回k组最大值,这些最大值是原输入的一个子序列;
  • pooling中的参数k可以是一个动态函数,具体的值依赖于输入或者网络的其他参数;

模型结构及原理

DCNN的网络结构如下图:

网络中的卷积层使用了一种称之为宽卷积(Wide Convolution)的方式,紧接着是动态的k-max池化层。中间卷积层的输出即Feature Map的大小会根据输入句子的长度而变化。下面讲解一下这些操作的具体细节:

1. 宽卷积

相比于传统的卷积操作,宽卷积的输出的Feature Map的宽度(width)会更宽,原因是卷积窗口并不需要覆盖所有的输入值,也可以是部分输入值(可以认为此时其余的输入值为0,即填充0)。如下图所示:

图中的右图即表示宽卷积的计算过程,当计算第一个节点即s1时,可以假使s1s1节点前面有四个输入值为0的节点参与卷积(卷积窗口为5)。明显看出,狭义上的卷积输出结果是宽卷积输出结果的一个子集。

2. k-max池化

给出数学形式化的表述是,给定一个k值,和一个序列pRp(其中pk),k-max pooling选择了序列p中的前k个最大值,这些最大值保留原来序列的次序(实际上是原序列的一个子序列)。

k-max pooling的好处在于,既提取除了句子中的较重要信息(不止一个),同时保留了它们的次序信息(相对位置)。同时,由于应用在最后的卷积层上只需要提取出k个值,所以这种方法允许不同长度的输入(输入的长度应该要大于k)。然而,对于中间的卷积层而言,池化的参数k不是固定的,具体的选择方法见下面的介绍。

3. 动态k-max池化

动态k-max池化操作,其中的k输入句子长度网络深度两个参数的函数,具体如下:

 

Kl=max(ktop,LlLs)

 

其中ll表示当前卷积的层数(即第几个卷积层),L是网络中总共卷积层的层数;ktop为最顶层的卷积层pooling对应的k值,是一个固定的值。举个例子,例如网络中有三个卷积层,ktop=3ktop=3,输入的句子长度为18;那么,对于第一层卷积层下面的pooling参数k1=12,而第二层卷积层对于的为k2=6,而k3=ktop=3

动态k-max池化的意义在于,从不同长度的句子中提取出相应数量的语义特征信息,以保证后续的卷积层的统一性。

4. 非线性特征函数

pooling层与下一个卷积层之间,是通过与一些权值参数相乘后,加上某个偏置参数而来的,这与传统的CNN模型是一样的。

5. 多个Feature Map

和传统的CNN一样,会提出多个Feature Map以保证提取特征的多样性。

6. 折叠操作(Folding)

之前的宽卷积是在输入矩阵d×s中的每一行内进行计算操作,其中d是word vector的维数,s是输入句子的词语数量。而Folding操作则是考虑相邻的两行之间的某种联系,方式也很简单,就是将两行的vector相加;该操作没有增加参数数量,但是提前(在最后的全连接层之前)考虑了特征矩阵中行与行之间的某种关联。

模型的特点

  • 保留了句子中词序信息和词语之间的相对位置;
  • 宽卷积的结果是传统卷积的一个扩展,某种意义上,也是n-gram的一个扩展;
  • 模型不需要任何的先验知识,例如句法依存树等,并且模型考虑了句子中相隔较远的词语之间的语义信息;

实验部分

1. 模型训练及参数

  • 输出层是一个类别概率分布(即softmax),与倒数第二层全连接;
  • 代价函数为交叉熵,训练目标是最小化代价函数;
  • L2正则化;
  • 优化方法:mini-batch + gradient-based (使用Adagrad update rule, Duchi et al., 2011)

2. 实验结果

在三个数据集上进行了实验,分别是(1)电影评论数据集上的情感识别,(2)TREC问题分类,以及(3)Twitter数据集上的情感识别。结果如下图:

可以看出,DCNN的性能非常好,几乎不逊色于传统的模型;而且,DCNN的好处在于不需要任何的先验信息输入,也不需要构造非常复杂的人工特征。

Hu’s Paper

模型结构与原理

1. 基于CNN的句子建模

这篇论文主要针对的是句子匹配(Sentence Matching)的问题,但是基础问题仍然是句子建模。首先,文中提出了一种基于CNN的句子建模网络,如下图:

图中灰色的部分表示对于长度较短的句子,其后面不足的部分填充的全是0值(Zero Padding)。可以看出,模型解决不同长度句子输入的方法是规定一个最大的可输入句子长度,然后长度不够的部分进行0值的填充;图中的卷积计算和传统的CNN卷积计算无异,而池化则是使用Max-Pooling。

  • 卷积结构的分析

下图示意性地说明了卷积结构的作用,作者认为卷积的作用是从句子中提取出局部的语义组合信息,而多张Feature Map则是从多种角度进行提取,也就是保证提取的语义组合的多样性;而池化的作用是对多种语义组合进行选择,过滤掉一些置信度低的组合(可能这样的组合语义上并无意义)。

2. 基于CNN的句子匹配模型

下面是基于之前的句子模型,建立的两种用于两个句子的匹配模型。

2.1 结构I

模型结构如下图:

简单来说,首先分别单独地对两个句子进行建模(使用上文中的句子模型),从而得到两个相同且固定长度的向量,向量表示句子经过建模后抽象得来的特征信息;然后,将这两个向量作为一个多层感知机(MLP)的输入,最后计算匹配的分数。

这个模型比较简单,但是有一个较大的缺点:两个句子在建模过程中是完全独立的,没有任何交互行为,一直到最后生成抽象的向量表示后才有交互行为(一起作为下一个模型的输入),这样做使得句子在抽象建模的过程中会丧失很多语义细节,同时过早地失去了句子间语义交互计算的机会。因此,推出了第二种模型结构。

2.2 结构II

模型结构如下图:

图中可以看出,这种结构提前了两个句子间的交互行为。

  • 第一层卷积层

第一层中,首先取一个固定的卷积窗口k1,然后遍历 Sx 和 Sy 中所有组合的二维矩阵进行卷积,每一个二维矩阵输出一个值(文中把这个称作为一维卷积,因为实际上是把组合中所有词语的vector排成一行进行的卷积计算),构成Layer-2。下面给出数学形式化表述:

  • 第一层卷积层后的Max-Pooling层

从而得到Layer-2,然后进行2×2的Max-pooling:

  • 后续的卷积层

后续的卷积层均是传统的二维卷积操作,形式化表述如下:

  • 二维卷积结果后的Pooling层

与第一层卷积层后的简单Max-Pooling方式不同,后续的卷积层的Pooling是一种动态Pooling方法,这种方法来源于参考文献[1]。

  • 结构II的性质
  1. 保留了词序信息;
  2. 更具一般性,实际上结构I是结构II的一种特殊情况(取消指定的权值参数);

实验部分

1. 模型训练及参数

  • 使用基于排序的自定义损失函数(Ranking-based Loss)
  • BP反向传播+随机梯度下降;
  • mini-batch为100-200,并行化;
  • 为了防止过拟合,对于中型和大型数据集,会提前停止模型训练;而对于小型数据集,还会使用Dropout策略;
  • Word2Vector:50维;英文语料为Wikipedia(~1B words),中文语料为微博数据(~300M words);
  • 使用ReLu函数作为激活函数;
  • 卷积窗口为3-word window;
  • 使用Fine tuning;

2. 实验结果

一共做了三个实验,分别是(1)句子自动填充任务,(2)推文与评论的匹配,以及(3)同义句识别;结果如下面的图示:

其实结构I和结构II的结果相差不大,结构II稍好一些;而相比于其他的模型而言,结构I和结构II的优势还是较大的。

He’s Paper

第四篇论文即He的文章中所提出的模型,是所有基于NN的模型中,在Paraphrase identification任务标准数据集MSRP上效果最佳的。下面我们来学习一下这个模型。

模型结构与原理

模型主要分为两个部分:

  • 句子的表征模型:得到句子的表征(representation),以供后续的相似度计算;
  • 相似度计算模型:使用多种相似度计算方法,针对句子表征后的局部进行相应的计算;

模型不需要借助WordNet, 句法解析树等资源;但是可以选择性地使用词性标注、word embedding等方法来增强模型的性能;与之前的模型区别在于,文中的模型使用了多种类型的卷积、池化方法,以及针对得到的句子表征的局部进行相应的相似度计算。(这样做的优点在于能够更加充分地挖掘出句子中的特征信息,从而提升性能,但同时使得模型变得复杂、耗时)

模型的整体框架如下:

下面具体看看这两个模型是如何实现的。

  1. 句子的表征模型

模型是基于CNN的,卷积层有两种卷积方式,池化层则有三种。

  • 卷积层

假设模型的输入为二维矩阵 SentSentRlen×Dim,其中 lenlen 表示句子切分为Token List后的长度(Token可以是词/字),Dim 表示Token的Embedding表示的维度。由此有 Senti表示矩阵的第 i 行,即输入中的第 i 个Token的Embedding表示;Senti:j 表示矩阵中的第 i到第 j 行的一个切片,也是一个子矩阵;Senti[k] 表示矩阵的第 i 行第 k 列的值,对应是Embedding的第 k 个值;而 Senti:j[k] 则是矩阵中第 i 行到第 j 行中的第 k 列的一个切片。

卷积层有两种卷积的方式:(1)粒度为word的卷积;(2)粒度为embedding 维度上的卷积。如下图:

其中,第一种卷积方式与之前的Kim Y提出模型中的相同,相当于是n-gram特征的抽取;而对于第二种卷积方式,论文作者给出的解释是,(1)这种方式有助于充分地提取出输入的特征信息;(2)由于粒度更小,所以在学习过程中的参数调整上,每一个维度能够得到不同程度的参数调整。(第二种卷积方式从直观上没有太多的物理意义,而作者也是直说不能够给出符合人直观想法上的解释)。

  • 池化层

模型除了使用传统的max-pooling,还使用了min-poolingmean-pooling方式。

假设 group(ws,pooling,sent) 表示卷积宽度为 ws,使用 pooling 池化函数,应用在输入的句子 sen上。我们使用了两种类型的building block,分别是 blockA 和 blockB上,定义如下

 

blockA={groupA(wsa,p,sent):pmax,min,mean}

 

这里 blockA 有三组卷积层,卷积窗口的宽度一致(都是 wsa ),每一组对应一种池化操作。这里池化操作和卷积层是一一对应的,也就是说并不是一个卷积层上实施三种池化操作(虽然也可以这么做,作者没有这么做的原因是由于激活函数的存在,对每个卷积结果都进行max-poolingmin-pooling是没有必要的)。

而 blockB 的定义如下:

 

blockB={groupB(wsb,p,sent):pmax,min}

 

这里 blockB 有两组卷积层,卷积窗口的宽度为 wsb,两组分别对应max-poolingmin-pooling的操作。值得说明的是,groupB() 中的卷积层对应有 Dim 个以embedding dimension为粒度的卷积窗口,也就是对embedding的每一维度做卷积运算。

这里只所以要组合这些多样的卷积和池化操作,原因是希望能够从多个方面来提取出输入中的特征信息,以供后续的决策任务。

  • 多种窗口尺寸

与传统的n-gram模型相似,这里在building block中使用了多种尺寸的卷积窗口。如下图所示:

其中 wsws 表示卷积时卷积的n-gram长度,而 ws=ws=∞ 表示卷积窗口为整个word embedding矩阵。wsws 的值及Feature Map 的数量都是需要调参的。

  1. 相似度计算模型

下面介绍在得到句子的表征向量之后,如何计算它们的相似度。直观的想法是,我们可以使用传统的相似度计算方法如余弦相似度等来计算两个句子向量的相似度。但是,直接应用这种做法在两个句子向量上并不是最优的,原因在于最后生成的句子向量中的每一个部分的意义各不相同,这样简单粗暴的计算势必会影响效果,所以做法是对句子向量中的各个部分进行相应的比较和计算(Structured Comparision)。为了使得句子向量中的局部间的比较和计算更加有效,我们需要考虑如下方面:

(1) 是否来自相同的building block
(2) 是否来自相同卷积窗口大小下的卷积结果;
(3) 是否来自相同的pooling层
(4) 是否来自相同的Feature Map

最终比较句子中的相应部分时,需要至少满足以上两个条件。为了识别句子中的哪些对应部分需要参与到相似度计算,文中提供了两种算法。

2.1. 相似度计算单元(Unit)

两种相似度计算单元如下:

2.2. 基于句子局部的相似度计算

算法1和算法2为句子表征向量的两种计算方法,其中算法1仅用在 blockAblockA 上;而算法2则都用在 blockAblockA 和 blockBblockB 上,两种算法都是针对相同类型(pooling和block类型)的输出做局部比较。

给出如下的符号假设:

算法的伪代码如下:

下面的图示说明了在 blockA 上,两种算法的计算方式的区别,算法一表现了向量在水平方向上的比较;而算法二则是在垂直方向。

需要注意的是,在算法二中相同类型的pooling的输出groups中,向量是两两进行比较的(图中的红色虚线只是为了说明比较的方向,并不是只针对group中相同大小的卷积窗口作比较);而算法一中的每一行都要作比较,不仅仅是第一行。

  1. 模型的其他细节
  • 相似度向量输出 + 全连接层

基于句子局部的相似度计算之后,得到相应的相似度向量;然后这组向量之后连接一个全连接层,最后softmax对应输出。如果是计算相似度度量值,可以用softmax输出的类别概率值。

  • 激活函数

使用tanh函数作为激活函数。

实验部分

  1. 实验数据集

用于评测同义句检测 (Paraphrase Identification) 任务的经典数据集,数据集来源于新闻;包含5801对句子对,其中4076对用于模型训练,而1725对用于测试;每一对句子拥有一个标签,0或者1,0表示两个句子不是互为同义句,而1则表示两个句子互为同义句。因此这是一个二分类的任务。

数据来源于2014年SemEval比赛,数据集有9927对句子对,其中4500对用于模型训练,500对用于模型验证,而剩下的4927对用于模型测试。这些句子都是在图片和视频描述中抽取得到的,每一对句子对有一个相关分数,区间在[1, 5],分数越高表示句子越相关。

数据集来源于2012年的SemEval比赛,包含1500对短文本(用于描述视频信息)。其中一般用于模型训练,一半用于模型测试,每一对句子有一个相关性分数,区间在[0, 5],分数越高表示句子越相关。

  1. 模型训练

针对MSRP和其他两个数据集,分别使用两种损失函数。对于MSRP数据集,损失函数(Hinge Loss)如下:

对于其余两个数据集,损失函数(KL-divergence Loss)如下:

  1. 实验参数设置
  • wsws 的值ws[1,3]ws∈[1,3]和 ws=ws=∞.
  • Word Embedding: 300维的GloVe word embedding;对于MSRP数据集,还额外使用了200维的POS embedding (Standford POS tagger)和25维的Paragram Vectors (Wieting et al., 2015 PDF数据下载地址)。因此对于MSRP任务而言,word embedding的维数为525维 (200+300+25);而其余两个任务则对应是300维。
  • 在MSRP上使用了5-折交叉验证的方式,对模型参数进行tuningTuning好的模型参数将会用在另外两个数据集任务上。
  • 只有在MSRP数据集任务上,允许模型参数进行更新。
  • 输出的全连接层,MSRP有250个神经元节点,而SICK和MSRVID则是150个。
  • 在 blockAblockA 中,Feature Map 的数量与输入的embedding维数相同,即MSRP是525个,而SICK和MSRVID则是300个。
  • 优化算法使用随机梯度下降方法。
  • 学习率为0.01,而正则化参数 λ=104λ=10−4.
  1. 实验结果
  • MSRP数据集

可以看出,文中的模型是所有基于NN的方法中在MSRP数据集上性能最好的。

  • SICK数据集

  • MSRVID数据集

而模型在SICK和MSRVID数据集上的表现也很好。

  1. 模型的敏感度分析

下面的表格说明了在不使用某种技术下,模型性能在实验数据集上的变化情况。

从中可以得出以下结论:

  • 对于MSRP数据集任务而言,增加POS EmbeddingParagram Vector效果显著;
  • 移除相似度计算层的影响显著,说明结构化的句子局部比较方法是有效且必要的;
  • HorizontalVertical算法均有一定的提升效果,而Vertical算法的提升程度更高;
  • max-pooling方式确实要比min-poolingmean-pooling强太多。
  1. 总结

文中的模型包含两个部分:卷积-池化模型和相似度计算模型。实验部分已经验证了模型的有效性,在MSRP数据集上模型取得了仅次于state-of-art的结果,并且在基于NN的方法中是最好的。模型中的相似度计算层是有必要的,因为对卷积池化处理后的句子成分进行了针对性的比较,从直观上要比直接扔进全连接层更合理,而实验结果也表明了这一点。

然而,个人觉得,文中的模型结构较为复杂,而且其中有很多trick的地方,比如为什么要对word embedding中的每一维度做卷积,blockBblockB 中的pooling方式为什么只用了max和min,不用mean的方式等问题,而这些方式或许是作者自己做了大量实验后,从果到因而使用的。

Yin’s Paper

Yin的这篇论文提出了一种叫Bi-CNN-MI的架构,其中Bi-CNN表示两个使用Siamese框架的CNN模型;MI表示多粒度的交互特征。Bi-CNN-MI包含三个部分:

  • 句子分析模型 (CNN-SM)

这部分模型主要使用了上述Kal在2014年提出的模型,针对句子本身提取出四种粒度的特征表示:词、短ngram、长ngram和句子粒度。多种粒度的特征表示是非常必要的,一方面提高模型的性能,另一方面增强模型的鲁棒性。

  • 句子交互计算模型 (CNN-IM)

这部分模型主要是基于2011年Socher提出的RAE模型,做了一些简化,即仅对同一种粒度下的提取特征做两两比较。

  • LR或Softmax网络层以适配任务

模型结构

论文提出的模型主要是基于Kal的模型及Socher的RAE模型的结合体,如下图:

通过模型图可以看出模型的主要思想:一方面利用Kal的模型进行多种粒度上的特征提取,另一方面采取RAE模型的思想,对提取出来的特征进行两两的相似度计算,计算完成的结果通过dynamic pooling的方式进一步提取少量特征,然后各个层次的pooling计算结果平摊为一组向量,通过全连接的方式与LR(或者softmax)层连接,从而适配同义句检测任务本身。

这个模型具体的计算细节不再赘述了,感兴趣的读者可以直接去看论文。除了提出这种模型结构之外,论文还有一个亮点在于使用了一种类似于语言模型的CNN-LM来对上述CNN部分的模型进行预训练,从而提前确定模型的参数。CNN-LM的网络结构如下图:

CNN-LM模型的训练预料使用了最终的实验数据集,即MSRP;另外,由于MSRP的数据规模较小,所以作者又增加了100,000个英文句子语料。CNN-LM模型最终能够得到word embedding, 模型权值等参数。需要注意的是,这些参数并不是固定的,在之后的句子匹配任务中是会不断更新的。从后面的实验结果中可以看出,CNN-LM的作用是显著的。

实验结果

论文仅使用了一种数据集,即公认的PI (Paraphrase Identification)任务数据集,MSRP。实验结果如下:

可以看出,CNN-LM的预训练效果显著,预训练后的模型性能很强(但是结果上比之前He提出的模型稍差一些)。


本文结束,感谢欣赏。

欢迎转载,请注明本文的链接地址:

http://www.jeyzhang.com/cnn-apply-on-modelling-sentence.html

参考文献

[1] R. Socher, E. H. Huang, and A. Y. Ng. Dynamic pooling and unfolding recursive autoencoders for paraphrase detection. In Advances in NIPS, 2011.

推荐资料

A Sensitivity Analysis of (and Practitioners’ Guide to) Convolutional Neural Networks for Sentence Classification

Implementing a CNN for Text Classification in TensorFlow

Kim Y’s Implement: Convolutional Neural Networks for Sentence Classification

 

posted @ 2018-02-27 17:30  笨兔勿应  阅读(3470)  评论(0编辑  收藏  举报