论文赏析[ACL18]直接到树:基于神经句法距离的成分句法分析(一)

简介: 今天要讲的这篇论文发表在ACL18上面,一句话概括,本文就是将句法树序列化,通过预测序列进行句法分析。

摘要


主要思想是通过预测一个实值向量来构造出成分句法树,该实值向量表示的就是成分句法树的所有split,并且按照中序遍历给出,具体细节之后会讲到。这个方法之前没有见过,很有新意,效果也很不错,虽然比不上之前讲的基于span的方法,但是该模型最大的优点就是可以并行,时间复杂度低。

近些年来,成分句法分析模型大多是通过学习出词和短语的表示,然后用基于转移的或者基于chart的方法进行句法分析,亦或者是上一篇笔记中提到的top-down方法。但是这一类方法都有一些不可避免的缺点,比如基于转移的方法,通过预测转移序列来生成句法分析树,但是一棵句法分析树可能对应着多棵不同的转移序列,所以训练的时候可能产生错误,可以通过动态Oracle技术解决。基于chart的模型缺点就是速度太慢。

本文提出了一种新的概念叫做“syntactic distance”,以下称作句法距离,这个概念首次提出是2017年一篇语言模型的论文中的,本文将其用在了句法分析中。主要思想是这样的:对于一棵二叉树,它的中序遍历的split序列和二叉树是唯一对应的,所以只需要预测这个split序列就行了,而每个split就是用句法距离来表示。下图就是一棵句法树对应的句法距离:

image.png

这棵树有两个split,第一个split的高度更高,所以对应的句法距离数值更大。

最后通过top-down顺序进行解码,解码时间复杂度为 image.png 。最后模型在PTB上取得了91.8的F1值,CTB上取得了86.5的F1值。

Syntactic Distances


一棵句法树的句法距离如下定义:

对于句法分析树 T ,它的叶子结点也就是句子为 image.png ,记叶子结点 image.png 的最近公共祖先LCA为 image.png ,那么句法树 T 的句法距离定义为任意向量 image.png ,并且满足

image.png

这个定义可能看起来比较难理解,通俗一点讲就是, image.png 中任意一对元素的大小关系和 image.png 中下标相同的一对元素的大小关系是完全一样的,也就是说,句法距离大小反映的是一个句子两两相邻元素的LCA的高度大小。

还用上面那张图举个例子, image.png ,那么它的句法距离 image.png 就是满足 image.png 的任意向量。

这样就可以将一棵句法树唯一对应到一个句法距离的序列,只要预测这个序列就可以得到句法树了,这比预测span集合更加直接。

那么训练的时候如何将句法树转化为句法距离呢?这里只考虑二叉树,下面的算法1给出了伪代码,将句法树转化为三元组 image.png 。其中 d 是两两相邻的叶子结点的LCA的高度向量,可以证明,这和中序遍历得到的结点顺序完全相同。 c 是与之顺序相同的结点的label向量。 t 是叶子结点从左向右的tag标签向量。

image.png

从算法中可以看出,采用自顶向下递归的形式,叶子结点高度为0,不存在句法距离和label。而内结点的高度等于左右儿子高度较大的一个加1,句法距离为左儿子句法距离拼接上自身句法距离再拼接上右儿子句法距离,label也是如此。

那么如果得到了一棵句法树的三元组 image.png ,如何还原出这棵句法树呢?算法2给出了构造方法,其实类似于之前那篇论文的top-down方法。

image.png

原理很简单,只要在每一步寻找 d 中最大的元素,也就是寻找高度最大的内结点,该内结点对应的下标就是句法树的split,然后对左右子树递归解析就行了。时间复杂度只要 image.png ,而之前的top-down模型时间复杂度为 image.png

image.png

上图是构造句法树的一个例子,和之前一样,通过 image.png 的label隐式的将句法树二叉化了,一元还是处理成新的label。图中的矩形高度就代表了句法距离的大小,可以看出,除了 image.png 这两个句子开始结束标记的句法距离以外, image.png 最大,所以句法树的split就是 image.png ,然后对右子树递归分析。

在子树递归过程中,可以并行计算,理论上时间复杂度可以降到 image.png ,但是句子长度过短的话,是否与cpu通讯时间都要大于这个数量级了呢?这个并行的意义还有待商榷。

