0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

求一种基于结构统一M叉编码树的求解器解决方案

深度学习自然语言处理 来源:南大NLP 作者:王斌 2022-11-12 10:25 次阅读

01

研究动机

数学问题(英文叫Math Word Problem,简称MWP)的求解要求给定一段描述文本,其中包含对于若干已知变量和一个未知变量的描述,要求利用变量间的数值关系来推理计算出未知变量的准确数值。

一个具体的例子如下图1所示,可以发现一个数学问题可能对应着多个正确的表达式或二叉树,有着非确定性的输出空间,而目前主流方法输入问题文本序列来学习特定单个表达式序列或二叉树的生成,使得模型所学到的知识不完整,并需要大量数据来提升性能,限制了模型在低资源场景下的表现。

e62705a4-622e-11ed-8abf-dac502259ad0.png

图1: MWP问题示例

对于MWP的输出多样性,分析原因如下:

1、计算顺序的不确定性:a)运算之间常拥有相同的计算优先级。如n1 + n2 + n3 − n4 中的三个运算符优先级一样,可以等价转换为不同的序列或二叉树;b)数学表达式中括号的使用给计算顺序也带来了不确定性。如n1 + n2 − n3, n1 − (n3 − n2) 和 (n1+n2)−n3都是等价的表达;

2、运算的可交换性带来的不确定性:加法和乘法操作两边的算子可以进行交换且不影响计算逻辑与最终结果,使得输出的结构具有多样性的表达,如n1 + n2 × n3可以转换为n1+n3×n2,n2×n3+n1等;

为了解决由多样性给问题求解带来的挑战,我们提出了基于结构统一M叉编码树的数学问题求解器。针对第一点原因,在二叉树的结构基础上,我们设计了拥有任意分支数量的M-tree,在竖直方向上对树的结构进行统一;针对第二点,我们在M-tree中重新定义了新的M元运算,使得所有的运算都满足可交换性,将只在子节点左右顺序不一样的两棵M-tree视为相同的结构,从而在水平方向对树的结构进行统一。

而为了学习输出M-tree,我们放弃了进行自上而下且从左到右的自回归式生成方法,因为该方法不能避免由于子节点左右顺序的变化而带来的输出(one by one)多样性。我们首先对M-tree进行编码,将其转换为M-tree codes形式的等价表达,用于保存M-tree的结构信息,其中每个code对应M-tree中的一个叶子节点,保存从根节点到叶子节点的路径以及叶子节点本身的信息。

通过一个sequence to code(seq2code)模型学习从输入问题文本序列到每个code的映射,以非自回归的方式生成输出。

02

贡献

1、我们分析了MWP中输出多样性的原因,创新地设计了一个基于M树的方案来统一输出结构;

2、我们设计了M-tree codes来等价表示M-tree,并提出了一个seq2code模型来以非自回归的方式生成codes,据我们所知这是第一个利用M-tree codes和seq2code来分析求解MWP的工作;

3、在广泛使用的Math23K和MAWPS数据集上的实验结果表明,SUMC-Solver在同等实验设置下优于以前的方法。尤其是在低资源的情况下,我们的求解器取得了更好的性能表现。

03

解决方案

方法的整体示例及模型框架如下图2所示,下面介绍M-tree,M-tree codes和seq2code模型的设计。

M-tree的设计:M-tree具有两种节点——内部节点和叶子节点,其中内部节点拥有任意M个子分支(M>=1)且对应四种M元运算:{ +,x,x-,+/ },这四种M元运算都具有可交换性,叶子节点有四种:{原始数值v,v的负数,v的倒数,v的倒数的相反数};定义M-tree的根节点为+类型节点,任何两棵仅在子节点左右顺序不一样的M-tree会被视为同一颗。

M-tree codes的设计:由于M-tree中的内部节点可以拥有任意数量的子分支,且兄弟节点在结构上的位置是等价的,所以基于自回归式的生成不能避免由于兄弟节点的顺序在输出端造成的多样性。为了解决这一难题,我们将M-tree的结构信息编码到每个叶子节点中,在M-tree和叶子节点的codes集合之间形成一个映射,这样模型就能以非自回归的方式生成codes。

具体而言,每个叶子节点的M-tree code由两部分组成:一部分保存数值信息,会使用两个二进制位来区分数值的四种形式,另一部分由根节点到当前叶子节点的路径信息构成。

