Counting frequency of occurrence in matrix
Show older comments
Good day,
I am attempting to count the number of times each number in a matrix occurred in the matrix.
For example, suppose I have a matrix;
x =
22 23 24 23
24 23 24 22
22 23 23 23
I want an output which will tell me 22 occurred 3 times, 23 occurred 6 times, and 24 occurred 2 times. The actual matrix is larger in size.
Is there a specific function which returns such values or are there any other ways I can resolve this challenge?
3 Comments
Z D
on 5 Jun 2017
Edited: Andrei Bobrov
on 5 Jun 2017
you can use this command'tabulate'
Syntax
tbl = tabulate(x)
tabulate(x)
Jerry Olup
on 20 Jun 2017
Let x be your vector. Something like this can save you an unnecessary toolbox:
xx = unique(x); % temp vector of vals
x = sort(x); % sorted input aligns with temp (lowest to highest)
t = zeros(size(xx)); % vector for freqs
% frequency for each value
for i = 1:length(xx)
t(i) = sum(x == xx(i));
end
Then the t vector shows freqs of the sorted, unique vector x.
m_vdv
on 10 May 2018
Hi, is it also possible to do this without using 'unique' and 'sort'? For example with only using a for loop and/or if loop? Thanks in advance.
Accepted Answer
More Answers (3)
Aurelien Queffurust
on 23 Oct 2012
Using nnz for example:
nnz(x==22)
will return 3
1 Comment
Guan Zhao
on 23 Oct 2012
Thomas
on 23 Oct 2012
x=[22 23 24 23
24 23 24 22
22 23 23 23];
[a,b]=hist(x,unique(x));
out=[b' sum((a),2)]
abdelrahim hashem
on 15 Nov 2017
0 votes
x = [22 23 24 23; 24 23 24 22; 22 23 23 23];
un_x = unique(x);
for i = 1:length(un)
un(i), length(find(x == un_x(i)))
end
Categories
Find more on Sparse Matrices in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!