基于WOA鲸鱼优化的GroupCNN分组卷积网络时间序列预测算法matlab仿真

news/2024/10/19 1:14:17/文章来源:https://www.cnblogs.com/matlabworld/p/18475293

1.算法运行效果图预览

(完整程序运行后无水印)

 

2.算法运行软件版本

matlab2022a

 

3.部分核心程序

(完整版代码包含详细中文注释和操作步骤视频)

 

for t=1:Itersfor j=1:Dif rand_flag<0.5   if abs(K1)>=1RLidx    = floor(Num*rand()+1);X_rand   = xwoa(RLidx, :);D_X_rand = abs(K2*X_rand(j)-xwoa(i,j)); xwoa(i,j)= X_rand(j)-K1*D_X_rand;     elseD_Leader = abs(K2*woa_idx(j)-xwoa(i,j)); xwoa(i,j)= woa_idx(j)-K1*D_Leader;    endelsedistLeader = abs(woa_idx(j)-xwoa(i,j));xwoa(i,j)  = distLeader*exp(2*l).*cos(l.*2*pi)+woa_idx(j);end%目标函数更新if xwoa(i,j)>=tmps(j,2) xwoa(i,j)=tmps(j,2);endif xwoa(i,j)<=tmps(j,1) xwoa(i,j)=tmps(j,1);endendgb12(i)= func_obj(xwoa(i,:));end
endLR              = woa_idx(1);
numHiddenUnits1 = floor(woa_idx(2))+1;% 定义隐藏层中LSTM单元的数量
numHiddenUnits2 = floor(woa_idx(3))+1;% 定义隐藏层中LSTM单元的数量layers = func_model2(Dim,numHiddenUnits1,numHiddenUnits2);
%设置
%迭代次数
%训练模型
%训练模型
[GCNN_net, INFO] = trainNetwork(Dat_train, Lab_train, layers, opts);
Rerr = INFO.TrainingRMSE;
Rlos = INFO.TrainingLoss;
%预测
ypred2 = predict(GCNN_net, Dat_test );figure
plot(Lab_test, 'r')
hold on
plot(ypred2, 'b-o')
legend('真实值', '预测值')
grid onfigure
subplot(211)
plot(Rerr)
xlabel('迭代次数')
ylabel('RMSE')
grid onsubplot(212)
plot(Rlos)
xlabel('迭代次数')
ylabel('LOSS')
grid onsave R2.mat Rerr Rlos ypred2 Lab_test
168

  

 

4.算法理论概述

        基于woa优化的GroupCNN分组卷积网络时间序列预测算法是一种结合了粒子群优化技术和分组卷积神经网络(GroupCNN)的时间序列预测方法。这种方法利用粒子群优化来寻找最优的网络结构和超参数,以提高时间序列预测的准确性和效率。

 

4.1 分组卷积神经网络(GroupCNN)

       分组卷积是一种减少计算成本同时保持模型性能的有效手段。在深度学习领域,尤其是在卷积神经网络(CNN)中,分组卷积被用来降低参数数量和计算复杂度。假设输入张量为X,卷积核为W,输出张量为Y,则分组卷积的计算可以表示为:

 

 

 

常规卷积和分组卷积,其区别如下图所示:

 

 

 

4.2 WOA优化算法

        WOA即Whale Optimization Algorithm(鲸鱼优化算法),是一种受自然界鲸鱼捕食行为启发的生物启发式优化算法,由Eslam Mohamed于2016年提出,常用于解决各种连续优化问题,包括函数优化、机器学习参数调整、工程设计等领域中的复杂优化任务。鲸鱼优化算法模拟了虎鲸的两种主要觅食策略: Bubble-net attacking 和 Spiral updating 过程。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mann–Whitney U test R语言检验

001、set.seed(123)group_A <- rnorm(30, mean = 5, sd = 1) # 药物A的效果 group_B <- rnorm(30, mean = 6, sd = 1) # 药物B的效果u_test_result <- wilcox.test(group_A, group_B, alternative = "two.sided")print(u_test_result)。