seq2code模型框架:为了验证M-tree和M-tree codes的先进性,我们设计了一个简单的seq2code模型来求解MWP,它将问题文本序列作为其输入,然后输出问题中数值的相应code(以向量表示)。在结合所有的codes以恢复M-tree之后,我们可以计算出问题的最终答案。整个模型由两部分组成:问题编码器和code生成器。a)问题编码器将MWP的单词转化为向量表示,我们的实验中编码器有两种选择:循环神经网络(RNN)编码器或预训练语言模型(PLM)编码器;b)我们使用了一个简单的三层前馈神经网络(FFNN)来作为生成器。

e64824a0-622e-11ed-8abf-dac502259ad0.png图2: SUMC-Solver问题求解示例与模型框架

04

实验

实验结果展示在表1中。SUMC-Solver在两个MWP数据集上的表现优于所有的基准模型。当使用RNN编码器时,SUMC-Solver的准确率比学习表达式序列输出的StackDecoder和T-RNN 高约9-10%。相比学习二叉树输出的方法,SUMC-Solver也取得了比GTS、SAU-Solver和Graph2Tree更好的结果,尽管这些方法使用了精心设计的树解码器或丰富输入表示的图编码器。

当使用预训练语言模型(PLM)作为编码器时,SUMC-Solver达到了82.5%的准确率,比GTS-PLM和UniLM-Solver有了明显的提高(分别为3%和5%)。总之,上述两种不同编码器设置下的结果都表明,M-tree和M-tree codes的设计是合理和先进的,这使得我们只用一个简单的seq2code模型就可以达到更好的性能。

表1:各模型在基准数据集上的性能对比

e673bac0-622e-11ed-8abf-dac502259ad0.png

表1中在Math23K数据集上展示的是在公共测试集上的结果,在MAWPS*上展示的是5折交叉验证的结果,带 † 的结果是由我们复现得到的。

MWP的人工标注成本很高,因此提升该模型在低资源场景下的表现是有必要的。我们用不同数据规模的训练集来评估GTS、SAU-Solver和Graph2Tree的性能。测试集统一包含2,312个随机抽样的实例。详细的结果可以在图3中找到。可以看出,无论训练集的大小如何,SUMC-Solver的性能始终优于其他模型。

首先,当训练集的规模小于6000时,SAU-Slover的性能优于GTS;当数量超过6000时,这两个模型的性能相似。就整体性能而言,在资源受限的情况下,SAU-Solver和Graph2Tree的结果比GTS的好。其次,在6000个样本的训练集下,SUMC-Solver和其他模型之间出现了最明显的性能差距,我们的模型在准确率上大约提升了5%。这表明SUMC-Solver在低资源情况下具有突出的优势。

e6a92b24-622e-11ed-8abf-dac502259ad0.png

图3:低资源场景下的模型性能对比

此外,我们根据问题计算答案所需的操作数(问题中的某些数值)将测试集(2,312个随机抽样的实例)分为不同的等级,并在不同等级的数据上对比模型性能。详细情况可见图4。从结果中,我们可以看到,大多数的MWP需要2到4个操作数,而SUMC-Slover在需要更多操作数的数据上表现得比基准模型更好,这表明我们的求解器有潜力解决更复杂的问题。

e6cb7422-622e-11ed-8abf-dac502259ad0.png

图4:不同模型在需要不同操作数的测试数据上正确回答问题数量的对比

最后,seq2code框架也可以应用于二叉树结构,例如可为每个MWP选择一个二叉树结构的输出,并以同样的方法将其转换为codes。我们对Math23K的训练集数据进行了转换,并对二叉树codes和M-tree codes进行了比较,结果如下表2所示。可以看出,应用M-tree可以大大减少codes集合的大小,并保证得到的codes能够覆盖测试集,这说明M-tree对统一输出结构的效果非常明显。

表2:二叉树与M-tree编码对比

e6f063f4-622e-11ed-8abf-dac502259ad0.png

05

总结

针对数学问题求解的输出多样性,我们提出了SUMC-Slover求解器,其应用M-tree来统一多样化的输出,以及seq2code模型来学习M-tree。在广泛使用的MAWPS和Math23K数据集上的实验结果表明,SUMC-Solver在类似的设置下优于目前一些最先进的方法,并且在低资源场景下有着更好的表现。





审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 编码器
    +关注

    关注

    45

    文章

    3658

    浏览量

    134977
  • PLM
    PLM
    +关注

    关注

    2

    文章

    124

    浏览量

    20887
  • 求解器
    +关注

    关注

    0

    文章

    77

    浏览量

    4542

