Effacer les filtres
Effacer les filtres

Error using get for Naive Bayes

1 vue (au cours des 30 derniers jours)
Lester Lim
Lester Lim le 25 Jan 2013
Commenté : Venkatesh Deo le 15 Mar 2017
Error using get Too many input arguments.
Error in NaiveBayesClassifier2 (line 82) get predicted output for test set
Code:
% NAIVE BAYES CLASSIFIER
clear
tic
disp('--- start ---')
distr='normal';
distr='kernel';
% read data
data = importdata('White_Wine.xlsx')%import the data
features=data.data.Sheet1(:,1:end-1); %split data without labels
lable=data.data.Sheet1(:,end);
X = features;%Take up to row 11
Y = lable;%Take row 12 which is the label
% Create a cvpartition aka cross validation
c = cvpartition(Y,'holdout',.2);
% Create a training set
x = X(training(c,1),:);
y = Y(training(c,1));
% test set
u=X(test(c,1),:);
v=Y(test(c,1),:);
yu=unique(y);%find the unique elements. The resulting vector yu is sorted in ascending order and its elements are of the same class as y.
nc=length(yu); % number of classes
ni=size(x,2); % independent variables
ns=length(v); % test set
% compute class probability
for i=1:nc
fy(i)=sum(double(y==yu(i)))/length(y);
end
switch distr
case 'normal'
% normal distribution
% parameters from training set
for i=1:nc
xi=x((y==yu(i)),:);
mu(i,:)=mean(xi,1);
sigma(i,:)=std(xi,1);
end
% probability for test set
for j=1:ns
fu=normcdf(ones(nc,1)*u(j,:),mu,sigma);
P(j,:)=fy.*prod(fu,2)';
end
case 'kernel'
% kernel distribution
% probability of test set estimated from training set
for i=1:nc
for k=1:ni
xi=x(y==yu(i),k);
ui=u(:,k);
%fuStruct(i,k).f = ksdensity(xi,ui);
end
end
% re-structure
for i=1:ns
for j=1:nc
for k=1:ni
%fu(j,k)=fuStruct(j,k).f(i);
end
end
%P(i,:)=fy.*prod(fu,2)';
end
otherwise
disp('invalid distribution stated')
return
end
get predicted output for test set
[pv0,id]=max(P,[],2);
for i=1:length(id)
pv(i,1)=yu(id(i));
end
% compare predicted output with actual output from test data
confMat=myconfusionmat(v,pv);
disp('confusion matrix:')
disp(confMat)
conf=sum(pv==v)/length(pv);
disp(['accuracy = ',num2str(conf*100),'%'])
toc

Réponse acceptée

the cyclist
the cyclist le 25 Jan 2013
Looks like you forget to put a comment character before the line:
>> get predicted output for test set
  3 commentaires
Lester Lim
Lester Lim le 28 Jan 2013
Yup, you're right, I changed a few more stuff and it works fine...
Venkatesh Deo
Venkatesh Deo le 15 Mar 2017
I have put a comment character but it is still not working. What other changes did you make? Can you please help me with those.

Connectez-vous pour commenter.

Plus de réponses (0)

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by