RabbitMQ 工作队列(Work queues)模式示例

总结自:BV15k4y1k7Ep模式说明Work queues与简单模式相比,多了一个或一些消费端,多个消费端共同消费同一个队列中的消息。消费者之间是竞争的关系。 应用场景:对于任务过重或任务较多情况使用工作队列可以提高任务处理的速度。 代码 Work queues与简单模式的代码是几乎一样的…

定时中断基本结构

打开时钟-->配置 时钟源-->配置 时基单元-->配置 中断输出-->配置 NVIC-->启动 定时器 程序 void Timer_Init(void) {RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);/*配置时钟*/TIM_InternalClockConfig(TIM2);TIM_TimeBaseInitTypeDef TIM_TimeBaseIni…

定时器-输出比较PWM

打开时钟-->配置 时钟源-->配置 时基单元-->配置 输出比较单元-->配置 GPIO口 代码 void PWM_Init(void) {RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);/*配置 时钟*/TIM_InternalClockConfig(TIM2…

专题二:操作系统基本原理

1. 操作系统概述 操作系统:管理系统的硬件、软件、数据资源 控制程序运行 人机之间的接口 应用软件与硬件之间的接口进程管理 存储管理 文件管理 作业管理 设备管理 2. 进程管理 2.1. 进程状态(三态模型、五态模型) 2.2. ★★★信号量与PV操作★★★ 2.2.1. 前趋图 2.2.2.…

C++内存模型实践探索

C++对象模型是个常见、且复杂的话题,本文基于Itanium C++ ABI通过程序实践介绍了几种 简单C++继承 场景下对象模型,尤其是存在虚函数的场景,并通过图的方式直观表达内存布局。前言 C++对象模型是个常见、且复杂的话题,本文基于Itanium C++ ABI通过程序实践介绍了几种 简单C…

乘风破浪,扬帆出海,专门为英语学习者设计的在线学习平台之English Pod

什么是English Podhttps://learnenglishpod.comEnglish Pod是一个专门为英语学习者设计的在线学习平台,提供各种各样的英语学习播客(pod cast)和教学资源。其目标是帮助不同水平的学习者通过日常对话和实用内容提高英语听力、口语、词汇和语法能力。EnglishPod的课程通常包括对…

课堂练习

Complex.h中的代码:#include <iostream> #pragma once class Complex { public:Complex(double x=0, double y=0);Complex(const Complex& p);~Complex();void add(const Complex& p);double get_real() const;double get_imag() const;friend Complex add(cons…

乘风破浪,乘风出海,学习英语之English Pod

什么是English Podhttps://learnenglishpod.comEnglish Pod是一个专门为英语学习者设计的在线学习平台,提供各种各样的英语学习播客(podcast)和教学资源。其目标是帮助不同水平的学习者通过日常对话和实用内容提高英语听力、口语、词汇和语法能力。EnglishPod的课程通常包括对…

20222306 2024-2025-1 《网络与系统攻防技术》实验二实验报告

1.实验内容 1.1 实践目标 (1)使用netcat获取主机操作Shell,cron启动某项任务(任务自定) PS:cron是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程 (2)使用socat获取主机操作Shell, 任务计划启动 (3)使用MSF meterpreter(或其他软件)生成可执行文件,利…

transformers 推理 Qwen2.5 等大模型技术细节详解(一)transformers 初始化和对象加载(文末免费送书)

本文详细讲解 transformers 推理大语言模型的初始化过程,包括 Python 包搜索、LazyModule 延迟模块、模块搜索和 Python 包 API 设计美学……上周收到一位网友的私信,希望老牛同学写一篇有关使用 transformers 框架推理大模型的技术细节的文章。 老牛同学刚开始以为这类的文章…

UI开发概述

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(MaoistLearning)➤博客园地址:为敢技术(https://www.cnblogs.com/strengthen/ )➤GitHub地址:https://github.com/strengthen➤原文地址:https://www.cnblogs…