Compare cells in cell array to find common columns

1 vue (au cours des 30 derniers jours)
sr9497
sr9497 le 30 Mar 2022
Modifié(e) : sr9497 le 4 Avr 2022
I have two cell arrays, data 1 (1x6 cell) and data 2 (1x8 cell) where each cell consists of 3x5 double or 3x4 double. I would like to compare these cell arrays and find out which cells have at least two columns in common, e.g. data1{1,1} and data2{1,1} have two columns in common. Then I would like to store all these cells in a new cell array.
What is the best way to do this?

Réponse acceptée

Matt J
Matt J le 30 Mar 2022
Modifié(e) : Matt J le 30 Mar 2022
You should just use an explicit loop over all combinations of cells. With cell arrays, there is never a good reason to look for some kind of fancy vectorization, and certainly not with arrays as small as what you've posted.
  2 commentaires
sr9497
sr9497 le 30 Mar 2022
Thank you for your answer. Which function would you suggest I use to be able to find the common columns if the cell arrays and the cells have different sizes?
Matt J
Matt J le 30 Mar 2022
Modifié(e) : Matt J le 30 Mar 2022
You can transpose the matrices and use intersect(__,'rows') if the agreement between columns is to be exact, otherwise ismembertol(__,'ByRows', true)

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Matrices and Arrays 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