How to check if a column data is equal to any of a group of values?
4 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
I have a column data A like the below:
A = [1; 3; 2; 7; 11; 6];
B can be a group of numbers with unknow counts. For example B can be like the below:
B = [1; 7];
Here is my question. How do I come up with an index to show the elemens of A that can be any of B? For example if I know B has two elements, I can use something like the below, but B can have an unknown number of elements.
Ind1 = A == B(1);
Ind2 = A == B(2);
Ind = Ind1 + Ind2;
0 Kommentare
Antworten (4)
Sulaymon Eshkabilov
am 3 Okt. 2020
You can use a loop for instance if you have many Bs, e.g.:
for ii = 1:numel(B)
Ind = A==B(ii); S(ii) = sum(Ind(:));
end
S_all=sum(S); % Total number of observed cases
2 Kommentare
Sulaymon Eshkabilov
am 3 Okt. 2020
Altenrative (more efficient one) solution can be this one:
S = sum(sum(ismember(A,B)))
0 Kommentare
madhan ravi
am 3 Okt. 2020
Bearbeitet: madhan ravi
am 3 Okt. 2020
clear sum
Ind = sum(ismember(A, B), 2)
%Or perhaps you need
Ind = nnz(ismember(A, B))
%or
fprintf('%d occurs %d times/s\n', [B.'; sum(A == B.')])
0 Kommentare
Siehe auch
Kategorien
Mehr zu Matrix Indexing finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!