Clear Filters
Clear Filters

Counting frequency of occurrence in matrix

70 views (last 30 days)
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
Jerry Olup
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
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.

Sign in to comment.

Accepted Answer

Andrei Bobrov
Andrei Bobrov on 23 Oct 2012
x =[
22 23 24 23
24 23 24 22
22 23 23 23];
a = unique(x);
out = [a,histc(x(:),a)];
  8 Comments
Brian Derstine
Brian Derstine on 31 Aug 2021
would be nice if you could just do tabulate(x)

Sign in to comment.

More Answers (3)

Aurelien Queffurust
Aurelien Queffurust on 23 Oct 2012
Using nnz for example:
nnz(x==22)
will return 3
  1 Comment
Guan Zhao
Guan Zhao on 23 Oct 2012
Hi,
My actual matrix will have at least 256 elements. I will have to consider zero elements too.
Regards
Guan Zhao

Sign in to comment.


Thomas
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
abdelrahim hashem on 15 Nov 2017
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!