matlab train smaple,求大神解惑

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

clc

clear all

close all

%bp神经网络的预测代码

%载入输出和输入数据

load C:\Users\chen\Desktop\input.txt;

load C:\Users\chen\Desktop\output.txt;

%保存数据到matlab的工作路径里面

save inputp.mat;

save output.mat;

%注意t必须为行向量

%赋值给输入p和输出t

p=input;

t=output;

%数据的归一化处理,利用mapminmax函数,使数值归一化到[-1.1]之间

%该函数使用方法如下:[y,ps] =mapminmax(x,ymin,ymax),x需归化的数据输入,

%ymin,ymax为需归化到的范围,不填默认为归化到[-1,1]

%返回归化后的值y,以及参数ps,ps在结果反归一化中,需要调用

[p1,ps]=mapminmax(p);

[t1,ts]=mapminmax(t);

%确定训练数据,测试数据,一般是随机的从样本中选取70%的数据作为训练数据

%15%的数据作为测试数据,一般是使用函数dividerand,其一般的使用方法如下:

%[trainInd,valInd,testInd] = dividerand(Q,trainRatio,valRatio,testRatio)

[trainsample.p,valsample.p,testsample.p] =dividerand(p,0.7,0.15,0.15);

[trainsample.t,valsample.t,testsample.t] =dividerand(t,0.7,0.15,0.15);

%建立反向传播算法的BP神经网络,使用newff函数,其一般的使用方法如下

%net = newff(minmax(p),[隐层的神经元的个数,输出层的神经元的个数],{隐层神经元的传输函数,输出层的传输函数},'反向传播的训练函数'),其中p为输入数据,t为输出数据

%tf为神经网络的传输函数,默认为'tansig'函数为隐层的传输函数,

%purelin函数为输出层的传输函数

%一般在这里还有其他的传输的函数一般的如下,如果预测出来的效果不是很好,可以调节

%TF1 = 'tansig';TF2 = 'logsig';

%TF1 = 'logsig';TF2 = 'purelin';

%TF1 = 'logsig';TF2 = 'logsig';

%TF1 = 'purelin';TF2 = 'purelin';

TF1='tansig';TF2='logsig';

net=newff(minmax(p),[8,1],{TF1,TF2},'traingdm');

%返回点 net=newff(p,t,[3,8,1],{'tansig''logsig''purelin'},'traingdm')

%网络创建

%网络参数的设置

net.trainParam.epochs=10000;%训练次数设置

net.trainParam.goal=1e-5;%训练目标设置

net.trainParam.lr=0.01;%学习率设置,应设置为较少值,太大虽然会在开始加快收敛速度,但临近最佳点时,会产生动荡,而致使无法收敛

net.trainParam.mc=0.9;%动量因子的设置,默认为0.9

net.trainParam.show=25;%显示的间隔次数

%?指定训练参数

% net.trainFcn = 'traingd'; %?梯度下降算法

% net.trainFcn = 'traingdm'; %?动量梯度下降算法

% net.trainFcn = 'traingda'; %?变学习率梯度下降算法

% net.trainFcn = 'traingdx'; %?变学习率动量梯度下降算法

% (大型网络的首选算法)

% net.trainFcn = 'trainrp'; % RPROP(弹性BP)算法,内存需求最小

%?共轭梯度算法

% net.trainFcn = 'traincgf'; %Fletcher-Reeves修正算法

% net.trainFcn = 'traincgp'; %Polak-Ribiere修正算法,内存需求比Fletcher-Reeves修正算法略大

% net.trainFcn = 'traincgb'; % Powell-Beal复位算法,内存需求比Polak-Ribiere修正算法略大

% (大型网络的首选算法)

%net.trainFcn = 'trainscg'; % ScaledConjugate Gradient算法,内存需求与Fletcher-Reeves修正算法相同,计算量比上面三种算法都小很多

% net.trainFcn = 'trainbfg'; %Quasi-Newton Algorithms - BFGS Algorithm,计算量和内存需求均比共轭梯度算法大,但收敛比较快

% net.trainFcn = 'trainoss'; % OneStep Secant Algorithm,计算量和内存需求均比BFGS算法小,比共轭梯度算法略大

