【lssvm回归预测】基于灰狼算法优化最小支持向量机GWO-LSSVM数据预测模型含Matlab源码

news/2024/11/17 10:52:37/

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法  神经网络预测 雷达通信  无线传感器

信号处理 图像处理 路径规划 元胞自动机 无人机  电力系统

⛄ 内容介绍

1) 构建数据集( 即训练集与测试集) ,并对数据预处理,

得到路段的历史交通流量数据的时间序列.

2) 利用改进灰狼优化算法对 LSSVM 参数优化( 即惩罚

因子 γ 和核函数参数 σ) ,主要步骤如下:

Step 1. 参数初始化.

Step 2. 初始化种群并计算函数目标值,选择最优个体 α、β 和 η.

Step 3. 计算 a、A 和 C 的值,根据式( 7) 计算种群个体与最优个体的距离并根据式( 8) 、式( 9) 更新个体位置.

Step 4. 由式( 12) -式( 14) 对当前种群执行变异、交叉和选择操作,计算个体的目标函数值.

Step 5. 更新最优个体位置.

Step 6. 判断是否达到要求. 如果达到设定值,则运行结束,否则转至 Step 3 继续迭代.

3) 根据最优参数得到最优模型后进行交通流量预测.

⛄ 部分代码

%灰狼算法优化LSSVM代码

addpath('LSSVMlabv1_8_R2009b_R2011a')%添加工具箱

clear

clc

tic

%% 导入训练数据

data = xlsread('data.xlsx')';

[data_m,data_n] = size(data);%获取数据维度

P = 80;  %百分之P的数据用于训练,其余测试

Ind = floor(P * data_m / 100);

train_data = data(1:Ind,1:end-1); %训练样本输入集

train_result = data(1:Ind,end);   %训练样本输出集

test_data = data(Ind+1:end,1:end-1);% 测试样本输入集

test_result = data(Ind+1:end,end);  %测试样本输出集

%% 数据归一化

[train_x,PS_i] =mapminmax(train_data',0,1);

test_x=mapminmax('apply',test_data',PS_i);

[train_y,PS_o] = mapminmax(train_result',0,1);

train_x=train_x';

test_x=test_x';

train_y=train_y';

%% 参数初始化

type='f';

kernel= 'RBF_kernel';

%计算均方差

trainmse=sum((train_predict-train_result).^2)/length(train_result);

%testmse=sum((test_predict-test_y).^2)/length(test_y)

disp(['best gam = ',num2str(gam),' best sig2 = ',num2str(sig2)])

figure

subplot(1,2,1);

plot(train_predict,':og')

hold on

plot(train_result,'- *')

legend('实际值','拟合值')

title('拟合图')

ylabel('函数输出')

xlabel('样本')

subplot(1,2,2);

plot(test_predict,'r-o')

hold on

plot(test_result,'g:s')

legend('实际值','预测值')

title('预测图')

ylabel('函数输出')

xlabel('样本')

hold off

toc   %计算时间

⛄ 运行结果

⛄ 参考文献

[1]顾凯冬. 基于灰狼算法优化最小二乘支持向量机的调制信号识别研究[D]. 南京邮电大学.

[2]伍轶鸣, 孙博文, 成荣红,等. 基于灰狼算法的LSSVM模型预测凝析气藏露点压力研究[J]. 西安石油大学学报:自然科学版, 2020, 35(2):7.

⛄ Matlab代码关注

❤️部分理论引用网络文献,若有侵权联系博主删除

❤️ 关注我领取海量matlab电子书和数学建模资料


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

相关文章

MR案例(2):学生排序(单字段排序、多字段排序)

文章目录一、任务目标1. 准备数据二、实行任务1. 创建Maven项目2. 添加相关依赖3. 创建日志属性文件4. 创建学生实体类5. 创建学生映射器类6. 创建学生归并器类7. 创建学生驱动类8. 启动学生驱动器类,查看结果一、任务目标 MR案例:学生排序(…

物联网开发笔记(64)- 使用Micropython开发ESP32开发板之控制ILI9341 3.2寸TFT-LCD触摸屏进行LVGL图形化编程:控件显示

一、目的 这一节我们学习如何使用我们的ESP32开发板来控制ILI9341 3.2寸TFT-LCD触摸屏进行LVGL图形化编程:控件显示。 二、环境 ESP32 ILI9341 3.2寸TFT-LCD触摸屏 Thonny IDE 几根杜邦线 接线方法:见前面文章。 三、滑杆代码 import lvgl as lv i…

【Mitigating Voltage Attacks in Multi-Tenant FPGAs 论文笔记】

减轻多租户FPGA中的电压攻击摘要引言内容背景和相关工作INTEL STRATIX 10 FPGA上的PDN攻击Stratix 10 PDN特性定位电压下降片上监控和攻击抑制结论和未来工作结论:未来工作作者:GEORGE PROVELENGIOS, University of Massachusetts Amherst, MA, USADANIE…

华为OD机试真题 Python 实现【预订酒店】【2022.11 Q4 新题】

目录 题目 思路 考点 Code 题目 放暑假了,小明决定到某旅游景点游玩,他在网上搜索到了各种价位的酒店(长度为n的 数组A),他的心理价位是x元,请帮他筛选出k个最接近x元的酒店 (n>=k>0) ,并由低到高打印酒店的价格输入描述 第一行: n,k,x 第二行: A[o] A[1] A[2].…

Java项目:基于jsp+mysql+Spring+mybatis的SSM在线网络图书商城

作者主页:源码空间站2022 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本项目分为前后台,有管理员与用户两种角色; 管理员角色包含以下功能: 管理员登录,商品分类管理,商品管理,商…

Linux c编程之IO复用机制

一、说明 在实际网络程序中,比如服务器程序,需要使用IO复用机制来处理多个客户端的连接和数据收发。Linux系统下常用的IO复用机制有三种:select、poll、epoll。   poll是Linux中的字符设备驱动中的一个函数。Linux 2.5.44版本后,poll被epoll取代。   select用于监视文件…

海量数据小内存!从未出现过的数在哪里

文章目录题目要求1)内存 1G2)内存 3 KB3)内存 有限变量举例题目 现在有 40 亿个无符号整数,无符号整数的范围是 0 ~ 232-1(42亿),哪怕 40 亿个数完全不同,在该范围中也总有没有出现…

29.图像卷积代码实现

1. 互相关运算 接下来,我们在corr2d函数中实现如上过程,该函数接受输入张量X和卷积核张量K,并返回输出张量Y。 import torch from torch import nn from d2l import torch as d2ldef corr2d(X,K): # X是输入,K是核矩阵计算二维互…