文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

时序预测 | MATLAB实现基于PSO-BiLSTM、BiLSTM时间序列预测对比

2023-08-30 16:23

关注

时序预测 | MATLAB实现基于PSO-BiLSTM、BiLSTM时间序列预测对比

效果一览

1
2

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

基本描述

MATLAB实现基于PSO-BiLSTM、BiLSTM时间序列预测对比。
1.Matlab实现PSO-BiLSTM和BiLSTM神经网络时间序列预测;
2.输入数据为单变量时间序列数据,即一维数据;
3.运行环境Matlab2020及以上,依次运行Main1BiLSTMTS、Main2PSOBiLSTMTS、Main3CDM即可,其余为函数文件无需运行,所有程序放在一个文件夹,data为数据集;
BiLSTM(双向长短时记忆模型)与粒子群算法优化后的BiLSTM(PSOBiLSTM)对比实验,可用于风电、光伏等负荷预测,时序预测,数据为单输入单输出,PSO优化超参数为隐含层1节点数、隐含层2节点数、最大迭代次数和学习率。

命令窗口输出MAE、MAPE、RMSE和R2;

程序设计

for i=1:PopNum%随机初始化速度,随机初始化位置    for j=1:dim        if j==dim% % 隐含层节点与训练次数是整数 学习率是浮点型            pop(i,j)=(xmax(j)-xmin(j))*rand+xmin(j);        else            pop(i,j)=round((xmax(j)-xmin(j))*rand+xmin(j));  %        end    endend% calculate the fitness_value of Poppbest = pop;gbest = zeros(1,dim);data1 = zeros(Maxstep,PopNum,dim);data2 = zeros(Maxstep,PopNum);for i = 1:PopNum    fit(i) = fitness(pop(i,:),p_train,t_train,p_test,t_test);    f_pbest(i) = fit(i);endg = min(find(f_pbest == min(f_pbest(1:PopNum))));gbest = pbest(g,:);f_gbest = f_pbest(g);%-------- in the loop -------------for step = 1:Maxstep        mbest =sum(pbest(:))/PopNum;    % linear weigh factor    b = 1-step/Maxstep*0.5;    data1(step,:,:) = pop;    data2(step,:) = fit;    for i = 1:PopNum        a = rand(1,dim);        u = rand(1,dim);        p = a.*pbest(i,:)+(1-a).*gbest;        pop(i,:) = p + b*abs(mbest-pop(i,:)).*...            log(1./u).*(1-2*(u >= 0.5));        % boundary detection                for j=1:dim            if j ==dim                if pop(i,j)>xmax(j) | pop(i,j)<xmin(j)                    pop(i,j)=(xmax(j)-xmin(j))*rand+xmin(j);  %                end            else                pop(i,j)=round(pop(i,j));                if pop(i,j)>xmax(j) | pop(i,j)<xmin(j)                    pop(i,j)=round((xmax(j)-xmin(j))*rand+xmin(j));  %                end            end        end                        fit(i) = fitness(pop(i,:),p_train,t_train,p_test,t_test);        if fit(i) < f_pbest(i)            pbest(i,:) = pop(i,:);            f_pbest(i) = fit(i);        end        if f_pbest(i) < f_gbest            gbest = pbest(i,:);            f_gbest = f_pbest(i);        end    end    trace(step)=f_gbest;    step,f_gbest,gbest    result(step,:)=gbest;endor i=1:N%随机初始化速度,随机初始化位置    for j=1:D        if j==D% % 隐含层节点与训练次数是整数 学习率是浮点型            x(i,j)=(xmax(j)-xmin(j))*rand+xmin(j);        else            x(i,j)=round((xmax(j)-xmin(j))*rand+xmin(j));  %        end    end        v(i,:)=rand(1,D);end%------先计算各个粒子的适应度,并初始化Pi和Pg----------------------for i=1:N    p(i)=fitness(x(i,:),p_train,t_train,p_test,t_test);    y(i,:)=x(i,:);    end[fg,index]=min(p);pg = x(index,:);             %Pg为全局最优%------进入主要循环,按照公式依次迭代------------for t=1:M        for i=1:N        v(i,:)=w*v(i,:)+c1*rand*(y(i,:)-x(i,:))+c2*rand*(pg-x(i,:));        x(i,:)=x(i,:)+v(i,:);                        for j=1:D            if j ~=D                x(i,j)=round(x(i,j));            end            if x(i,j)>xmax(j) | x(i,j)<xmin(j)                if j==D                    x(i,j)=(xmax(j)-xmin(j))*rand+xmin(j);  %                else                    x(i,j)=round((xmax(j)-xmin(j))*rand+xmin(j));  %                end            end        end        temp=fitness(x(i,:),p_train,t_train,p_test,t_test);        if temp<p(i)            p(i)=temp;            y(i,:)=x(i,:);        end                if p(i)<fg            pg=y(i,:);            fg=p(i);        end    end    trace(t)=fg;    result(t,:)=pg;

参考资料

[1] https://blog.csdn.net/kjm13182345320/article/details/127596777?spm=1001.2014.3001.5501
[2] https://download.csdn.net/download/kjm13182345320/86830096?spm=1001.2014.3001.5501

来源地址:https://blog.csdn.net/kjm13182345320/article/details/132557833

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