Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Count strings occurrences and plot histogram

Is there any straightforward way to create a histogram from a cell array like the one below? The spacing between the consecutive bars should be exactly the same and the labels of the x-axis should be the corresponding names of the variables below in a vertical orientation.

'w464'
'w462'
'w461'
'w464'
'w461'
'w463'
'w466'
'w461'
like image 269
user706838 Avatar asked Aug 15 '12 09:08

user706838


4 Answers

I would like to know a better way, as well. Fwiw, I have used countmember in a roundabout way to plot data like this. I.E. if the data you posted was named A

>> B={sort(unique(A)) countmember(sort(unique(A)),A)};
>> bar(B{2});
>> set(gca,'XTickLabel',B{1})
like image 122
AGS Avatar answered Oct 15 '22 16:10

AGS


If you have access to the statistics toolbox, grp2idx is very useful:

%# sorting is only necessary if the output should be sorted as well
[idx,label] = grp2idx(sort(A)) 

hist(idx,unique(idx));
set(gca,'xTickLabel',label)
like image 20
Jonas Avatar answered Oct 15 '22 17:10

Jonas


A solution that only uses built-in functions

[u,~,n] = unique(A(:));
B = accumarray(n, 1, [], @sum);
bar(B)
set(gca,'XTickLabel',u)
like image 3
Mohsen Nosratinia Avatar answered Oct 15 '22 18:10

Mohsen Nosratinia


You can also use the histogram function as follows:

[C,~,ic] = unique(A);

fig1 = figure;
axes1 = axes('Parent',fig1,'XTickLabel',C,'XTick',1:length(C));
hold(axes1,'on');

histogram(ic)
like image 2
positronidude Avatar answered Oct 15 '22 18:10

positronidude