【BP分类】基于花朵授粉算法优化BP神经网络实现数据分类附matlab代码

简介: 【BP分类】基于花朵授粉算法优化BP神经网络实现数据分类附matlab代码

 1 简介

为了提高分类的准确性,降低因预测精度不高带来的电能损失,提出将花朵授粉算法(flower pollination algorithm,FPA)与BP神经网络相结合,利用FPA算法具有收敛速度快,全局搜索能力强的特点,对BP神经网络的权值和阈值进行优化,改善传统BP神经网络因权值和阈值的选择具有随机性而陷入局部最优和收敛速度慢的缺点.最后,通过某地区实际负荷数据验证了优化后的BP神经网络的预测精度得到了提高.

2 部分代码

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%Flower Pollination Algorithm for Multimodal Optimization (MFPA)%Jorge G醠vez, Erik Cuevas and Omar Avalos%%This is the line to execute the code:%%[mem,bestSol,bestFit,optima,FunctionCalls]=FPA([500.255002]);%FitFunc implements the function to be optimized%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%function [mem,bestSol,bestFit,optima,FunctionCalls]=FPA(para)% Default parametersif nargin<1,   para=[50 0.25 500];   endn=para(1);           % Population sizep=para(2);           % Probabibility switchN_iter=para (3);  % Number of iterationsphase = 1; %First statephaseIte= [0.5,0.9,1.01]; %State vector%Deb Functiond = 1;Lb = 0;Ub = 1;optima =  [.1;.3;.5;.7;.9];% Initialize the populationfor i=1:n,  Sol(i,:)=Lb+(Ub-Lb).*rand(1,d);  Fitness(i)=fitFunc(Sol(i,:));  %%Evaluate fitness functionend% Initialice the memory[mem,bestSol,bestFit,worstF] = memUpdate(Sol,Fitness, [], zeros(1,d), 100000000, 0, phase,d,Ub,Lb);S = Sol;FunctionCalls = 0;% Main Loopfor ite = 1 : N_iter,                    %For each pollen gamete, modify each position acoording                    %to local or global pollination                    for i = 1 : n,                                % Switch probability                                if rand>p,                                                                                        L=Levy(d);                                            dS=L.*(Sol(i,:)-bestSol);                                            S(i,:)=Sol(i,:)+dS;                                            S(i,:)=simplebounds(S(i,:),Lb,Ub);                                else                                            epsilon=rand;                                            % Find random flowers in the neighbourhood                                            JK=randperm(n);                                            % As they are random, the first two entries also random                                            % If the flower are the same or similar species, then                                            % they can be pollenated, otherwise, no action.                                            % Formula: x_i^{t+1}+epsilon*(x_j^t-x_k^t)                                            S(i,:)=S(i,:)+epsilon*(Sol(JK(1),:)-Sol(JK(2),:));                                            % Check if the simple limits/bounds are OK                                            S(i,:)=simplebounds(S(i,:),Lb,Ub);                                end                                Fitness(i)=fitFunc(S(i,:));                    end                    %Update the memory                    [mem,bestSol,bestFit,worstF] = memUpdate(S,Fitness,mem,bestSol,bestFit,worstF,phase,d,Ub,Lb);                                       Sol = get_best_nest(S, mem, p);                                      FunctionCalls = FunctionCalls + n;                                   if ite/N_iter > phaseIte(phase)                        %Next evolutionary process stage                        phase = phase + 1;                        [m,~]=size(mem);                        %Depurate the memory for each stage                        mem = cleanMemory(mem);                        FunctionCalls = FunctionCalls + m;                   endend%Plot the solutions (mem) founded by the multimodal frameworkx = 0:.01:1;y = ((sin(5.*pi.*x)).^ 6);plot(x,y)hold onplot(mem(:,1),-mem(:,2),'r*');

3 仿真结果

image.gif编辑

4 参考文献

[1]牛庆、曹爱民、陈潇一、周冬. 基于花朵授粉算法和BP神经网络的短期负荷预测[J]. 电网与清洁能源, 2020, 36(10):5.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

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


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
3月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
210 8
|
3月前
|
机器学习/深度学习 算法 自动驾驶
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
224 8
|
3月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
390 0
|
3月前
|
算法 定位技术 计算机视觉
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
174 0
|
3月前
|
算法 机器人 计算机视觉
【图像处理】水下图像增强的颜色平衡与融合技术研究(Matlab代码实现)
【图像处理】水下图像增强的颜色平衡与融合技术研究(Matlab代码实现)
146 0
|
3月前
|
新能源 Java Go
【EI复现】参与调峰的储能系统配置方案及经济性分析(Matlab代码实现)
【EI复现】参与调峰的储能系统配置方案及经济性分析(Matlab代码实现)
146 0
|
3月前
|
机器学习/深度学习 编解码 算法
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
224 8
|
3月前
|
机器学习/深度学习 数据采集 测试技术
基于CEEMDAN-VMD-BiLSTM的多变量输入单步时序预测研究(Matlab代码实现)
基于CEEMDAN-VMD-BiLSTM的多变量输入单步时序预测研究(Matlab代码实现)
131 8
|
3月前
|
编解码 运维 算法
【分布式能源选址与定容】光伏、储能双层优化配置接入配电网研究(Matlab代码实现)
【分布式能源选址与定容】光伏、储能双层优化配置接入配电网研究(Matlab代码实现)
205 12
|
3月前
|
人工智能 数据可视化 网络性能优化
【顶级SCI复现】虚拟电厂的多时间尺度调度:在考虑储能系统容量衰减的同时,整合发电与多用户负荷的灵活性研究(Matlab代码实现)
【顶级SCI复现】虚拟电厂的多时间尺度调度:在考虑储能系统容量衰减的同时,整合发电与多用户负荷的灵活性研究(Matlab代码实现)
164 9

热门文章

最新文章