【ELM回归预测】基于极限学习机实现气象影响因子光伏出力预测附matlab代码

简介: 【ELM回归预测】基于极限学习机实现气象影响因子光伏出力预测附matlab代码

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

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

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

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

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

⛄ 内容介绍

针对各分量的不同特性,考虑相应气象因素作为输入,利用ELM神经网络建立不同的预测模型,分别预测各分量值;最后对ELM预测的各分量值求和,从而得到最终预测结果.算例仿真表明,该方法比传统的预测方法具有更高的预测准确度.

⛄ 部分代码

close all

clear,clc


%% 加载数据

load fengsu5min;     %用间隔15min的48个点(即12个小时)的数据直接预测间隔15min的16个点

load gonglv5min;

% load wendu5min;

% load fengxiang5min;

% for i=1:8929

% zhengxuan(i)=sin(fengxiang5min(i)*pi/180);

% end

b=fengsu5min;

c=gonglv5min;

% f=zhengxuan;

% d=wendu5min;

% e=fengxiang5min;

mi1=min(b);

ma1=max(b);

b=(b-mi1)/(ma1-mi1);

mi2=min(c);

ma2=max(c);

c=(c-mi2)/(ma2-mi2);

% mi5=min(f);

% ma5=max(f);

% f=(f-mi5)/(ma5-mi5);

% mi3=min(d);

% ma3=max(d);

% d=(d-mi3)/(ma3-mi3);

% mi4=min(e);

% ma4=max(e);

% e=(e-mi4)/(ma1-mi4);

for i=1:8900

   p(i,:)=[b(i),b(i+1),b(i+2),b(i+3),b(i+4),b(i+5)];

%     ,b(i+7),b(i+8),b(i+9),b(i+10),b(i+11),b(i+12),b(i+13),b(i+14),b(i+15)

% ,f(i),f(i+1),f(i+2),f(i+3),f(i+4),f(i+5)

%    ,d(i),d(i+1),d(i+2),d(i+3),d(i+4),e(i),e(i+1),e(i+2),e(i+3),e(i+4)

%     ,b(i+16),b(i+17),c(i),c(i+1),c(i+2),c(i+3),c(i+4),c(i+5)

end

for i=6:8912

   a(i,:)=[c(i)];

end

for k=1:48

p_train=p(1:2874+k,:);

t_train=a(6:2879+k,:);

p_test=p(2875+k,:);

t_test=a(2880+k,:);


p_train=p_train';

t_train=t_train';

p_test=p_test';

t_test=t_test';

% nn=[31 2];

% for i=1:2

threshold=[0 1;0 1;0 1;0 1;0 1;0 1];


net=newelm(threshold,[13,1],{'tansig','purelin'});


net.trainParam.epochs=1000;

net.trainParam.show=20;

net=init(net);

net=train(net,p_train,t_train);

y=sim(net,p_test);

y1=y*(ma2-mi2)+mi2;

y2(k)=y1;

t_test1=t_test*(ma2-mi2)+mi2;

t_test2(k)=t_test1;

error(k)=t_test2(k)-y2(k);

end

% end

figure

plot(y2,'r-s')

hold on

plot(t_test2,'k-*')

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

% plot(error,'-ro','linewidth',2);

% hold on;

% mse(error);

% fprintf('error= %f\n', error);

% plot(y1,':k')

% hold on;

% plot(t_test1,'k')

% error;

rate1=(sum((error./1500).^2)/48)^(1/2)

rate2=(sum((error.^2).^(1/2)))/48/1500

y3=mean(y2);

t_test3=mean(t_test2);

for k=1:48

error1(k)=y2(k)-y3;

error2(k)=t_test2(k)-t_test3;

end

rate3=sum(error1.*error2);

rate4=(sum(error1.^2)*sum(error2.^2))^(1/2);

rate5=rate3/rate4

% bk=0;

% for i=1:16

%     if error(i)/1600<=0.15

%         bk(i)=1;

%     else

%         bk(i)=0;

%     end

% end

% rate2(k)=sum(bk)/16

% ans(error)

% for i=1:16

%     f(i)=e(i)/t_test(i);

% end

% sum(f(i))/16

⛄ 运行结果

⛄ 参考文献

[1]陈恒志, 杨建平, 卢新春,等. 基于极限学习机(ELM)的连铸坯质量预测[J]. 工程科学学报, 2018, 040(007):815-821.

[2]张宇, 叶季蕾, 李斌,等. 一种基于改进极限学习机的光伏发电预测方法:, CN114298377A[P]. 2022.

⛄ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
1月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
114 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
1月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
66 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
1月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
91 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
4月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
4月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
4月前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
|
4月前
|
供应链 算法
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
|
4月前
|
算法 调度
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
|
4月前
|
算法 调度 SoC
电动汽车充放电V2G模型(Matlab代码)
电动汽车充放电V2G模型(Matlab代码)

热门文章

最新文章