时间序列预测系列之循环神经网络

news2024/12/24 3:19:00

文章目录

  • 1.前言
  • 2.RNN基础组件
    • 1.RNN
    • 2.LSTM
    • 3.GRU
    • 4.FC-LSTM
    • 5.ConvLSTM
    • 6.CNN-LSTM

1.前言

循环神经网络(Recurrent Neural Network,简称RNN)是一类在处理序列数据和时间序列数据时非常有用的神经网络架构。RNN的主要特点是它们具有循环连接,允许信息从一个时间步传递到下一个时间步,从而捕获时间依赖性和序列关系。正是由于RNN这种可以处理上下文依赖的特性,在机器翻译、文本生成、情感分析、语音识别、时间序列预测、图像描述生成、和游戏AI等各领域得到广泛应用

注:虽然RNN在许多序列建模任务中表现出色,但它们也有一些局限性,包括计算资源要求较高和难以捕获非常长的依赖性。因此,在某些情况下,其他神经网络架构,如卷积神经网络(CNN)和注意力机制(Attention Mechanism),可能更适合处理序列数据

循环神经网络包括RNN、LSTM、GRU、FC LSTM、ConvLSTM等基础组件

2.RNN基础组件

1.RNN

RNN在全连接网络基础上加入了时序关联的结构:即增加 s t s_t st来表示隐藏层在不同时刻的状态,其中每个时刻的隐藏状态 s t s_t st由上一层隐藏状态 s t − 1 s_{t-1} st1和权重 W W W,输入 x t x_t xt和权重 U U U以及偏置 b b b决定,每个时刻输出则由计算得到的当前层隐藏状态 s t s_t st和输出权重 V V V来决定,其中每个时刻的 W U V WUV WUV权重矩阵都是共享的。

优点:

  • 1.RNN很适合处理序列数据,因为考虑了之前的信息。
  • 2.可以和CNN一起使用得到更好的效果。

缺点:

  • 1.由于在训练过程中的 W U V WUV WUV权值共享,容易出现梯度爆炸或者梯度消失的情况。
  • 2.RNN相较于其他CNN和全连接需要更多的显存空间,更难训练。
  • 3.如果使用tanh、relu作为激活函数,没办法处理太长的序列。

在这里插入图片描述

在这里插入图片描述

2.LSTM

RNN容易出现梯度消失和爆炸,并且随着时间序列或距离增加,RNN会变得无法连接相关信息,即出现记忆问题,通常超过十步就不行了,为了解决这些问题,研究者在普通RNN的基础上提出了LSTM(Long Short-term Memory,长短期记忆网络),LSTM在RNN基础上新增了记忆单元 c t c_t ct,记忆单元可以分解为输入门 i t i_t it、遗忘门 f t f_t ft、输出门 o t o_t ot,这些门通过权重和激活函数来控制信息的流动:

  • 输入门 i t i_t it用于控制当前输入 x t x_t xt有多少保存到 c t c_t ct
  • 遗忘门 f t f_t ft用于控制信息的保留和遗忘
  • 输出门 o t o_t ot用于控制记忆单元 c t c_t ct对当前隐藏状态 s t s_t st的影响

它们都由各自的权重和当前时刻输入 x t x_t xt和上一时刻隐藏状态 s t − 1 s_{t-1} st1决定,得到三个门后,就可以得出记忆单元 c t c_t ct和隐藏状态 s t s_t st

  • 记忆单元 c t c_t ct由上一时刻记忆单元 c t − 1 c_{t-1} ct1的部分信息和输入门 i t i_t it的部分信息组成, 其中 c t − 1 c_{t-1} ct1部分信息由遗忘门 f t f_t ft控制
  • 隐藏状态 s t s_t st由输出门 o t o_t ot和记忆单元 c t c_t ct决定

LSTM因计算量稍大,不能处理空间信息等缺点,后又引申出多种变体,如GRU、FC-LSTM、 ConvLSTM
在这里插入图片描述
在这里插入图片描述

3.GRU

