热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

navicat生成er图_实践案例丨ACL2020KBQA基于查询图生成回答多跳复杂问题

摘要:目前复杂问题包括两种:含约束的问题和多跳关系问题。本文对ACL2020KBQA基于查询图生成的方法来回答多跳复杂问题这一论文工作进行了解读
摘要:目前复杂问题包括两种:含约束的问题和多跳关系问题。本文对ACL2020 KBQA 基于查询图生成的方法来回答多跳复杂问题这一论文工作进行了解读,并对相关实验进行了复现。
bbc3462c95a1aa996f58184b2d255d54.png

1、摘要

1.1 复杂问题

1)带约束的问题

2)多跳关系问题

1.2 提出一种改进的阶段式查询图生成方法

1.3 三份数据集上达到SOTA:CWQ、WQSP、CQ

2、介绍

2.1 复杂问题

(1)单跳关系带约束的问题

  • Who was the first president of the U.S.?
  • 单跳关系:“president_of”
  • 已知实体:“U.S.”
  • 约束词:“first”

(2)多跳关系问题

  • Who is the wife of the founder of Facebook?
  • 两跳关系:“wife_of”、“founder_of”

2.2 解决方法:考虑更长的关系路径,但是搜索空间会随着路径的变长呈指数性增长

2.3 挑战:如何限制搜索空间?以前也有一些方法,提出的只考虑匹配的最佳关系,而不是所有关系。但是没有同时处理两种类型的复杂问题。

2.4 方案:束搜索(beam search)

2.5改进:路径扩展 + 合并约束,串行 → 并行,有效地减少了搜索空间

3、方法

3.1、预备工作

(1)KB

    • K={(h,r,t)}
    • h,t 来自实体集合 E
    • r 来自关系集合 R

(2)KBQA:给定一个问题Q,从KB中找到一个答案a

3.2、阶段查询图方法

(1)四种类型的节点,如下图所示

  • A grounded entity 接地实体/对齐实体:KB中已存在的一个实体,至少有一个(阴影矩形)
  • An existential variable 未接地实体/存在变量/中间变量:0个或者多个(无阴影矩形)
  • A lambda variable 未接地实体/未知变量:表示答案,有且只有一个(圆形)
  • An aggregation funciton 聚合函数:最大/最小/求和等操作,0个或者多个(菱形)

(2)查询图的边是KB中的 r

09e711f51b7be80539e4837511cc2a83.png

(3)查询图的生成过程就是SPARQL查询语句生成的过程,如下图所示。注:与上图例子不完全符合。

其中,ns:m.0k2kfpc 是接地实体的MID(Freebase),?name3 是未知变量,?e1、?e2、?e3、?e4 等是中间变量。

6c0e811eb27a73f02f6668722b1e1616.png

3.3、阶段查询图生成的一般过程

1)从问句中的一个接地实体(topic entity)开始,识别一条核心关系路径(core relation path),将主题实体连接到一个lambda变量;

2)给核心关系路径添加一个或多个约束,这个约束包含一个接地实体或者一个带关系的聚合函数;

3)生成候选查询图,度量和问句的相似度,排序(CNN等神经网络);

4)取top1,在知识图谱上执行查询图,获得答案。

注:核心关系路径,在其他论文里叫核心推理链,或者叫基本查询图

3.4、动机

(1)问题:

    • 已有方法只考虑单个关系或两个关系的核心路径,无法解决多关系约束问题;
    • 如果允许核心关系路径变长,搜索空间会剧增;
    • CWQ数据集上,每个问题三跳情况下会有10000条路径。

(2)束搜索(beam search)

    • 在生成 t+1 跳关系路径时,只保留 top-K 个 t 跳关系路径,即每次路径只生成 K 个;
    • 已有方法忽视了约束这个条件,只考虑通过路径减少搜索空间;
    • 问题中的约束也可以帮助减少搜索空间,引导核心路径朝正确的方法生成。

(3)改进的阶段式查询图生成方法

    • 在附加约束前,不需要生成所有的核心关系路径;
    • 束搜索和语义匹配结合,得到一个更小的搜索空间。
    • 给定一个部分核心路径 (The Jeff Probst Show, nominated for, y1, nominee, y2),如果在y2上扩展一个关系,需要考虑KB中连接y2的所有关系,但是如果先加一个约束(is a, TV producer),将只考虑电视制片人被提名为xx show的人。

3.5、查询图生成

(1)束搜索生成查询图

  • 假设第 t 次迭代生成了 K 个查询图,表示为 G_t;
  • 第 t+1 次迭代,对于每个图 g∈G_t,使用三个操作 {extend, connect, aggregate} 增加一条边和一个节点,如下图所示;
  • 所有生成的图集合表示为 G′_(t+1) ,使用得分函数排序,取 top-K 个 ,得到候选查询图 G_(t+1);
  • 继续迭代,直到没有 g∈G_(t+1) 得分比 g∈G_t 高。