原文标题:EMNLP'22 | 基于结构统一M叉编码树的数学问题求解器

文章出处:【微信号:zenRRan,微信公众号:深度学习自然语言处理】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    一种基于ZigBee的驾驶辅助系统解决方案

    一种基于ZigBee的驾驶辅助系统解决方案
    发表于 05-14 06:22

    一种射频开关的解决方案

    一种射频开关的解决方案
    发表于 05-21 06:46

    一种NXP最新的NFC电子钱包解决方案

    NFC电子钱包总体结构是怎样构成的?一种NXP最新的NFC电子钱包解决方案
    发表于 05-24 06:44

    一种基于ARM Cortex-M处理的音频解决方案

    一种基于ARM Cortex-M处理的音频解决方案
    发表于 06-01 06:32

    一种LCD和LED冲突的解决方案

    一种LCD和LED冲突的解决方案
    发表于 01-25 07:12

    一种求解关键路径的新算法

    通过定义节点编码图概念,提出一种不需要拓扑排序的求解关键路径的新算法。该算法扩充图的邻接表的存储结构,使图的存储与算法求解过程共享同
    发表于 04-23 10:29 7次下载

    基于四的分形图像编码中的剖分决策函数

    基于四的分形图像编码中的剖分决策函数 为了得到可变的位率,在分形图像压缩中经常采用四分割方法。该文提出了
    发表于 02-22 14:20 18次下载

    基于HBase的四Hilbert索引设计

    随着遥感技术的发展,遥感数据的类型和量级发生了巨大变化,对于传统的存储方法产生了挑战。针对HBase中海量地形数据管理效率不高的问题,提出一种- Hilbert相结合的索引设计方法。首先,对传
    发表于 01-07 10:01 1次下载
    基于HBase的四<b class='flag-5'>叉</b><b class='flag-5'>树</b>Hilbert索引设计

    4中二叉树的遍历方式介绍

    对于一种数据结构而言,遍历是常见操作。二叉树一种基本的数据结构,是一种每个节点的儿子数目都不多于2的
    的头像 发表于 04-27 17:23 4814次阅读
    4中二<b class='flag-5'>叉树</b>的遍历方式介绍

    叉树一种基础的数据结构类型

    然后我们再定义棵深度也为 3 的二叉树,该二叉树的 n 个结点(n≤7),当从 1 到 n 的每个结点都与上图中的编号结点一一对应时,这二叉树就称为完全二
    的头像 发表于 04-13 10:48 4383次阅读
    二<b class='flag-5'>叉树</b>,<b class='flag-5'>一种</b>基础的数据<b class='flag-5'>结构</b>类型

    详解电源二叉树到底是什么

    作为数据结构的基础,分很多种,像 AVL 、红黑、二搜索....今天我想分享的是关于二
    的头像 发表于 06-06 15:05 1w次阅读
    详解电源二<b class='flag-5'>叉树</b>到底是什么

    基于三链表的编译中间结构的设计方案研究

    基于树形结构的中间结构是现今大多数编译中间结构的主流设计方案,比如GCC、LCC、TCC等均使用二叉树
    的头像 发表于 05-14 09:13 3573次阅读
    基于三<b class='flag-5'>叉</b><b class='flag-5'>树</b>链表的编译<b class='flag-5'>器</b>中间<b class='flag-5'>结构</b>的设计<b class='flag-5'>方案</b>研究

    红黑(Red Black Tree)是一种自平衡的二搜索

    平衡(Balance):就是当结点数量固定时,左右子树的高度越接近,这棵二叉树越平衡(高度越低)。而最理想的平衡就是完全二叉树/满二叉树,高度最小的二叉树
    的头像 发表于 07-01 15:05 5774次阅读
    红黑<b class='flag-5'>树</b>(Red Black Tree)是<b class='flag-5'>一种</b>自平衡的二<b class='flag-5'>叉</b>搜索<b class='flag-5'>树</b>

    叉树操作的相关知识和代码详解

    是数据结构中的重中之重,尤其以各类二叉树为学习的难点。在面试环节中,二叉树也是必考的模块。本文主要讲二叉树操作的相关知识,梳理面试常考的内
    的头像 发表于 12-12 11:04 2070次阅读
    二<b class='flag-5'>叉树</b>操作的相关知识和代码详解

    C语言数据结构:什么是二叉树

    完全二叉树:完全二叉树是效率很高的数据结构。对于深度为K,有n个节点的二叉树,当且仅当每个节点都与深度为K的满二
    的头像 发表于 04-21 16:20 2592次阅读