%% PSO-BP神经网络
%% 清空环境
clear all;
close all;
clc;
data=xlsread('Test.xlsx','Sheet1','A2:G46');%读取数据
[M,NN]=size(data);%M是样本数,N是变量数
inputn=data(:,1:NN-1)';%训练样本输入
outputn=data(:,NN)';%训练样本输出
%节点个数
inputnum=NN-1;%输入个数
hiddennum=12;%隐藏层
outputnum=1;%输出个数
%构建网络
net=newff(inputn,outputn,hiddennum);
tic
%% 粒子群
numWolf=60;
limit = [-10, 10;]; % 设置位置参数限制(矩阵的形式可以多维)
vlimit = [-0.01, 0.01;]; % 设置速度限制
c_1 = 0.8; % 惯性权重
c_2 = 0.5; % 自我学习因子
c_3 = 0.5; % 群体学习因子
N=inputnum*hiddennum+hiddennum+hiddennum*outputnum+outputnum;
x = zeros(numWolf,N);
% 初始化种群
for i = 1:numWolf
x(i,:)=rands(1,N);
% fitness(i)=fun(x(i,:),inputnum,hiddennum,outputnum,net,inputn,outputn);
end
% [xm,LeadWolf] = min(fitness);
% ym = x(LeadWolf,:);
% globalMin = xm;
v = 0.1*rand(numWolf,N); % 初始种群的速度
xm = x; % 每个个体的历史最佳位置
ym = zeros(1, N); % 种群的历史最佳位置
fxm = 100000*ones(numWolf, 1); % 每个个体的历史最佳适应度
fym = 100000; % 种群历史最佳适应度
%% 粒子群工作
iter = 1;
end
time = toc;
disp(['用时= ',num2str(time)])
X=ym;
%% BP网络训练
%网络进化参数
net.trainParam.epochs=2000;%bp神经网络的代数
net.trainParam.lr=0.1;
%net.trainParam.goal=0.00001;
%网络训练
[net,per2]=train(net,inputn,outputn);
%% BP网络预测
% load data inputn_test output_test
inputn_test=inputn;%测试数据输入
output_test=outputn;%测试数据输出
an=sim(net,inputn_test);%预测
error=(an-output_test);%误差
error_xiangdui=(an-output_test)./output_test;%相对误差
figure(1)
plot(error_xiangdui,'ko-')
ylabel('相对误差值')
title('粒子群优化BP神经网络')
figure(2)
plot(error,'ro-')
ylabel('误差值')
title('粒子群优化BP神经网络')
figure(3)
plot(output_test,'r + -');
hold on;
plot(an,'b * -')
hold off
legend('真实值','预测值');
title('粒子群优化BP神经网络')
figure(4)
plot( record)
xlabel('迭代次数')
ylabel('均方差值')