% (中型网络的首选算法)

%net.trainFcn = 'trainlm'; %Levenberg-Marquardt算法,内存需求最大,收敛速度最快

% net.trainFcn = 'trainbr'; %?贝叶斯正则化算法

%?有代表性的五种算法为:'traingdx','trainrp','trainscg','trainoss', 'trainlm'

%在这里一般是选取'trainlm'函数来训练,其算对对应的是Levenberg-Marquardt算法

net.trainFcn='trainlm';

[net,tr]=train(net,trainsample.p,trainsample.t);

%计算仿真,其一般用sim函数

[normtrainoutput,trainPerf]=sim(net,trainsample.p,[],[],trainsample.t);%训练的数据,根据BP得到的结果

[normvalidateoutput,validatePerf]=sim(net,valsample.p,[],[],valsample.t);%验证的数据,经BP得到的结果

[normtestoutput,testPerf]=sim(net,testsample.p,[],[],testsample.t);%测试数据,经BP得到的结果

%将所得的结果进行反归一化,得到其拟合的数据

trainoutput=mapminmax('reverse',normtrainoutput,ts);

validateoutput=mapminmax('reverse',normvalidateoutput,ts);

testoutput=mapminmax('reverse',normtestoutput,ts);

%正常输入的数据的反归一化的处理,得到其正式值

trainvalue=mapminmax('reverse',trainsample.t,ts);%正常的验证数据

validatevalue=mapminmax('reverse',valsample.t,ts);%正常的验证的数据

testvalue=mapminmax('reverse',testsample.t,ts);%正常的测试数据

%做预测,输入要预测的数据pnew

pnew=[313,256,239]';

pnewn=mapminmax(pnew);

anewn=sim(net,pnewn);

anew=mapminmax('reverse',anewn,ts);

%绝对误差的计算

errors=trainvalue-trainoutput;

%plotregression拟合图

figure,plotregression(trainvalue,trainoutput)

%误差图

figure,plot(1:length(errors),errors,'-b')

title('误差变化图')

%误差值的正态性的检验

figure,hist(errors);%频数直方图

figure,normplot(errors);%Q-Q图

[muhat,sigmahat,muci,sigmaci]=normfit(errors);%参数估计 均值,方差,均值的0.95置信区间,方差的0.95置信区间

[h1,sig,ci]= ttest(errors,muhat);%假设检验

figure,ploterrcorr(errors);%绘制误差的自相关图

figure,parcorr(errors);%绘制偏相关图

这是我的神经网络程序,弄了一天了,怎么改训练参数都没有用,求大神帮忙看看

Open Cascade是一个开源的CAD/CAE/CAM平台,提供了一套用于三维几何建模和处理的开发工具。其中,Open Cascade Sample是Open Cascade平台的一个示例项目,用于演示和学习如何使用Open Cascade平台进行三维模型的创建、编辑、显示和分析等操作。 在Open Cascade Sample中,csharp工程是一个使用C#语言编写的示例项目,主要展示了在Open Cascade平台上如何通过C#语言进行三维模型的操作和管理。通过这个示例工程,开发人员可以学习到如何使用Open Cascade提供的API来实现各种功能,如创建几何体、应用变换操作、进行几何计算和分析、进行网格生成和编辑、展示和渲染等。 在csharp工程中,可能包含的功能模块有: 1. 三维模型创建与编辑:可以通过代码创建各种几何体,如点、线、面、体等,也可以进行几何体的编辑和变换操作,如平移、旋转、缩放等。 2. 几何计算与分析:可以进行各种几何计算和分析,比如计算体积、表面积、重心、惯性矩等,也可以进行几何体的相交、包围盒计算等操作。 3. 网格生成与编辑:可以实现对几何体的网格生成和编辑操作,如三角网格生成、网格平滑、网格切割等。 4. 模型展示与渲染:可以将创建的三维模型进行展示和渲染,可以实现模型的视图操作,如放大、缩小、旋转、平移等。 总之,Open Cascade Sample中的csharp工程是一个用于展示和学习Open Cascade平台三维模型操作的示例项目,开发人员可以通过参考这个示例工程,学习如何使用Open Cascade平台的API进行各种三维模型的操作和管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值