相关文章
|
机器学习/深度学习 自然语言处理
论文赏析[ACL18]直接到树:基于神经句法距离的成分句法分析(二)
今天要讲的这篇论文发表在ACL18上面,一句话概括,本文就是将句法树序列化,通过预测序列进行句法分析。
124 0
论文赏析[ACL18]直接到树:基于神经句法距离的成分句法分析(二)
|
机器学习/深度学习
论文赏析[ACL18]基于RNN和动态规划的线性时间成分句法分析(二)
好像已经很久没有看论文了呢,开学了一堆事情,以后还是要抽空阅读论文,保持一定的阅读量,并且不能光看最新的论文,还得去前人传统的方法中去寻找有没有能应用于深度学习的东西,说不定就发ACL了呢(手动滑稽)。 论文地址:Linear-Time Constituency Parsing with RNNs and Dynamic Programming 代码地址:github
105 0
论文赏析[ACL18]基于RNN和动态规划的线性时间成分句法分析(二)
|
机器学习/深度学习 自然语言处理
论文赏析[ACL18]基于RNN和动态规划的线性时间成分句法分析(一)
好像已经很久没有看论文了呢,开学了一堆事情,以后还是要抽空阅读论文,保持一定的阅读量,并且不能光看最新的论文,还得去前人传统的方法中去寻找有没有能应用于深度学习的东西,说不定就发ACL了呢(手动滑稽)。 论文地址:Linear-Time Constituency Parsing with RNNs and Dynamic Programming 代码地址:github
105 0
论文赏析[ACL18]基于RNN和动态规划的线性时间成分句法分析(一)
|
机器学习/深度学习 自然语言处理
论文赏析[ACL18]一个句子向量表示究竟可以塞进多少语言性质?
本文主要探究了不同encoder在不同任务上训练得到的句子向量表示,是否蕴含了各种语言性质。
157 0
论文赏析[ACL18]一个句子向量表示究竟可以塞进多少语言性质?
论文赏析[EMNLP18]用序列标注来进行成分句法分析(二)
本文定义了一种新的树的序列化方法,将树结构预测问题转化为了序列预测问题。该序列用相邻两个结点的公共祖先(CA)数量和最近公共祖先(LCA)的label来表示一棵树,并且证明了这个树到序列的映射是单射但不是满射的,但是提出了一系列方法来解决这个问题。
138 0
论文赏析[EMNLP18]用序列标注来进行成分句法分析(二)
|
机器学习/深度学习
论文赏析[EMNLP18]用序列标注来进行成分句法分析(一)
本文定义了一种新的树的序列化方法,将树结构预测问题转化为了序列预测问题。该序列用相邻两个结点的公共祖先(CA)数量和最近公共祖先(LCA)的label来表示一棵树,并且证明了这个树到序列的映射是单射但不是满射的,但是提出了一系列方法来解决这个问题。
176 0
论文赏析[EMNLP18]用序列标注来进行成分句法分析(一)
|
机器学习/深度学习 自然语言处理 算法
论文赏析[NAACL19]基于DIORA的无监督隐式句法树归纳(二)
今天要分享的这篇论文来自NAACL2019,主要利用inside-outside算法推理出给定句子的句法树,不需要任何的监督,也不需要下游任务作为目标函数,只需要masked语言模型就行了。
470 0
论文赏析[NAACL19]基于DIORA的无监督隐式句法树归纳(二)
|
自然语言处理 算法
论文赏析[NAACL19]基于DIORA的无监督隐式句法树归纳(一)
今天要分享的这篇论文来自NAACL2019,主要利用inside-outside算法推理出给定句子的句法树,不需要任何的监督,也不需要下游任务作为目标函数,只需要masked语言模型就行了。
477 0
论文赏析[NAACL19]基于DIORA的无监督隐式句法树归纳(一)
|
机器学习/深度学习 自然语言处理
论文赏析[TACL18]隐式句法树模型真的能学到句子中有意义的结构吗?(二)
本文是一篇分析类论文,主要对近年来几种无监督句法分析模型(RL-SPINN和ST-Gumbel)进行了分析,得出了如下三个结论: 在句子分类任务上,只有一种模型效果好于传统的树结构模型。 这些模型随机性很大,初始化不同,结果也都差距很大。 这些模型产生的句法树的平均深度比PTB数据集的平均深度浅。
538 0
论文赏析[TACL18]隐式句法树模型真的能学到句子中有意义的结构吗?(二)
|
机器学习/深度学习 自然语言处理
论文赏析[TACL18]隐式句法树模型真的能学到句子中有意义的结构吗?(一)
本文是一篇分析类论文,主要对近年来几种无监督句法分析模型(RL-SPINN和ST-Gumbel)进行了分析,得出了如下三个结论: 在句子分类任务上,只有一种模型效果好于传统的树结构模型。 这些模型随机性很大,初始化不同,结果也都差距很大。 这些模型产生的句法树的平均深度比PTB数据集的平均深度浅。
150 0
论文赏析[TACL18]隐式句法树模型真的能学到句子中有意义的结构吗?(一)

热门文章

最新文章