哪吒闹海!SCI算法+分解组合+四模型原创对比首发!SGMD-FATA-Transformer-LSTM多变量时序预测

embedded/2025/2/13 10:50:44/

哪吒闹海!SCI算法+分解组合+四模型原创对比首发!SGMD-FATA-Transformer-LSTM多变量时序预测

目录

效果一览

在这里插入图片描述

在这里插入图片描述

基本介绍

1.SCI算法海市蜃楼优化算法优化算法+分解组合对比!SGMD-FATA-Transformer-LSTM多变量时间序列光伏功率预测,辛几何模态分解+海市蜃楼优化算法优化Transformer结合长短期记忆神经网络多变量时间序列预测(程序可以作为核心级论文代码支撑,目前尚未发表);
海市蜃楼优化算法(Fata morgana algorithm, FATA)是一种新型的元启发式算法(智能优化算法),灵感来源于海市蜃楼的形成过程,该成果由Ailiang Qi于2024年8月发表在SCI的Top期刊《Neurocomputing》上!
2.算法优化参数为:学习率,隐含层单元数目,最大训练周期,运行环境为Matlab2023b及以上;
3.数据集为excel(光伏功率数据集,输入辐射度、气温、气压、湿度,输出光伏功率),输入多个特征,输出单个变量,考虑历史特征的影响,多变量时间序列预测,主程序运行即可,所有文件放在一个文件夹;
4.命令窗口输出R2、MSE、RMSE、MAE、MAPE、MBE等多指标评价。
先运行main1SGMD,进行SGMD分解;再运行main2FATATransformerLSTM,四个模型对比;注意:一种算法不是万能的,不同的数据集效果会有差别,后面的工作就是需要调整参数。

数据集
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

参考文献
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

程序设计

%%  清空环境变量
warning off             % 关闭报警信息
close all               % 关闭开启的图窗
clear                   % 清空变量
clc                     % 清空命令行clc;
clear 
close all
warning off
%% CSDN《机器学习之心》
%% Transformer预测
tic
X = xlsread('北半球光伏数据.xlsx');
load SGMD_data.matdisp('…………………………………………………………………………………………………………………………')num_samples = length(X);       % 样本个数 
kim = 5;                       % 延时步长(kim个历史数据作为自变量)
zim =  1;                      % 跨zim个时间点进行预测
or_dim = size(X,2);%  重构数据集
for i = 1: num_samples - kim - zim + 1res(i, :) = [reshape(X(i: i + kim - 1,:), 1, kim*or_dim), X(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);%%  数据平铺
%   将数据平铺成1维数据只是一种处理方式
%   也可以平铺成2维数据,以及3维数据,需要修改对应模型结构
%   但是应该始终和输入层数据结构保持一致
P_train =  double(reshape(P_train, f_, 1, 1, M));
P_test  =  double(reshape(P_test , f_, 1, 1, N));t_train = t_train';
t_test  = t_test' ;%%  数据格式转换%% CSDN《机 器 学 习 之 心》
for i = 1 : Mp_train{i, 1} = P_train(:, :, 1, i);
endfor i = 1 : Np_test{i, 1}  = P_test( :, :, 1, i);
end% Transformer建模
numChannels = f_;                                             % 定义输入的通道数,变量 f_ 代表特征的维度
maxPosition = 256*2;                                          % 最大位置编码,通常用于序列长度的上限,这里设为 512
numHeads = 4;                                                 % 自注意力机制中的头数
numKeyChannels = numHeads*32;                                 % 每个头的键通道数,总键通道数为 128

参考资料

[1] https://blog.csdn.net/kjm13182345320/article/details/127931217
[2] https://blog.csdn.net/kjm13182345320/article/details/127418340


http://www.ppmy.cn/embedded/161851.html

相关文章

DeepSeek免费部署到WPS或Office

部署到WPS - 通过OfficeAI插件接入: - 准备工作:安装最新版本的WPS Office软件;访问DeepSeek官网,点击右上角的“API开放平台”,登录账号(若无账号需先注册),登录成功后,…

《qt open3d网格拉普拉斯平滑》

qt open3d网格拉普拉斯平滑 效果展示二、流程三、代码效果展示 二、流程 创建动作,链接到槽函数,并把动作放置菜单栏 参照前文 三、代码 1、槽函数实现 void on_actionFilterLaplacian_triggered();void MainWindow::on_actionFil

React(5)

组件通信 父子通信 父传子 // 父传子 function Son(props){console.log(props);return(<div>这是子组件 {props.msg}</div>) }function App() {const msg父组件数据const msg2父组件数据2return (<div className"App"><Son msg{msg} msg2{ms…

认购期权卖出相当于平仓吗?

财顺小编本文主要介绍认购期权卖出相当于平仓吗&#xff1f;认购期权卖出并不直接等同于平仓&#xff0c;但卖出认购期权可以是平仓操作的一部分。 认购期权卖出相当于平仓吗&#xff1f; 一、认购期权卖出的含义 卖出认购期权是指投资者作为期权卖方&#xff0c;将认购期权合…

Java全栈项目实战:校园活动摄影平台开发

一、项目背景 随着高校文化活动的日益丰富&#xff0c;传统摄影作品管理方式已无法满足需求。本项目基于Spring BootVue全栈技术体系&#xff0c;打造集活动发布、作品展示、在线投票、版权管理于一体的数字化平台&#xff0c;已成功应用于多所高校的文化节活动管理。 二、技…

rabbitmq详解

有需要的直接看狂神的视频&#xff0c;讲得很好 简介 RabbitMQ 是一个开源的 消息队列中间件&#xff0c;实现了 AMQP&#xff08;Advanced Message Queuing Protocol&#xff0c;先进消息队列协议&#xff09;。它允许 应用程序、服务、系统之间异步地传递消息&#xff0c;并…

蓝桥杯试题:归并排序

一、问题描述 在一个神秘的岛屿上&#xff0c;有一支探险队发现了一批宝藏&#xff0c;这批宝藏是以整数数组的形式存在的。每个宝藏上都标有一个数字&#xff0c;代表了其珍贵程度。然而&#xff0c;由于某种神奇的力量&#xff0c;这批宝藏的顺序被打乱了&#xff0c;探险队…

HiveQL命令(二)- 数据表操作

文章目录 前言一、数据表操作1. 创建表1.1 语法及解释1.2 内部表1.2.1 创建内部表示例 1.3 外部表1.3.1 创建外部表示例 2. 查看表2.1 查看当前数据库中所有表2.2 查看表信息2.2.1 语法及解释2.2.2 查看表信息示例 3. 修改表3.1 重命名表3.1.1 语法3.1.2 示例 3.2 修改表属性3.…