为了解决LSTM计算量较大的问题,出现了另一个广泛流行RNN变体是GRU,GRU没有窥视孔连接和输出激活函数,也没有线性自连接的记忆单元,而是直接线性累积在隐藏状态 s t s_t st上。GRU包含更新门 u t u_t ut和重置门 r t r_t rt

  • 更新门 u t u_t ut由LSTM中的输入门和遗忘门耦合而成,用于控制前一时刻的记忆状态(或隐藏状态)是否被传递到当前时刻,当 u t = 0 ut = 0 ut=0,无论序列有多长,都可以保持最初时间步中的信息
  • 重置门 r t r_t rt控制如何将当前的输入与前一时刻的记忆状态结合起来
    相比于LSTM,GRU通常具有更快的训练速度,并且在某些任务上和LSTM相当,但是LSTM在处理长序列和学习长期依赖关系方面表现可能更加出色。
    在这里插入图片描述

4.FC-LSTM

全连接LSTM,又称带窥视孔连接LSTM,相比于传统LSTM增加了三个门控单元和记忆单元的连接,叫全连接的原因是输入到三个门和记忆单元间是通过全连接层,即矩阵乘法来实现的,由于增加了门和记忆单元之间的连接,使得处理速度更慢。

在这里插入图片描述

5.ConvLSTM

和FC-LSTM主要的不同点在于ConvLSTM将输入到门之间的全连接层使用卷积计算来代替,也就是矩阵乘法变成了卷积计算,使得输入由3维变为了5维,即
(batchsize, timestamps, features) -> (batchsize, timestamps, channel size, row, column)
在这里插入图片描述
在这里插入图片描述

6.CNN-LSTM

注意到CNN-LSTM和ConvLSTM的区别在于,ConvLSTM是按时间步处理数据,而CNN-LSTM是先通过卷积提取特征,通过矩阵变换等操作,将数据处理成3维,输入LSTM后再反卷积回去,在此过程中可能会丢失一些信息,实际上,CNN在这里起到编码器和解码器的作用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1006572.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

QT网页 webengine / CEF

QT WebEngine 官方文档 WebEngine 架构: 能看到 WebEngine 有一个核心模块是基于 Chromium 构造的,通过使用 Chromium 的Blink渲染引擎和V8 JavaScript引擎来处理和渲染Web内容,并将这些底层技术封装为一系列高级的C类和接口,以…

JVM基础-Hotspot VM相关知识学习

这里写目录标题 jdkJVM虚拟机类类的生命周期类加载的时机类的双亲委派机制类的验证 java对象Mark WordKlass Pointer实例数据对齐数据 字符串常量池垃圾收集器1.Serial收集器(串行收集器)cms垃圾算法G1垃圾收集器与CMS收集器相比, G1收集器的优势:G1收集…

开利网络到访东家集团,沟通招商加盟数字化机制落地事项

近日,开利网络到访东家集团,就集团近日开展的奖金池激励制度的推进情况和市场反馈进行复盘与沟通。通过打破“层层中间商”,提供厂家直供价格的方式,东家集团推出了数字化激励机制,消费集团会员礼包即可在会员专区进行…

Layui快速入门之第五节 导航

目录 一:基本概念 导航依赖element模块 API 渲染 属性 事件 二:水平导航 常规用法: 三:垂直导航 四:侧边垂直导航 五:导航主题 六:加入徽章等元素 七:面包屑导航 ps&a…

大学经典题目:Java输出杨辉三角形

本节利用​ 过 Java 语 ​言中的流程控制语句,如条件语句、循环语句和跳转语句等知识输出一个指定行数的杨辉三角形。 杨辉三角形由数字进行排列,可以把它看作是一个数字表,其基本特性是两侧数值均为 1,其他位置的数值是其左上方数…

Kettle——大数据ETL工具

文章目录 ETL一、Kettle二、安装和运行Kettle三、Kettle使用四、Kettle核心概念可视化转换步骤跳 ETL ETL(Extract-Transform-Load,即数据抽取、转换、转载),对于企业或行业应用来说,我们经常会遇到各种数据的处理,转换&#xff…

【操作系统】进程的概念、组成、特征

概念组成 程序:静态的放在磁盘(外存)里的可执行文件(代码) 作业:代码+数据+申请(JCB)(外存) 进程:程序的一次执行过程。 …

5. 自动求导

5.1 向量链式法则 ① 例子1是一个线性回归的例子,如下图所示。 5.2 自动求导 5.3 计算图 5.4 两种模型 ① b是之前计算的结果,是一个已知的值。 5.5 复杂度 5.6 自动求导 import torch x torch.arange(4.0) x 结果: ② 在外面计算y关于x的…

linux 用户、组操作

一、创建用户并设置密码 #创建用户 duoergun useradd duoergun #设置用户 duoergun 密码 passwd duoergun二、创建组 #创建组 qingdynasty groupadd qingdynasty三、用户添加到组,用户从组删除 #添加用户duoergun到组qingdynasty usermod -aG qingdynasty duoer…

【CSS】React项目如何在CSS样式文件中使用变量

需求 在修改样式时候,需要根据不同条件,使用不同的样式,使用动态类需要多重判断,是否考虑使用变量传入的方式呢 应该怎么做 tsx import ./App.css; import ./test.cssfunction App() {const styles {--var: white,};return (…

20230912java面经整理

1.gc算法有哪些 引用计数(循环引用)和可达性分析找到无用的对象 标记-清除:简单,内存碎片,大对象找不到空间 标记-复制:分成两半,清理一半,没有碎片,如果存活多效率低&a…

Bigemap 在土地图利用环境生态行业中的应用

工具 Bigemap gis office地图软件 BIGEMAP GIS Office-全能版 Bigemap APP_卫星地图APP_高清卫星地图APP Bigemap 在土地图利用环境生态行业中的应用  使用场景 : 1. 土地利用占地管理: 核对数据,查看企业的实际占地是否超出宗地&…

电商运营管理——广告系统

广告位对于电商平台而言,具有非常重要的作用。如何设计一个广告位是本篇文章重点讲述的内容,作者从六个方面出发,系统地介绍该如何去搭建一个广告位,能为产品设计的同学提供一些思路。 对于电商平台,广告位无论是对产品…

制造业企业使用哪种ERP系统好?金蝶还是用友?

制造业企业使用哪种ERP系统好?金蝶还是用友? 综合来看,这几位都算是是典型的ERP软件,它有着ERP软件应该有的基础功能,并且做的也比较成熟。下面是本文对这几个软件的总结 金蝶: 优势:1.产品丰…

mysql逻辑备份和恢复

备份恢复指令 1 全备 (变量为密码、端口号、输出路径。 --compress支持压缩) mysqldump -uroot -p*** -P*** --single-transaction --master-data2 --flush-logs --hex-blob --flush-privileges --triggers --routines --events --all-databases > …

【100天精通Python】Day61:Python 数据分析_Pandas可视化功能:绘制饼图,箱线图,散点图,散点图矩阵,热力图,面积图等(示例+代码)

目录 1 Pandas 可视化功能 2 Pandas绘图实例 2.1 绘制线图 2.2 绘制柱状图 2.3 绘制随机散点图 2.4 绘制饼图 2.5 绘制箱线图A 2.6 绘制箱线图B 2.7 绘制散点图矩阵 2.8 绘制面积图 2.9 绘制热力图 2.10 绘制核密度估计图 1 Pandas 可视化功能 pandas是一个强大的数…

在 Python 中实现 DBSCAN

一、说明 DBSCAN(Density-Based Spatial Clustering of Applications with Noise)聚类是一种基于密度的聚类算法。它能够根据数据点的密度来将数据划分为不同的类别,并可以自动识别离群点。DBSCAN聚类算法的核心思想是将密度高的数据点划分为…

MacVim for Mac:强大的文本编辑器,提升你的编程体验

在Mac上,有这样一款独特的文本编辑器——MacVim for Mac,它以其强大的功能和出色的性能,吸引了广大的程序员和编程爱好者。这款编辑器不仅继承了Unix编辑器Vi的强大功能,更通过创新的设计和功能拓展,提供了一款更完整、…

批量上传文件,以input上传文件,后端以List<MultipartFile>类型接收

批量上传文件,以input上传文件,后端以List类型接收 一、后端接口二、前端对接三、测试 最近公司要求要做一个批量上传文件的功能,以往做的导入Excel表格、上传图片都是上传一个文件的,此次在开发的过程中着实让我犯了难&#xff0…

vue Echarts饼图指定颜色与数据对应

需求:一般自定义颜色是按照数据的顺序依次对应,现在想要指定字段对应某个颜色 因为是直接在返回数据中做操作,所以直接写这部分的代码 数据格式 cdata: {xData: ["水文", "森林", "气象", "地质",…