基于self-attention的BIGRU时间序列预测Python程序

该文章提供了一个基于Pytorch的BIGRU模型,结合self-attention机制进行时间序列预测的Python程序。模型支持单变量和多变量输入,单步和多步预测,并能从Excel文件中读取数据。训练、验证和测试数据集划分明确,且包含多种评估指标如MAE、MSE、R2和MAPE。
摘要由CSDN通过智能技术生成

 基于self-attention的BIGRU时间序列预测Python程序

 

特色:1、单变量,多变量输入,自由切换 

           2、单步预测,多步预测,自动切换

           3、基于Pytorch架构

           4、多个评估指标(MAE,MSE,R2,MAPE等)

           5、数据从excel文件中读取,更换简单

           6、标准框架,数据分为训练集、验证集,测试集

 

全部完整的代码,保证可以运行的代码看这里。

http://t.csdnimg.cn/El450

 

  !!!如果第一个链接打不开,请点击个人首页,查看我的个人介绍。

(搜索到的产品后,点头像,就能看到全部代码)

黑科技小土豆的博客_CSDN博客-深度学习,32单片机领域博主

 

cba77fc9cc354f809f379ea7e187bbb7.png

3a558005fce7a0902c75d6e5ba71cea2.png

 

1、BIGRU-selfAttention模型背景简介

BIGRU是双向GRU,与单向GRU相比较,它包含两个GRU,一个从前向后扫描整个序列,另一个从后向前扫描序列。这种结构使得模型能够同时考虑过去和未来的信息,从而更加准确地捕捉序列数据中的特征信息。

此外,模型还采用了self-attention机制,可以更好地关注序列中不同位置的信息,提高预测准确率。

综上,BIGRU-selfAttention模型利用双向GRU网络结合self-attention机制,在更好地捕捉序列数据特征的同时,提高了模型预测能力。

2、BIGRU-selfAttention模型优点总结

本模型的优点有:

  • BIGRU双向GRU可以同时考虑过去和未来的信息,更全面地捕捉序列数据中的特征信息;
  • self-attention机制能够更好地处理序列数据之间的关系,为BIGRU网络提供各个时间步不同的辅助信息,帮助提高预测准确率。

 

 

 

train_ratio = 0.7  # 训练集比例
val_ratio = 0.15  # 验证集比例
test_ratio = 0.15  # 测试集比例
input_length = 48  # 输入数据长度,多步预测建议长,单步预测建议短
output_length = 1  # 输出数据长度,1为单步预测,1以上为多步预测 请注意,随着输出长度的增长,模型训练时间呈指数级增长
learning_rate = 0.1  # 学习率
estimators = 100  # 迭代次数
max_depth = 5  # 树模型的最大深度
interval_length = 2000  # 预测数据长度,最长不可以超过总数据条数
scalar = True  # 是否使用归一化
scalar_contain_labels = True  # 归一化过程是否包含目标值的历史数据
target_value = 'load'  # 需要预测的列名,可以在excel中查看

 

3b6eadb0210c4946bfd54e910aa2fa84.png

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值