【Kelm回归预测】基于粒子群算法优化核极限学习机实现数据回归预测附matlab代码

该文提出了一种基于粒子群优化的核极限学习机(PSO-KELM)模型,用于风电功率的概率区间预测。相较于传统的点预测方法,PSO-KELM能更好地描述风电输出的不确定性。通过与PSO-ELM比较,PSO-KELM展现出更高的预测精度和效率,为风电并网的决策支持提供了帮助。
摘要由CSDN通过智能技术生成

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

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

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

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

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

⛄ 内容介绍

风电功率预测能为电网规划和运行提供重要依据,传统预测方法多为点预测,其结果一般有不同程度的误差,区间预测方法能有效描述风电输出功率的不确定性因而逐步受到重视。针对短期风电功率概率区间预测问题,提出一种基于粒子群优化的核极限学习机(PSO-KELM)模型,用于风电功率区间预测。通过核极限学习机(KELM)建立预测模型,采用粒子群算法对KELM的输出权值进行优化,寻找最优预测区间上下限,充分利用了KELM学习速度快、泛化能力强的优点,实现了对风电功率的快速区间预测。通过与PSO-ELM模型对比分析风电场在不同置信水平下的概率预测结果,发现PSO-KELM模型的预测精度更高,速度更快,能够为风电功率区间预测及风电并网安全稳定运行提供决策支持。

⛄ 部分代码

function [g,gbest,Convergence_curve]=PSO(N,T,lb,ub,dim,fobj)

%% 定义粒子群算法参数

%% 随机初始化种群

D=dim;                   %粒子维数

c1=1.5;                 %学习因子1

c2=1.5;                 %学习因子2

w=0.8;                  %惯性权重

Xmax=ub;                %位置最大值

Xmin=lb;               %位置最小值

Vmax=ub;                %速度最大值

Vmin=lb;               %速度最小值

%%

%%%%%%%%%%%%%%%%初始化种群个体(限定位置和速度)%%%%%%%%%%%%%%%%

x=rand(N,D).*(Xmax-Xmin)+Xmin;

v=rand(N,D).*(Vmax-Vmin)+Vmin;

%%%%%%%%%%%%%%%%%%初始化个体最优位置和最优值%%%%%%%%%%%%%%%%%%%

p=x;

pbest=ones(N,1);

for i=1:N

    pbest(i)=fobj(x(i,:)); 

end

%%%%%%%%%%%%%%%%%%%初始化全局最优位置和最优值%%%%%%%%%%%%%%%%%%

g=ones(1,D);

gbest=inf;

for i=1:N

    if(pbest(i)<gbest)

        g=p(i,:);

        gbest=pbest(i);

    end

end

%%%%%%%%%%%按照公式依次迭代直到满足精度或者迭代次数%%%%%%%%%%%%%

for i=1:T

       i

    for j=1:N

        %%%%%%%%%%%%%%更新个体最优位置和最优值%%%%%%%%%%%%%%%%%

        if (fobj(x(j,:))) <pbest(j)

            p(j,:)=x(j,:);

            pbest(j)=fobj(x(j,:)); 

        end

        %%%%%%%%%%%%%%%%更新全局最优位置和最优值%%%%%%%%%%%%%%%

        if(pbest(j)<gbest)

            g=p(j,:);

            gbest=pbest(j);

        end

        %%%%%%%%%%%%%%%%%跟新位置和速度值%%%%%%%%%%%%%%%%%%%%%

        v(j,:)=w*v(j,:)+c1*rand*(p(j,:)-x(j,:))...

            +c2*rand*(g-x(j,:));

        x(j,:)=x(j,:)+v(j,:);

        %%%%%%%%%%%%%%%%%%%%边界条件处理%%%%%%%%%%%%%%%%%%%%%%

        if length(Vmax)==1

            for ii=1:D

                if (v(j,ii)>Vmax)  |  (v(j,ii)< Vmin)

                    v(j,ii)=rand * (Vmax-Vmin)+Vmin;

                end

                if (x(j,ii)>Xmax)  |  (x(j,ii)< Xmin)

                    x(j,ii)=rand * (Xmax-Xmin)+Xmin;

                end

            end           

        else

            for ii=1:D

                if (v(j,ii)>Vmax(ii))  |  (v(j,ii)< Vmin(ii))

                    v(j,ii)=rand * (Vmax(ii)-Vmin(ii))+Vmin(ii);

                end

                if (x(j,ii)>Xmax(ii))  |  (x(j,ii)< Xmin(ii))

                    x(j,ii)=rand * (Xmax(ii)-Xmin(ii))+Xmin(ii);

                end

            end

        end

            

    end

    %%%%%%%%%%%%%%%%%%%%记录历代全局最优值%%%%%%%%%%%%%%%%%%%%%

   Convergence_curve(i)=gbest;%记录训练集的适应度值

end

⛄ 运行结果

⛄ 参考文献

[1]杨锡运, 关文渊, 刘玉奇,等. 基于粒子群优化的核极限学习机模型的风电功率区间预测方法[J]. 中国电机工程学报, 2015, 35(S1):146-153.

⛄ 完整代码

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

matlab科研助手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值