How to check if a column data is equal to any of a group of values?
11 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
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 comentarios
Respuestas (4)
Sulaymon Eshkabilov
el 3 de Oct. de 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 comentarios
Sulaymon Eshkabilov
el 3 de Oct. de 2020
Altenrative (more efficient one) solution can be this one:
S = sum(sum(ismember(A,B)))
0 comentarios
madhan ravi
el 3 de Oct. de 2020
Editada: madhan ravi
el 3 de Oct. de 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 comentarios
Ver también
Categorías
Más información sobre Matrix Indexing en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!