当前位置:   article > 正文

BP神经网络参考代码——Matlab_金黄色葡萄球菌拉曼光谱数据分析matlabbp神经网络算法代码

金黄色葡萄球菌拉曼光谱数据分析matlabbp神经网络算法代码

废话不多说直接上程序:

  1. %% I. 清空环境变量
  2. clear all
  3. clc
  4. %% II. 训练集/测试集产生
  5. %%
  6. % 1. 导入数据
  7. load spectra_data.mat
  8. %%
  9. % 2. 随机产生训练集和测试集
  10. temp = randperm(size(NIR,1)); %打乱60个样本排序
  11. % 训练集——50个样本
  12. P_train = NIR(temp(1:50),:)';
  13. T_train = octane(temp(1:50),:)';
  14. % 测试集——10个样本
  15. P_test = NIR(temp(51:end),:)';
  16. T_test = octane(temp(51:end),:)';
  17. N = size(P_test,2);
  18. %% III. 数据归一化
  19. [p_train, ps_input] = mapminmax(P_train,0,1);
  20. p_test = mapminmax('apply',P_test,ps_input);
  21. [t_train, ps_output] = mapminmax(T_train,0,1);
  22. %% IV. BP神经网络创建、训练及仿真测试
  23. %%
  24. % 1. 创建网络
  25. net = newff(p_train,t_train,9); %9是隐含层神经元的个数(大家改改测试下结果影响),连接权值是3628,讲一下怎么计算得到的
  26. %%
  27. % 2. 设置训练参数
  28. net.trainParam.epochs = 1000; %迭代次数
  29. net.trainParam.goal = 1e-3; %mse均方根误差小于这个值训练结束
  30. net.trainParam.lr = 0.01; %学习率
  31. %%
  32. % 3. 训练网络
  33. net = train(net,p_train,t_train);
  34. %%
  35. % 4. 仿真测试
  36. t_sim = sim(net,p_test); %返回10个样本的预测值
  37. %%
  38. % 5. 数据反归一化
  39. T_sim = mapminmax('reverse',t_sim,ps_output); %反归一化结果
  40. %% V. 性能评价
  41. %%
  42. % 1. 相对误差error
  43. error = abs(T_sim - T_test)./T_test;
  44. %%
  45. % 2. 决定系数R^2
  46. R2 = (N * sum(T_sim .* T_test) - sum(T_sim) * sum(T_test))^2 / ((N * sum((T_sim).^2) - (sum(T_sim))^2) * (N * sum((T_test).^2) - (sum(T_test))^2));
  47. %%
  48. % 3. 结果对比
  49. result = [T_test' T_sim' error'] %输出真实值,预测值,误差
  50. %% VI. 绘图
  51. figure
  52. plot(1:N,T_test,'b:*',1:N,T_sim,'r-o')
  53. legend('真实值','预测值')
  54. xlabel('预测样本')
  55. ylabel('辛烷值')
  56. string = {'测试集辛烷值含量预测结果对比';['R^2=' num2str(R2)]};
  57. title(string)

%% I. 清空环境变量
clear all
clc

%% II. 训练集/测试集产生
%%
% 1. 导入数据
load spectra_data.mat

%%
% 2. 随机产生训练集和测试集
temp = randperm(size(NIR,1));      %打乱60个样本排序
% 训练集——50个样本
P_train = NIR(temp(1:50),:)';      
T_train = octane(temp(1:50),:)';
% 测试集——10个样本
P_test = NIR(temp(51:end),:)';
T_test = octane(temp(51:end),:)';
N = size(P_test,2);

%% III. 数据归一化
[p_train, ps_input] = mapminmax(P_train,0,1);
p_test = mapminmax('apply',P_test,ps_input);

[t_train, ps_output] = mapminmax(T_train,0,1);              

%% IV. BP神经网络创建、训练及仿真测试
%%
% 1. 创建网络
net = newff(p_train,t_train,9);    %9是隐含层神经元的个数(大家改改测试下结果影响),连接权值是3628,讲一下怎么计算得到的

%%
% 2. 设置训练参数
net.trainParam.epochs = 1000;   %迭代次数
net.trainParam.goal = 1e-3;      %mse均方根误差小于这个值训练结束
net.trainParam.lr = 0.01;         %学习率

%%
% 3. 训练网络
net = train(net,p_train,t_train);

%%
% 4. 仿真测试
t_sim = sim(net,p_test);         %返回10个样本的预测值

%%
% 5. 数据反归一化
T_sim = mapminmax('reverse',t_sim,ps_output);   %反归一化结果

%% V. 性能评价
%%
% 1. 相对误差error
error = abs(T_sim - T_test)./T_test;

%%
% 2. 决定系数R^2
R2 = (N * sum(T_sim .* T_test) - sum(T_sim) * sum(T_test))^2 / ((N * sum((T_sim).^2) - (sum(T_sim))^2) * (N * sum((T_test).^2) - (sum(T_test))^2)); 

%%
% 3. 结果对比
result = [T_test' T_sim' error']     %输出真实值,预测值,误差

%% VI. 绘图
figure
plot(1:N,T_test,'b:*',1:N,T_sim,'r-o')
legend('真实值','预测值')
xlabel('预测样本')
ylabel('辛烷值')
string = {'测试集辛烷值含量预测结果对比';['R^2=' num2str(R2)]};
title(string)

需要该程序及数据可关注下方公众号回复:BP神经网络参考代码。进行获取

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/煮酒与君饮/article/detail/739019
推荐阅读
相关标签
  

闽ICP备14008679号