Using FIND for common elements WITHOUT a loop (Vectorized?)

1 Ansicht (letzte 30 Tage)
Dave
Dave am 2 Feb. 2019
Kommentiert: Omar Salah am 11 Apr. 2020
Hello,
I have an array A 100x1 with different datenum that
I need to find in a big array B 5000000x1 (all datenum in B are in A, just repeated many times)
and then replace w another datenum C 100x1 (same index as A)
I am using find( ) but it is taking too long. Is there a way to do this without a loop?
BB=B %making a copy of B to check after.
for i=1:size(A,1)
loc=find(B==A(i))
BB(loc)=C(i);
end
  2 Kommentare
Star Strider
Star Strider am 2 Feb. 2019
The unique function comes quickly to mind.
The third output from unique may be what you want.
Dave
Dave am 3 Feb. 2019
Bearbeitet: Dave am 3 Feb. 2019
thank you, I don't know how to take your comment as the accepted answer.

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Stephen23
Stephen23 am 3 Feb. 2019
Use ismember and its second output argument:
>> A = randperm(5)
A =
3 5 4 1 2
>> B = randi(5,1,9)
B =
5 1 2 5 1 2 4 5 4
>> C = (1:5).^2
C =
1 4 9 16 25
>> [~,X] = ismember(B,A);
>> BB = C(X)
BB =
4 16 25 4 16 25 9 4 9
  3 Kommentare
Stephen23
Stephen23 am 5 Feb. 2019
"Thanks, is there a way to use that for a matrix instead?"
Probably. Please explain the logic of your new example (which is unrelated to your earlier question when C had the same size as A).
Omar Salah
Omar Salah am 11 Apr. 2020
Hi Stephen, I really wanted to thank you. I wanted to imporve my really slow code in which I tryz to find a 100k elements in a 320k elements vector. using is memeber the code runs in 5.4832 seconds instead of 1170 seconds when using for and parfor. Vectorization is magical for Big data.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Dates and Time finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by