Hi all, I'm struggling to figure a simple method to determine the number of unique values per row in a matrix. For example in the matrix [1 2 3; 4 4 5; 6 6 6]
I would expect the result to be [3, 2, 1] I've tried using unique() and histc but neither are giving me the result I am looking for. Thanks!

댓글 수: 2

Stephan
Stephan 2018년 11월 4일
편집: Stephan 2018년 11월 4일
Please explain the thoughts that lead to your expected result.
Zee Imports
Zee Imports 2018년 11월 4일
Hi, As there are 3x unique values in row 1, 2x unique values in row 2 and 1x unique values in row 3.
I have basically windowed an audio signal into a matrix and am now trying to find the number of unique values in each window

댓글을 달려면 로그인하십시오.

 채택된 답변

Bruno Luong
Bruno Luong 2018년 11월 4일

5 개 추천

>> A=[1 2 3; 4 4 5; 6 6 6]
A =
1 2 3
4 4 5
6 6 6
>> sum(diff(sort(A,2),1,2)~=0,2)+1
ans =
3
2
1

추가 답변 (1개)

Walter Roberson
Walter Roberson 2018년 11월 4일

1 개 추천

There is a vectorized way to compute this but it is not simple and it quickly gets expensive to calculate. Easier is
cellfun(@(c) length(unique(c)), num2cell(YourMatrix, 2))

카테고리

태그

질문:

2018년 11월 4일

댓글:

2018년 11월 6일

Community Treasure Hunt

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

Start Hunting!

Translated by