您的位置:首页 > 其它

二元语法(2-gram)分词中的平滑算法

2015-09-11 19:12 441 查看
从一年前的计算语言学作业开始,我一直没明白,为什么我写的二元语法分词要比一元语法差。两天来我仔细分析了一下之前的实验细节,发现二元语法分词要超过一元语法,可以有两种方式:1.超大的语料;2.强大的平滑算法。

  实验采用北大人民日报1-6月语料,大约700万字,选其中90%作为训练数据,另外10%作为测试数据。先看下实验结果:

分词方法准确率召回率F值
最大正向匹配0.90400.91890.9114
一元语法0.92800.95020.9389
二元语法(+1平滑)0.90930.92760.9184
二元语法(+eps平滑)0.91020.95290.9311
二元语法(删除插值)0.93170.96150.9463
  一元语法引入了词频信息,效果对最大正相匹配有很大的提高。但是奇怪的是,二元语法(用前两种平滑算法)居然比一元语法的效果更差,问题在哪呢?

  经过测试,在测试语料中,二元语法的最短路径(参考《SharpICTCLAS分词系统简介(2)初步分词》的思路)上,平均每个段落有12处 p(wn|wn−1)=0。这就意味着700万字的训练数据还是不够大,平滑算法在这里需要起到非常重要的作用。

  下面简单看看几种平滑算法的“含义”。


+1 平滑、+ε平滑

p(wn|wn−1)=f(wn−1wn)+1f(wn−1)+m

  对于f(wn−1wn)=0的情况,式子会退化成 p(wn|wn−1)=1f(wn−1)+m。也就是说,如果前词频率越大,则认为后词出现的概率就越小。


删除插值法

p(wn|wn−1)=(1−λ)p′(wn|wn−1)+λp′(wn)

  直观地说,这就是二元语法和一元语法的简单线性融合。

  这种平滑算法在p′(wn|wn−1)=0时会退化成 p(wn|wn−1)=λp′(wn)。也就是说,后词词频越大,则认为后词出现的概率就越大。

  实际上这也只是两种不同方法(一元、二元语法)的融合,因为 p′(wn|wn−1) 和 p′(wn) 这一个条件概率、一个概率直接加权没有什么物理意义,只是单纯地“平滑”了一下。


总结

  两种平滑方式很有意思。当出现数据稀疏时,一种只看前词的出现频率,一种只看后词的出现频率来进行估计。从结果看,还是后者略好。

  平滑……又是一个调参的过程,参数调不好,再NB的算法也没用……简直就是NB的参数胜过NB的方法啊。但是不管怎样,最终还是得靠好方法来撑腰。

  上面的实验还停留在“远古时期”,在现在有大规模语料的实际情况下,二元语法的数据稀疏问题已经基本消失了。在别的问题中,数据稀疏问题还是经常存在,选取好的平滑方法和参数,仍然是一个重要的问题。

  p.s. 师兄推荐看《A
study of smoothing methods for language models applied to information retrieval》,传说里面对平滑参数的选取有理论的证明。


参考文献

计算语言学讲义(06)词法分析(四)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: