时序预测 | Matlab实现SSA-TCN麻雀搜索算法优化时间卷积网络时序预测-递归预测未来数据(单输入单输出)

时序预测 | Matlab实现SSA-TCN麻雀搜索算法优化时间卷积网络时序预测-递归预测未来数据(单输入单输出)

目录

    • [时序预测 | Matlab实现SSA-TCN麻雀搜索算法优化时间卷积网络时序预测-递归预测未来数据(单输入单输出)](#时序预测 | Matlab实现SSA-TCN麻雀搜索算法优化时间卷积网络时序预测-递归预测未来数据(单输入单输出))

预测效果


基本介绍

1.Matlab实现SSA-TCN麻雀搜索算法优化时间卷积网络时序预测-递归预测未来数据(单输入单输出)(完整源码和数据);

2.数据集为excel,单列时间序列数据集,运行主程序main.m即可,其余为函数文件,无需运行;

3.SSA优化的超参数为:卷积核数量、正则化系数、初始化学习率,命令窗口输出RMSE、MAPE、MAE、R2等评价指标;

4.运行环境Matlab2020b及以上;

5.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。

程序设计

  • 完整源码和数据获取方式私信博主Matlab实现SSA-TCN麻雀搜索算法优化时间卷积网络时序预测-递归预测未来数据
clike 复制代码
%%  清空环境变量
warning off             % 关闭报警信息
close all               % 关闭开启的图窗
clear                   % 清空变量
clc                     % 清空命令行

%%  导入数据(时间序列的单列数据)
result = xlsread('data.xlsx');

%%  数据分析
num_samples = length(result);  % 样本个数 
kim = 4;                      % 延时步长(kim个历史数据作为自变量)
zim =  1;                      % 跨zim个时间点进行预测

%%  划分数据集
for i = 1: num_samples - kim - zim + 1
    res(i, :) = [reshape(result(i: i + kim - 1), 1, kim), result(i + kim + zim - 1)];
end

%% 数据集分析
outdim = 1;                                  % 最后一列为输出
num_size = 0.7;                              % 训练集占数据集比例
num_train_s = round(num_size * num_samples); % 训练集样本个数
f_ = size(res, 2) - outdim;                  % 输入特征维度

%%  划分训练集和测试集
P_train = res(1: num_train_s, 1: f_)';
T_train = res(1: num_train_s, f_ + 1: end)';
M = size(P_train, 2);

P_test = res(num_train_s + 1: end, 1: f_)';
T_test = res(num_train_s + 1: end, f_ + 1: end)';
N = size(P_test, 2);

%%  数据归一化
[p_train, ps_input] = mapminmax(P_train,0,1);
p_test = mapminmax('apply',P_test,ps_input);

[t_train, ps_output] = mapminmax(T_train,0,1);
t_test = mapminmax('apply',T_test,ps_output);


% CSDN 机器学习之心

参考资料

1\] https://blog.csdn.net/kjm13182345320/article/details/128577926?spm=1001.2014.3001.5501 \[2\] https://blog.csdn.net/kjm13182345320/article/details/128573597?spm=1001.2014.3001.5501

相关推荐
freexyn1 小时前
Matlab自学笔记五十二:变量名称:检查变量名称是否存在或是否与关键字冲突
人工智能·笔记·算法·matlab
XuX032 小时前
MATLAB小试牛刀系列(1)
开发语言·matlab
程高兴4 小时前
高压直流输电MATLAB/simulink仿真模型+说明文档
开发语言·网络·matlab
今天吃饺子5 小时前
时滞最大信息系数(MIC)分析,为你的预测模型添砖加瓦,MATLAB免费代码
开发语言·matlab
nwpu06170119 小时前
Simulink与C的联合仿真调试
matlab
__lost20 小时前
小球在摆线上下落的物理过程MATLAB代码
开发语言·算法·matlab
程高兴20 小时前
单相交直交变频电路设计——matlab仿真+4500字word报告
开发语言·matlab
是数学系的小孩儿1 天前
数值分析、数值代数之追赶法
数学·matlab·电脑
yyywxk1 天前
Matlab 报错:尝试将 SCRIPT vl_sift 作为函数执行:
开发语言·matlab
随风飘摇的土木狗1 天前
【MATLAB第118期】基于MATLAB的双通道CNN多输入单输出分类预测方法
matlab·cnn·分类预测·卷积神经网络·双通道