WOA-GRU多输入时序预测 | 鲸鱼优化算法-门控循环单元神经网络 | Matlab

news/2024/7/10 4:49:25 标签: gru, 算法, 深度学习, matlab, 优化, 时序, 预测

目录

一、程序及算法内容介绍:

基本内容:

亮点与优势:

 二、实际运行效果:

 三、部分程序:

 四、完整程序下载:


一、程序及算法内容介绍:

基本内容:

  • 本代码基于Matlab平台编译,将WOA(鲸鱼群算法)与GRU(门控循环单元神经网络)结合,进行多输入数据时序预测

  • 输入训练的数据包含8个特征1个响应值,即通过8个输入值预测1个输出值(多变量时序预测,个数可自行指定)

  • 归一化训练数据,提升网络泛化性

  • 通过WOA算法优化GRU网络的学习率、神经元个数参数,记录下最优的网络参数

  • 训练GRU网络进行回归预测,实现更加精准的预测

  • 迭代计算过程中,自动显示优化进度条,实时查看程序运行进展情况

  • 自动输出多种多样的的误差评价指标,自动输出大量实验效果图片

亮点与优势:

  • 注释详细,几乎每一关键行都有注释说明,适合小白起步学习

  • 直接运行Main函数即可看到所有结果,使用便捷

  • 编程习惯良好,程序主体标准化,逻辑清晰,方便阅读代码

  • 所有数据均采用Excel格式输入,替换数据方便,适合懒人选手

  • 出图详细、丰富、美观,可直观查看运行效果

  • 附带详细的说明文档(下图),其内容包括:算法原理+使用方法说明

 二、实际运行效果:

 三、部分程序:

clc;
clear;
warning off;
%% 导入数据
Data = table2array(readtable("数据集.xlsx"));
% 本例数据集中包含:
% 1. 总共357个样本(每一行表示一个样本)
% 2. 每个样本12个特征值(即前12列每一列表示样本的一个特征,即输入的变量)
% 3. 每个样本1个响应值(第13列为表示样本的响应值,即被预测的变量)

%% 划分训练集和测试集
Temp = randperm(size(Data,1)); % 打乱数据的顺序,提升模型的泛化性。
InPut_num = 1:1:12; % 输入特征的列数,数据表格中前12列为输入值,因此设置为1:1:12,若前5个为输入则设置为1:1:5
OutPut_num = 13; % 输出响应列数,本例仅一个响应值,为数据表格中第13列,若多个响应值参照上行数据格式设置为x:1:y

% 选取前327个样本作为训练集,后30个样本作为测试集,即(1:327),和(328:end)
Train_InPut = Data(Temp(1:327),InPut_num); % 训练输入
Train_OutPut = Data(Temp(1:327),OutPut_num); % 训练输出
Test_InPut = Data(Temp(328:end),InPut_num); % 测试输入
Test_OutPut = Data(Temp(328:end),OutPut_num); % 测试输出

%% 数据归一化
% 将输入特征数据归一化到0-1之间
[~, Ps] = mapminmax([Train_InPut;Test_InPut]',0,1); 
Train_InPut = mapminmax('apply',Train_InPut',Ps);
Test_InPut = mapminmax('apply',Test_InPut',Ps);

 四、完整程序下载:


http://www.niftyadmin.cn/n/5429570.html

相关文章

8-图像放大

其实,就是开辟一个zoomwidth,zoomheight的内存,再分别赋值即可。 void CDib::Maginify(float xZoom, float yZoom) { //指向原图像指针 LPBYTE p_data GetData(); //指向原像素的指针 LPBYTE lpSrc; //指向缩放图像对应像素的指针 LPBYTE l…

【C#算法实现】可见的山峰对数量

文章目录 前言一、题目要求二、算法设计及代码实现2.1 算法思想2.2 代码实现 前言 本文是【程序员代码面试指南(第二版)学习笔记】C#版算法实现系列之一,用C#实现了《程序员代码面试指南》(第二版)栈和队列中的可见的…

安全工程师说telnet

啥是telnet telnet 命令通常用来远程登录。 telnet 程序是基于 TELNET 协议的远程登录客户端程序。Telnet 协议是 TCP/IP 协议族中的一员,是 Internet 远程登陆服务的标准协议和主要方式。它为用户提供了在本地计算机上完成远程主机工作的 能力。在终端使用者的电…

用C++自定义String类

一、头文件 #pragma once #include <iostream>/*** 自定义String类*/ class String { public:String();String(const char *pstr);String(const String &str);~String();String &operator (const String &str);String &operator (const char *pstr);St…

Seurat 降级:从V5降级到V4

Seurat更新增加了一些功能&#xff0c;由于前期都是V4的结果&#xff0c;当使用过程中&#xff0c;容易报错&#xff0c;于是想降级。 清华源 https://mirrors.tuna.tsinghua.edu.cn/CRAN/src/contrib/Archive/PackageName 方法一&#xff1a;降级软件版本&#xff0c;参考R语…

HTML5、CSS3面试题(四)

HTML5、CSS3面试题&#xff08;三&#xff09;-CSDN博客 简述弹性盒子 flex 布局及 rem 布局&#xff1f;&#xff08;必会&#xff09; rem 是 CSS3 新增的一个相对单位&#xff0c;相对于根节点(html)字体大小的值&#xff0c;r 就是 root html{font-size:10px} 则 2rem2…

【DevOps云实践】对Azure数据进行备份和恢复(Windows Linux)

【DevOps云实践】对Azure数据进行备份和恢复(Windows & Linux) 目录 【DevOps云实践】对Azure数据进行备份和恢复(Windows & Linux)创建 VM时配置备份策略虚拟机的 Azure 备份资源组对已经存在的VM 启动备份从 Azure 虚拟机备份恢复文件步骤 1:生成并下载脚本以浏览和…

MySQL数据表的增删改查(基础)(CRUD)

1.CRUD 注释&#xff1a;在SQL中可以使用“--空格描述”来表示注释说明. CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写. 2.新增(Create) 语法: insert into 表名 values (值,值...); into --可以省略; values -- 关键字. 下面以一…