How to run find function faster?
34 views (last 30 days)
I have an array A with 6000 elements in integers, for example, "10", "12", "5" and others. Actually array A saves the number of non-zero elements in each rows of a sparse matrix B. I want to do some calculations on those selected rows in B with certian number of non-zero elements. I want to find out the indecis of selected values "10", "12" and "5" in A.
I did the following:
[~,ind1] = find(A==10);
[~,ind2] = find(A==12);
[~,ind3] = find(A==5).
I found it took about 1 second which is too slow. I am wondering if there is a faster way to do this
Thanks a lot.
dpb on 26 Jun 2021
Generally one doesn't need find explicitly at all; just use the logical addressing vector returned by the logical test.
Alternatives for something like the above would quite possibly be findgroups and splitapply depending upon just what is to be done next.
Or, of course, there are all the binning functions such as discretize that might come into play.
Without the end use here, it's hard to say specifically.
One note, however, is that creating sequentially-numbered variables such as above is generally a sign that the code factorization is not optimal in MATLAB -- arrays or cell arrays would be far better in all likelihood. Once you've created such a set of variables, you've made using them difficult for anything other than just duplicating the same code over and over...