482d953e1a03862893beba841bf8801f.png

(2)扩展操作(extend)

    • 增加一个关系;
    • 如果当前查询图只有一个主题实体 e,扩展操作就增加 e 的一个关系 r ,另一端作为lambda变量 x ;
    • 如果当前查询图含有一个lambda变量 x ,扩展操作就将 x 转成一个existential变量 y ,找到 y 的关系 r ,生成新的lambda变量 x 。

(3)连接操作(connect)

    • 除了主题实体外,问题中经常会出现一些其他的接地实体 e ;
    • 连接操作将这个接地实体 e 链接到 lambda 变量 x 或者与 x 连接的existential变量。

(4)聚合操作(aggregate)

    • 预定义一个关键词集合,检测约束词;
    • 聚合操作将约束词作为一个节点连接 lambda 变量 x 或者与 x 连接的existential变量。

(5)方法的创新性:扩展操作可以应用在连接或者聚合操作后面,以前的方法不行。

    • 以前:扩展 → 扩展 →......→ 扩展 → 连接或聚合
    • 现在:扩展、连接、聚合 → 扩展、连接、聚合 →......→ 扩展、连接、聚合

3.6、查询图排序

(1)方法:第 t 次迭代,排序候选查询图 G′_t,通过生成一个7维的特征向量,输入到全连接层,计算分数。

(2)特征

第1维:

      • 基于BERT的语义匹配模型;(Pytorch版:https://github.com/huggingface/transformers)
      • 将查询图 g∈G′_t 转成一个词序列,按照图的生成顺序
      • 忽视中间变量和未知变量
      • 下图的查询图生成的序列:(the, jeff, probst, show, nominated, for, nominee).
c0e0944c3809b51c63a600045e25cae8.png

第2维:所有接地实体的实体链接得分累加和;(谷歌的实体链接工具:https://developers.google.com/knowledge-graph)

第3维:接地实体的数量;

第4维:实体类型的数量;

第5维:时间表达式的数量;

第6维:最高级表达式的数量;

第7维:答案实体的数量。

(3)强化学习方法,学习决策函数。

4、实验

(1)数据

    • ComplexWebQuestons (CWQ) 数据量:34689
    • WebQuestionsSP (WQSP) 数据量:4737
    • ComplexQuestions (CQ) 数据量:2100

(2)结果

bf307396a66a64ea2e01c77d13cafcb2.png

(3)消融实验

模型性能的提升,不仅仅与BERT有关。

77dae890f508b624dbaadb9f84345033.png

论文:Lan Y, Jiang J. Query Graph Generation for Answering Multi-hop Complex Questions from Knowledge Bases[C]//Proceedings of the 58th Annual Meeting of the Association for Computational Linguistics. 2020: 969-974.

链接:https://www.aclweb.org/anthology/2020.acl-main.91/

代码:https://github.com/lanyunshi/Multi-hopComplexKBQA

点击关注,第一时间了解华为云新鲜技术~



推荐阅读
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文探讨了如何在iOS开发环境中,特别是在Xcode 6.1中,设置和应用自定义文本样式。我们将详细介绍实现方法,并提供一些实用的技巧。 ... [详细]
  • 本文深入探讨了二叉搜索树(Binary Search Tree, BST)及其操作,包括查找、插入和删除节点。同时,文章还介绍了平衡二叉树(AVL树)的概念及调整方法,并详细讨论了如何判断两个序列是否构成相同的二叉搜索树。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 作为一名专业的Web前端工程师,掌握HTML和CSS的命名规范是至关重要的。良好的命名习惯不仅有助于提高代码的可读性和维护性,还能促进团队协作。本文将详细介绍Web前端开发中常用的HTML和CSS命名规范,并提供实用的建议。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文详细介绍了在企业级项目中如何优化 Webpack 配置,特别是在 React 移动端项目中的最佳实践。涵盖资源压缩、代码分割、构建范围缩小、缓存机制以及性能优化等多个方面。 ... [详细]
  • 本文详细介绍了如何解决OBS在全屏录制时出现黑屏的问题,并提供了关于正确配置显卡以实现高效推流的指导。通过调整操作系统和显卡设置,确保OBS能够稳定运行并提供高质量的直播或录制体验。 ... [详细]
  • 本文探讨了2012年4月期间,淘宝在技术架构上的关键数据和发展历程。涵盖了从早期PHP到Java的转型,以及在分布式计算、存储和网络流量管理方面的创新。 ... [详细]
  • Python第三方库安装的多种途径及注意事项
    本文详细介绍了Python第三方库的几种常见安装方法,包括使用pip命令、集成开发环境(如Anaconda)以及手动文件安装,并提供了每种方法的具体操作步骤和适用场景。 ... [详细]
author-avatar
_LiNanaP
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有