Effacer les filtres
Effacer les filtres

Extract a row from a 2D matrix if any of its element matches with elements in other 1D matrix

1 vue (au cours des 30 derniers jours)
I have 2D matrxi A (size: 10000 x 3) and 1D matrix B (size: 5000 x 1)
If one elemnt of row in A matches with any element in B, then that rwo sfould be separated out. Suppose there are N such rows then I want the output as a matrix C (size: N x 3), (which is a subset of A).
I am using the code:
counter = 0
for i = 1:length(A)
if sum(ismember(A(i,:),B)) >= 1
counter = counter + 1;
C(counter,:) = A(i,:);
end
end
This gives me the output I want, but it takes huge time especially on very large sized matrices.
Any one/two liner replacment to speed up the code?
Thanks.

Réponse acceptée

Gaurav Aggarwal
Gaurav Aggarwal le 3 Juil 2020
Modifié(e) : Gaurav Aggarwal le 3 Juil 2020
Hi Sachin,
Can you check if this works for you?
C = A(any(ismember(A,B),2),:);
Thanks.

Plus de réponses (1)

Gifari Zulkarnaen
Gifari Zulkarnaen le 3 Juil 2020
Try this:
idx = [];
for i = 1:size(A,1)
if any(ismember(A(i,:),B))
idx = [idx i];
end
end
C = A(idx,:);

Catégories

En savoir plus sur Data Type Conversion dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by