粒子群算法(PSO)优化的BP神经网络预测,PSO-BP回归预测

关注:智能算法及其模型预测

clc;
clear all;
close all
% restoredefaultpath
tic

%%  导入数据
% 训练集——190个样本
P = xlsread('data','training set','B2:G191')';
T = xlsread('data','training set','H2:H191')';
% 测试集——44个样本
P_test=xlsread('data','test set','B2:G45')';
T_test=xlsread('data','test set','H2:H45')';

N = size(P_test, 2);          % 测试集样本数
M = size(P, 2);         % 训练集样本数
% warning('off')
% 初始隐层神经元个数
hiddennum=15;                                          %数据维度数15 数据条数是9
inputnum=size(P,1);       % 输入层神经元个数8          
outputnum=size(T,1);      % 输出层神经元个数1
w1num=inputnum*hiddennum; % 输入层到隐层的权值个数
w2num=outputnum*hiddennum;% 隐层到输出层的权值个数
NN=w1num+hiddennum+w2num+outputnum; %待优化的变量的个数

%% 定义PSO算法参数
E0 = 0.001;                             % 允许误差    达到误差时就可以停止迭代
MaxNum = 20;                           % 粒子最大迭代次数
narvs = NN;                              % 目标函数的自变量个数
particlesize = 30;                      % 粒子群规模
c1 = 1.5;                                 % 个体经验学习因子
c2 = 1.5;                                 % 社会经验学习因子
w =0.8;                                 % 惯性因子
vmax = 0.8;                             % 粒子的最大飞翔速度
x = -1 + 2* rand(particlesize, narvs);% 粒子所在的位置 (rand产生的大小为0,1),规模是 粒子群数和参数需求数 设置了x的取值范围[-5,5] 
v = rand(particlesize,narvs);         % 粒子的飞翔速度  生成每个粒子的飞翔速度,由于是只有一个变量,所以速度是一维的
trace=zeros(NN+1,MaxNum);                        %寻优结果的初始值
ObjV=Objfun(x,P,T,hiddennum,P_test,T_test);        %计算目标函数值
personalbest_x=x;         % 用于存储对于每一个粒子最佳经历点的x值
personalbest_faval=ObjV;     % 同时存储对于每一个粒子的最佳经历点的数值,用于更改 
[globalbest_faval,i] = min(personalbest_faval); % min函数返回的第一个是最小值,还有一个就是最小值的下标,这里就是告诉了是在哪个粒子上
globalbest_x = personalbest_x(i,:);   % 这个是必定是全局最优点的位置
k = 1; % 开始迭代计数
while k <= MaxNum   % 当迭代次数达到设定的最大值的时候,就不要再进行迭代了
    ObjV=Objfun(x,P,T,hiddennum,P_test,T_test);        %计算目标函数值
    for i = 1:particlesize   % 对于每一个粒子        
%         f(i) = fitness(x(i,1)); % 得到每个粒子的当前位置 在函数上的适应值 
        if ObjV(i) < personalbest_faval(i)   % 如果这个值是小于个人最优解的位置的时候,就更新,我们经过转换,所以只用考虑求最小值的情况
            personalbest_faval(i) = ObjV(i); % 将第i个粒子的个人最优解设置为
            personalbest_x(i,:) = x(i,:); % 同时更改最有地址的位置
        end
    end 
        
   [globalbest_favalN,i] = min(personalbest_faval); 
    globalbest_xn = personalbest_x(i,:); % 更新全局 全局信息由个体信息描述组成
    
   trace(1:NN,k)=globalbest_xn;                       %记下每代的最优值x值
   trace(end,k)=globalbest_favalN;                               %记下每代的最优值

  • 0
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
粒子算法-反向传播神经网络PSO-BP)是一种使用粒子算法PSO优化BP神经网络的方法,用于回归预测问题。下面是一个使用Matlab实现PSO-BP的代码示例: 首先,我们需要导入所需的Matlab工具箱,如Neural Network Toolbox和Particle Swarm Optimization Toolbox。 ```matlab % 导入数据集 data = load('data.csv'); % 将数据集存储在名为data.csv的文件中 X = data(:, 1:end-1); % 特征数据 y = data(:, end); % 目标数据 % 初始化BP神经网络 net = feedforwardnet([10 10]); % 创建一个包含两个隐藏层(每个隐藏层有10个神经元)的前馈型神经网络 net.trainFcn = 'trainlm'; % 设置BP神经网络的训练算法为Levenberg-Marquardt算法 % 创建粒子算法对象 pso = psoptimset('Display', 'iter'); % 设置参数显示方式为迭代显示 % 定义适应度函数 fitness = @(x) validateBPNet(x, X, y); % 运行PSO-BP算法进行优化 [mse, best] = pso(fitness, 20, [], [], [], [], [-10 -10], [10 10], pso); % 验证BP神经网络 net = configure(net, X', y'); net.IW{1, 1} = best(1:10); net.LW{2, 1} = best(11:20); net.LW{3, 2} = best(21:30); net.b{1} = best(31:40); net.b{2} = best(41:50); net.b{3} = best(51:60); % 运行BP神经网络进行预测 y_pred = net(X'); % 显示预测结果 figure; plot(y, 'b'); hold on; plot(y_pred', 'r'); legend('实际值', '预测值'); xlabel('样本编号'); ylabel('值'); title('PSO-BP回归预测结果'); function mse = validateBPNet(x, X, y) net = feedforwardnet([10 10]); net.trainFcn = 'trainlm'; net = configure(net, X', y'); net.IW{1, 1} = x(1:10); net.LW{2, 1} = x(11:20); net.LW{3, 2} = x(21:30); net.b{1} = x(31:40); net.b{2} = x(41:50); net.b{3} = x(51:60); y_pred = net(X'); mse = mean((y - y_pred').^2); end ``` 在上述代码中,我们首先导入数据集,然后初始化了一个包含两个隐藏层的BP神经网络。接下来,我们创建了一个粒子算法对象,并定义了适应度函数。然后,我们使用PSO-BP算法进行优化,得到了最佳的神经网络参数。最后,我们使用最佳参数配置的BP神经网络进行预测,并绘制了实际值和预测值之间的比较图。 这段代码实现了PSO-BP方法用于回归预测问题的一个简单示例,你可以根据自己的需要进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

智能算法及其模型预测

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

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

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

打赏作者

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

抵扣说明:

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

余额充值