【seq2seq】深入浅出讲解seq2seq神经网络模型

news/2024/11/28 7:46:55/
  • 本文收录于《深入浅出讲解自然语言处理》专栏,此专栏聚焦于自然语言处理领域的各大经典算法,将持续更新,欢迎大家订阅!
  • 个人主页:有梦想的程序星空
  • 个人介绍:小编是人工智能领域硕士,全栈工程师,深耕Flask后端开发、数据挖掘、NLP、Android开发、自动化等领域,有较丰富的软件系统、人工智能算法服务的研究和开发经验。
  • 如果文章对你有帮助,欢迎关注点赞收藏订阅。

1.Seq2seq背景:

经典的循环神经网络模型的输入序列以及输出序列要求是等长的,然而在机器翻译中,如输入序列:“机器学习”,输出序列:“Machine Learning”,输入输出序列不等长,循环神经网络就不能满足这样的情况。

Seq2seq可以用来处理输入输出序列不等长的问题,是一种特殊的RNN模型。

2.Seq2seq概述:

Seq2seq是一种编码(Encoder)-解码(Decoder)的结构,输入和输出可以是不等长的序列。

Seq2seq包括三个部分:编码器,解码器,以及连接两者的固定大小的状态向量。Encoder通过学习输入,将其编码成一个固定大小的状态向量,然后将状态向量传给Decoder,Decoder再通过对状态向量的学习来进行输出。

3.Seq2seq 编码器(Encoder):

Encoder是一个RNN,也可以是LSTM、GRU等,接收的是每一个单词的词向量,和上一个时间点的隐藏状态。输出的是这个时间点的隐藏状态。其中激活函数可以是sigmoid、tanh、Relu、softmax等。

读完序列中每个单词后,会得到一个固定长度的语义向量。

4.Seq2seq解码器(Decoder):

Decoder是个RNN,也可以是LSTM、GRU等,将encoder得到的语义向量作为初始状态输入到Decoder的RNN中,得到输出序列。可以看到上一时刻的输出会作为当前时刻的输入,而且其中语义向量只作为初始状态参与运算,后面的运算都与语义向量无关。

decoder处理方式还有另外一种,就是语义向量参与了序列所有时刻的运算,上一时刻的输出仍然作为当前时刻的输入,但语义向量会参与所有时刻的运算。

解码器的输出通常有如下几种方法:

(1)贪婪:输出对应最大概率值的单词,计算代价低。

(2)采样:通过对众多概率值采样输出单词。

(3)集束搜索:是一种启发式的算法,提高多个预测创建一个可能结果的扩展树。

5.seq2seq的相关论文:

(1)原始的模型:https://arxiv.org/pdf/1406.1078.pdf,

题目为:Learning Phrase Representations using RNN Encoder–Decoder for Statistical Machine Translation,由cho在2014年提出。

(2)改进的模型:https://arxiv.org/pdf/1409.3215.pdf,

题目为:Sequence to Sequence Learning with Neural Networks。

(3)融入Attention机制的模型:https://arxiv.org/pdf/1409.0473.pdf,

题目为:NEURAL MACHINE TRANSLATION BY JOINTLY LEARNING TO ALIGN AND TRANSLATE。

6.seq2seq的应用场景:

(1)机器翻译

(2)情感对话生成

(3)文本自动摘要

(4)图片自动描述


http://www.ppmy.cn/news/494737.html

相关文章

移动网络http请求不到数据,wifi下可以

今天客户反馈手机登录不上去,用wifi可以,但是切换到移动网络就不行。 查找相关文档 发现由于 Android P(版本27以上) 限制了明文流量的网络请求,非加密的流量请求都会被系统禁止掉。所以如果当前应用的请求是 htttp 请求,而非 https ,这样就会导系统禁止当前应用进行该请求…

在win10家庭版系统中使用远程桌面连接

windows 10家庭版系统和专业版相比有很多功能限制,最近在新电脑上连接远程桌面控制阿里云时就遇到了很多问题,远程桌面连接Window Server时报错信息如下: 如果在专业版系统里还是很好解决的。只要在本地组策略改一下Oracle修正就可以了。 具体步骤如下: 运行 gpedit.msc 本…

Python安装教程(Win10)以及双击安装包无反应的解决方法

文章目录 一、安装Python双击安装包无反应的解决方法 二、安装pip(使用Microsoft Store安装的Python可以无视这步) 一、安装Python 访问http://www.python.org/download/选择需要的版本进行安装。因为2.0和3.0并不兼容,非特殊情况的话请选择…

Java中4种访问权限修饰符

在Java编程语言中有四种权限访问控制符,这四种访问权限的控制符能够控制类中成员的可见性。 一、public (1)定义:public是公共的,被public所修饰的成员可以在任何类中都能被访问到。 (2)修饰的成分: public能用来修饰类,在一个java源文件中只能有一个类被声明为public…

Python新书上市,强烈推荐!《Python网络数据爬取及分析从入门到精通(爬取篇)》导读

Python新书上市,强烈推荐! 《Python网络数据爬取及分析从入门到精通(爬取篇)》导读 内容简介 本书主要包括上下两册: 《Python网络数据爬取及分析从入门到精通(爬取篇)》 《Python网络…

win10 U盘装机找不到启动盘等问题

文章目录 设置BIOS制作WinPE系统 设置BIOS UEFI快速启动:优点开机速度快,一般新电脑都支持此模式。传统模式启动:缺点开机速度不够快,一般老旧电脑只支持此模式。 目前很多厂家的BIOS更新,导致U盘安装系统只支持UEFI…

计算机网络中的c类地址,计算机网络中的A类、B类、C类地址的划分

A类地址的第一组数字为1~126。注意,数字0和 127不作为A类地址,数字127保留给内部回送函数,而数字0则表示该地址是本地宿主机,不能传送。 范围:1.0.0.1到126.255.255.254 B类地址的第一组数字为128&#xff…

[网络安全自学篇] 十五.Python攻防之多线程、C段扫描和数据库编程(二)

这是作者的系列网络安全自学教程,主要是关于网安工具和实践操作的在线笔记,特分享出来与博友共勉,希望您们喜欢,一起进步。前文分享了Python网络攻防相关基础知识,包括正则表达式、Web编程和套接字通信,本文将继续分析Python攻防之多线程、C段扫描和数据库编程。本文参考…