为什么我这个程序每次交叉验证求取spread的结果都不同呢?最终结果也不相同? 20C

%% 清空环境变量
clc;
clear all
close all
nntwarn off;%关闭警告

%% 载入数据
load data;
% 载入数据并将数据分成训练和预测两类
p_train=p(1:12,:);%p 影响因素,t 实际值
t_train=t(1:12,:);
p_test=p(13,:);
t_test=t(13,:);
%% 交叉验证
desired_spread=[];
mse_max=10e20;
desired_input=[];%期望
desired_output=[];
result_perfp=[];
indices = crossvalind('Kfold',length(p_train),4);%K折交叉验证,随机选择
h=waitbar(0,'正在寻找最优化参数....')%进度条
k=1;
for i = 1:4
perfp=[];
disp(['以下为第',num2str(i),'次交叉验证结果'])%输出
test = (indices == i); train = ~test;%==是逻辑判断,是则等于1,否则等于0
p_cv_train=p_train(train,:);
t_cv_train=t_train(train,:);
p_cv_test=p_train(test,:);
t_cv_test=t_train(test,:);
p_cv_train=p_cv_train';
t_cv_train=t_cv_train';
p_cv_test= p_cv_test';
t_cv_test= t_cv_test';
[p_cv_train,minp,maxp,t_cv_train,mint,maxt]=premnmx(p_cv_train,t_cv_train);%归一化
p_cv_test=tramnmx(p_cv_test,minp,maxp);
for spread=0.1:0.1:2
net=newgrnn(p_cv_train,t_cv_train,spread);
waitbar(k/80,h);
disp(['当前spread值为', num2str(spread)]);
test_Out=sim(net,p_cv_test);%书签
test_Out=postmnmx(test_Out,mint,maxt);
error=t_cv_test-test_Out;
disp(['当前网络的mse为',num2str(mse(error))])
perfp=[perfp mse(error)];
if mse(error)<mse_max
mse_max=mse(error);
desired_spread=spread;
desired_input=p_cv_train;
desired_output=t_cv_train;
end
k=k+1;
end
result_perfp(i,:)=perfp;
end;
close(h)
disp(['最佳spread值为',num2str(desired_spread)])
disp(['此时最佳输入值为'])
desired_input
disp(['此时最佳输出值为'])
desired_output
%% 采用最佳方法建立GRNN网络
net=newgrnn(desired_input,desired_output,desired_spread);
p_test=p_test';
p_test=tramnmx(p_test,minp,maxp);
grnn_prediction_result=sim(net,p_test);
grnn_prediction_result=postmnmx(grnn_prediction_result,mint,maxt);
grnn_error=t_test-grnn_prediction_result';
disp(['GRNN神经网络三项流量预测的误差为',num2str(abs(grnn_error))])
save best desired_input desired_output p_test t_test grnn_error mint maxt


1

2个回答

k折交叉验证https://blog.csdn.net/u011650143/article/details/71519240
每次的结果应该是不一样,但是经过多次,结果应该不会相差太大
想让结果复现,或者让每次结果一样,你需要设置一个随机种子,随机种子一样,每次执行结果就会是一样的
看一下matlab的随机数种子用法:https://blog.csdn.net/qq_26569761/article/details/53465617

0
xianyiming01
xianyiming01 对,已经解决了,程序开始加一句rng default就行,感谢
5 个月之前 回复

已经解决了,程序开始加一句rng default就行

0
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!