indexing a square matrix in the best possible way
1 visualizzazione (ultimi 30 giorni)
Mostra commenti meno recenti
I have a square matrix and I would check some condition of every element of it.which could be the best way to indexing a square matrix using for cycle?
1 Commento
Ryan
il 23 Set 2012
What condition are you looking to test? What type of points are you looking to index? For example if you have a matrix and want to find all the values greater or equal to 100 you could do:
idx_100 = A >= 100;
More complex conditions may require alternative methods.
Risposte (3)
Azzi Abdelmalek
il 23 Set 2012
Modificato: Azzi Abdelmalek
il 23 Set 2012
you can use cellfun for cell class or arrayfun and find for double class
3 Commenti
Azzi Abdelmalek
il 23 Set 2012
A=[2 3;10 25]
% that depends on the the actions that will be taken
% for examle if you wan to find index of elements of A that are >5
[idxn,idxm]=find(A>5)
Azzi Abdelmalek
il 23 Set 2012
Modificato: Azzi Abdelmalek
il 23 Set 2012
if you want to replace all value of A that are>=3 by 100 for example
A(arrayfun(@(x) x>=3 ,A))=100
sometimes for loop can't be replaced
Walter Roberson
il 23 Set 2012
If you are using a nested for loop, have the inner loop be over the first index.
If you are using a single for loop, just use natural index order.
0 Commenti
Image Analyst
il 23 Set 2012
Savatore, it depends on what you want to do. You need to tell us because that will affect the answer. For example if you have matrix A and matrix B and you want to set matrix B to 999 every place that matrix A is between 100 and 200, you'd do something like this
B(A>100 & A<200) = 999;
No for loop needed. In general, you do something like
logicalIndexes = (A == someCondition);
someMatrix(logicalIndexes) = someValue; % someMatrix could be A or some other matrix.
But if you wanted to do something like beep a tone the number of times that equals the value of A but only for all A that are less than 10, or something else that's more complicated, then you might want to use a loop.
0 Commenti
Vedere anche
Categorie
Scopri di più su Matrix Indexing in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!