elements >0 are present in matrix only once
Show older comments
a= [3 5 9 12 0 0 0 0
4 6 7 8 10 11 0 0
15 17 18 19 0 0 0 0
16 21 22 27 28 34 35 36
23 25 30 32 0 0 0 0
38 42 44 45 46 50 51 0
39 40 41 0 0 0 0 0
43 48 49 0 0 0 0 0
54 55 60 64 65 0 0 0
56 57 58 59 68 0 0 0
73 75 77 79 80 81 82 0
74 76 78 0 0 0 0 0
]
i want to know if elements >0 are present only once...
Accepted Answer
More Answers (3)
John D'Errico
on 22 Aug 2023
Edited: John D'Errico
on 22 Aug 2023
- Count the number of non-zero unique elements.
- Count the number of non-zero elements.
- Are those two numbers the same? In either case, you have your answer.
How can you count the number of non-zero elements?
help nnz
How can you count the number of unique non-zero elements? Almost as easy. Start with unique.
help unique
Count the number of unique values it generates. If zero is among that list, can you just now subtract 1?
The point is, IF all alements are present only once, then the two counts of elements will be the same. But if there are some duplicates, then they will not be the same.
And of course, this presumes your matrix is entirely non-negative. However, IF there are negative values, then just turn them into zero, then perform the above steps. Simple enough in any case.
a= [3 5 9 12 0 0 0 0
4 6 7 8 10 11 0 0
15 17 18 19 0 0 0 0
16 21 22 27 28 34 35 36
23 25 30 32 0 0 0 0
38 42 44 45 46 50 51 0
39 40 41 0 0 0 0 0
43 48 49 0 0 0 0 0
54 55 60 64 65 0 0 0
56 57 58 59 68 0 0 0
73 75 77 79 80 81 82 0
74 76 78 0 0 0 0 0];
ahat = a(a>0); % save only the elements that are positive numbers.
% we need not even use nnz in the next line, since the creation of
% ahat discards all zeros.
numel(ahat) == numel(unique(ahat))
It returns true, so the positive elements were found exactly once in that array. No duplicates at all exist.
Alternatively, you could use unique and diff, then combined with all.
all(diff(unique(ahat)))
Again, a true result, so the elements are all unique. This works because unique sorts the values as it returns them.
1 Comment
Walter Roberson
on 22 Aug 2023
You can select the positive elements into a temporary variable. Then you can test whether the number of elements in that variable is the same as the number of unique elements in the variable.
Walter Roberson
on 22 Aug 2023
0 votes
If you need to determine which entries are present more than once, one of the ways is to use findgroups and accumarray and logical indexing.
aldo
on 22 Aug 2023
9 Comments
Walter Roberson
on 22 Aug 2023
This code does not handle negative values properly.
Also, your source magic(30) does not have any zero or negative values, so you are not testing at all properly.
aldo
on 22 Aug 2023
John D'Errico
on 22 Aug 2023
Edited: John D'Errico
on 22 Aug 2023
It fails to discount any zero values, and treats negative values improperly. And worse, it just essentially copies at least a large part of my answer, which DID explain how to handle those issues.
aldo
on 22 Aug 2023
John D'Errico
on 23 Aug 2023
But they can clearly be zero! Your example shows exactly that, a has zero elements in it. So how can you possibly say they cannot be <= 0????
So I am sorry, but we don't like that code.
aldo
on 23 Aug 2023
John D'Errico
on 23 Aug 2023
Edited: John D'Errico
on 23 Aug 2023
Sigh. You say hello as if I don't understand. You posted non-working code, that fails to understand how to solve the probem you showed. Then you claimed that your problem had no non-zero elements, which was completely incorrect.
Yes, if you change the code, it can work. The code you posted as an answer does not.
This bit of clueless-ness is a waste of time on all parts.
Walter Roberson
on 23 Aug 2023
Under the condition that elements in a cannot be negative:
nnz(a) == nnz(unique(a))
Categories
Find more on Matrix Indexing 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!