并联SVM结构的低性能

时间:2013-11-14 08:59:14

标签: parallel-processing svm

我遇到了并行SVM分类的问题。在我的代码中,我重复3次对SVM的5倍交叉验证并平均其准确性。我想要将3次重复交叉验证的主循环并列化,但是当我在这个循环中使用parfor时,程序不会使用我的CPU的2个核心的所有性能,只使用60%的性能!。

非常感谢

代码:

parfor L=1:NumOFLoops;

indices = crossvalind('Kfold',QQ,NumOfKfold);
cp = classperf(QQ);

for m=1:NumOfKfold;

test = (indices == m); Train = ~test;
testI=zeros(numel(test>0),1);

TrainInputs=INPUT(Train,:);
TrainTargets=QQ(Train,:);
TestInputs=INPUT(test,:);

%% SVM Structure

  svmstruct=svmtrain(TrainInputs,TrainTargets,...
 'boxconstraint',Penalty,...
 'kernel_function','rbf','method','QP',...
 'rbf_sigma',Sigma)

  TestOutputs=svmclassify(svmstruct,TestInputs,'showplot',false);
  classperf(cp,TestOutputs,test);

end
Error(:,L)=cp.ErrorRate;         
end
Results.ErrorRate=(sum(Error))/NumOFLoops;

0 个答案:

没有答案