温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

matlab神经网络拟合非线性函数怎么用

发布时间:2022-01-14 10:07:43 来源:亿速云 阅读:187 作者:iii 栏目:大数据

这篇“matlab神经网络拟合非线性函数怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“matlab神经网络拟合非线性函数怎么用”文章吧。

%% 构造拟合数据

for i=1:4000

    input(i,:)=10*rand(1,2)-5;

    output(i)=input(i,1)^2+input(i,2)^2;

end

output=output';


save data input output

matlab神经网络拟合非线性函数怎么用  

%% 清空环境变量

clc

clear

matlab神经网络拟合非线性函数怎么用  

tic

%% 训练数据预测数据提取及归一化

%下载输入输出数据

load data input output


%从1到2000间随机排序

k=rand(1,4000);

[m,n]=sort(k);


%找出训练数据和预测数据

input_train=input(n(1:3900),:)';

output_train=output(n(1:3900),:)';

input_test=input(n(3901:4000),:)';

output_test=output(n(3901:4000),:)';


%选连样本输入输出数据归一化

[inputn,inputps]=mapminmax(input_train);

[outputn,outputps]=mapminmax(output_train);


%% BP网络训练

% %初始化网络结构

net=newff(inputn,outputn,5);

matlab神经网络拟合非线性函数怎么用  

net.trainParam.epochs=100;

net.trainParam.lr=0.1;

net.trainParam.goal=0.0000004;


%网络训练

net=train(net,inputn,outputn);


%% BP网络预测

%预测数据归一化

inputn_test=mapminmax('apply',input_test,inputps);

 

%网络预测输出

an=sim(net,inputn_test);

 

%网络输出反归一化

BPoutput=mapminmax('reverse',an,outputps);


%% 结果分析


figure(1)

plot(BPoutput,':og')

hold on

plot(output_test,'-*');

legend({'预测输出','期望输出'},'fontsize',12)

title('BP网络预测输出','fontsize',12)

xlabel('样本','fontsize',12)

ylabel('输出','fontsize',12)

print -dtiff -r600 4-3

%预测误差

error=BPoutput-output_test;

matlab神经网络拟合非线性函数怎么用  

figure(2)

plot(error,'-*')

title('神经网络预测误差')

matlab神经网络拟合非线性函数怎么用  

figure(3)

plot((output_test-BPoutput)./BPoutput,'-*');

title('神经网络预测误差百分比')

matlab神经网络拟合非线性函数怎么用  

errorsum=sum(abs(error));

toc

save data net inputps outputps

以上就是关于“matlab神经网络拟合非线性函数怎么用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI