Check if cell contains only certain combination of variables

1 vue (au cours des 30 derniers jours)
Metin Akyol
Metin Akyol le 31 Jan 2022
I have a 4x1 cell filled with 4 possible string values: 'A', 'B', 'C', or 'D'
I would like to ensure that the values in there either:
any combination of: 'A' and/or 'B'
OR
any combination of 'C' and/or 'C'
But I want to raise an error if there is any mix between say A and C, or A and D, and so forth
  3 commentaires
Metin Akyol
Metin Akyol le 31 Jan 2022
So when I print out the cell, I get this output:
example_Cell = 4x1 cell
'A'
'B'
'C'
'A'
Metin Akyol
Metin Akyol le 31 Jan 2022
So the above example, would thus be an invalid one based on my criterion, so this should raise a flag.

Connectez-vous pour commenter.

Réponse acceptée

Turlough Hughes
Turlough Hughes le 31 Jan 2022
Modifié(e) : Turlough Hughes le 31 Jan 2022
You can do this with an "exclusive or" (see xor) where you check that you have exlusively either 'A' or 'B' xor 'C' or 'D', but not a mix of A and C or A and D, etc. See the following:
x = {'A','B','C','D'}.';
% conditions
condA = any(matches(x,"A"|"B"));
condB = any(matches(x,"C"|"D"));
assert(xor(condA,condB),'Error: ...')

Plus de réponses (1)

Benjamin Thompson
Benjamin Thompson le 31 Jan 2022
So something like this? I am sure you can add more detail to deal with all possible cases.
myCellArray{1} = 'A';
myCellArray{2} = 'B';
myCellArray{3} = 'C';
myCellArray{4} = 'D';
if (myCellArray{1} == 'A')
for (i = 2:4)
if ((myCellArray{i} == 'C') || (myCellArray{i} == 'D'))
disp('Not Good')
end
end
end
  1 commentaire
Metin Akyol
Metin Akyol le 31 Jan 2022
Yep, that is kind of how I did it too. Thank you so much.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Matrix Indexing dans Help Center et File Exchange

Produits


Version

R2021a

Community Treasure Hunt

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

Start Hunting!

Translated by