juanshine 2015-05-27 06:57 采纳率: 0%
浏览 8314

BP神经网络拟合效果不好,怎么解决?附源程序

主函数,需调用fx2函数

%fun为进行拟合的非线性函数
%node为隐含层的节点数
%k为最大迭代次数,缺省时,默认为100
%eps为目标值,缺省时,默认为0.0001

%随机产生2000组输入数据x、输出数据y
input=10*rand(1,2000)-5;
output=zeros(1,2000);
for i=1:2000
output(i)=fsin(input(i));
end

%随机选择1000组训练数据和1000组预测数据
input_train=input(1:1000)';
output_train=output(1:1000)';
input_test=input(1001:2000)';
output_test=output(1001:2000)';

%训练数据归一化
[inputn,mininput,maxinput]=premnmx(input_train);
[outputn,minoutput,maxoutput]=premnmx(output_train);

%构建BP神经网络
net=newff([-5 5;-5 5],[5,1],{'tansig' 'purelin'}, 'trainlm' );

%配置网络参数(迭代次数、学习率、目标)
net.trainParam.epochs=3;
net.trainParam.lr=0.1;
net.trainParam.goal=eps;

%BP神经网络训练
net=train(net,inputn',outputn');

%预测数据归一化
inputn_test=tramnmx(input_test,mininput,maxinput);

%BP神经网络预测输出
an=sim(net,inputn_test');

%输出结果反归一化
BPoutput=postmnmx (an,minoutput,maxoutput);

%计算误差
error=BPoutput-output_test';

%网络预测结果图像
figure(1)
plot(BPoutput,':og')
hold on
plot(output_test,'-*');
legend('预测输出','期望输出')
title('BP网络预测输出','fontsize',12)
ylabel('函数输出','fontsize',12)
xlabel('样本','fontsize',12)

%网络预测误差图像
figure(2)
plot(error,'-*')
title('BP网络预测误差','fontsize',12)
ylabel('误差','fontsize',12)
xlabel('样本','fontsize',12)

fx2函数:
function y=fx2(x)
y=x(1)^2+x(2)^2;

  • 写回答

3条回答

  • keloli 2015-05-27 11:48
    关注

    你是要你和什么,神经网络的层数和基函数都要调的。

    评论

报告相同问题?

悬赏问题

  • ¥15 MATLAB动图的问题
  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名