论文笔记《End to end memory networks》

2024-05-27 04:08

本文主要是介绍论文笔记《End to end memory networks》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

论文地址
论文代码


这篇论文在简介中说是基于Memory Network而来的。


论文第一部分介绍说这相当于一个连续型的Memory Network(问号脸,后续看)。这个模型的一个特点是end-to-end,可以被训练为从输入一直到输出,比其他的模型更加的方便。不像Memory Network在每一层都需要监督信息。


模型具体操作流程如下图:
这里写图片描述
在模型训练时输入数据有三部分:一个连续的输入x1,x2,x3…(这部分相当于doc的内容),query q,还有answer a。
先是获取{xi}与query的一个表示(attention),然后这个表示经过多层的hops(多层神经网络),最后得到输出answer a。最后再用pred与a的差值通过方向传播来不断训练模型。


网络分为单层结构和多层结构:

单层网络:

第一步:下图主要介绍了最初对doc({xi})和query的处理步骤,首先还是讲doc和query embedding,然后将他们进行内积运算,再经过softmax层,得到attention表示(这个attention具体含义则是query对于doc中的每个词的注意力分配大小)。
这里写图片描述
第二步:下图则是由attention得到不同注意下分配下的doc的表示,简单解释就是将归一化后的概率值乘以doc表示,得到query”眼中”的doc表示
这里写图片描述
第三步:将得到的o(query眼中的doc表示)与query的emb相加后在经过一个softmax层得到answer的pred值(这里我曾今尝试过用o和query的emb表示继续相乘)。
这里写图片描述

整个模型的结构如下图:左边的是单层结构,右边的是多层(3层)结构的。
这里写图片描述

多层结构:

如图所示:

1,多层结构的每层的输入U(k+1)=U(k) +o(k),这里面的Uk代表的是第k层的query的emb表示,而ok表示的是第k层的attention后的输出,然后将他们加和得到第k+1层的输入,这里也不一定都要用加和的方式。
2,在顶层,最后一层做预测时,将U(k+1)经过softmax处理后,在进行预测。
这里写图片描述


模型细节
论文中一般采用 3 跳网络邻接模:,
其中句子 memory 表示有两种方式 :

1,一种是 bag of words 表示出的向量与 embedding 矩阵 A 相乘得到 memory,即
mi=ΣjAxij
其中 ii 表示第 ii 个句子,jj 表示第 jj 个词。
2,另一种是在它们做 element-wise 乘法时,前面乘上一个系数。
mi=Σjlj⋅Axij
这个系数 ljlj 叫做 Position Encoding,它是一个列向量,用如下公式计算
lkj=(1−j/J)−(k/d)(1−2j/J)
其中 JJ 表示句子中词汇数量,dd 表示 embedding 维度。
很多 QA 任务对上下文有要求,本文采用 Temporal Encoding。为了解决这个问题,用如下公式解决
mi=ΣjAxij+TA(i)
其中 TA(i)TA(i) 表示第 ii 行。cici 也同样用 TC(i)TC(i) 加强。
3,在正则化 TATA 时,引入随机噪音效果会比较好。文中在训练时对于 document 额外添加 10%10% 空的 memory。


总结:
本文一个比较大的特点就是,他引入了一个循环attention机制,与一般的memory network实现相比,他不需要在每一层都引入监督信息。
这里写图片描述

参考地址:https://blog.csdn.net/u014300008/article/details/52794821

这篇关于论文笔记《End to end memory networks》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1006473

相关文章

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

《offer来了》第二章学习笔记

1.集合 Java四种集合:List、Queue、Set和Map 1.1.List:可重复 有序的Collection ArrayList: 基于数组实现,增删慢,查询快,线程不安全 Vector: 基于数组实现,增删慢,查询快,线程安全 LinkedList: 基于双向链实现,增删快,查询慢,线程不安全 1.2.Queue:队列 ArrayBlockingQueue:

操作系统实训复习笔记(1)

目录 Linux vi/vim编辑器(简单) (1)vi/vim基本用法。 (2)vi/vim基础操作。 进程基础操作(简单) (1)fork()函数。 写文件系统函数(中等) ​编辑 (1)C语言读取文件。 (2)C语言写入文件。 1、write()函数。  读文件系统函数(简单) (1)read()函数。 作者本人的操作系统实训复习笔记 Linux

LVGL快速入门笔记

目录 一、基础知识 1. 基础对象(lv_obj) 2. 基础对象的大小(size) 3. 基础对象的位置(position) 3.1 直接设置方式 3.2 参照父对象对齐 3.3 获取位置 4. 基础对象的盒子模型(border-box) 5. 基础对象的样式(styles) 5.1 样式的状态和部分 5.1.1 对象可以处于以下状态States的组合: 5.1.2 对象

DDS信号的发生器(验证篇)——FPGA学习笔记8

前言:第一部分详细讲解DDS核心框图,还请读者深入阅读第一部分,以便理解DDS核心思想 三刷小梅哥视频总结! 小梅哥https://www.corecourse.com/lander 一、DDS简介         DDS(Direct Digital Synthesizer)即数字合成器,是一种新型的频率合成技术,具有低成本、低功耗、高分辨率、频率转换时间短、相位连续性好等优点,对数字信

数据库原理与安全复习笔记(未完待续)

1 概念 产生与发展:人工管理阶段 → \to → 文件系统阶段 → \to → 数据库系统阶段。 数据库系统特点:数据的管理者(DBMS);数据结构化;数据共享性高,冗余度低,易于扩充;数据独立性高。DBMS 对数据的控制功能:数据的安全性保护;数据的完整性检查;并发控制;数据库恢复。 数据库技术研究领域:数据库管理系统软件的研发;数据库设计;数据库理论。数据模型要素 数据结构:描述数据库

【软考】信息系统项目管理师(高项)备考笔记——信息系统项目管理基础

信息系统项目管理基础 日常笔记 项目的特点:临时性(一次性)、独特的产品、服务或成果、逐步完善、资源约束、目的性。 临时性是指每一个项目都有确定的开始和结束日期独特性,创造独特的可交付成果,如产品、服务或成果逐步完善意味着分步、连续的积累。例如,在项目早期,项目范围的说明是粗略的,随着项目团队对目标和可交付成果的理解更完整和深入时,项目的范围也就更具体和详细。 战略管理包括以下三个过程

【软考】信息系统项目管理师(高项)备考笔记——信息化与信息系统

信息化与信息系统 最近在备考信息系统项目管理师软考证书,特记录笔记留念,也希望可以帮到有需求的人。 因为这是从notion里导出来的,格式上可能有点问题,懒的逐条修改了,还望见谅! 日常笔记 核心知识 信息的质量属性:1.精确性 2.完整性 3.可靠性 4.及时性 5.经济性 6.可验证下 7.安全性 信息的传输技术(通常指通信、网络)是信息技术的核心。另外,噪声影响的是信道

flex布局学习笔记(flex布局教程)

前端笔试⾯试经常会问到:不定宽⾼如何⽔平垂直居中。最简单的实现⽅法就是flex布局,⽗元素加上如下代码即 可: display: flex; justify-content: center; align-items :center; 。下⾯详细介绍下flex布局吧。   2009年,W3C提出了 Flex布局,可以简便⼂完整⼂响应式地实现各种页⾯布局。⽬前已得到了所有浏览器的⽀持,这意味着,现