Using FIND for common elements WITHOUT a loop (Vectorized?)
1 次查看(过去 30 天)
显示 更早的评论
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 个评论
Star Strider
2019-2-2
The unique function comes quickly to mind.
The third output from unique may be what you want.
采纳的回答
Stephen23
2019-2-3
>> 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 个评论
Stephen23
2019-2-5
"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
2020-4-11
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.
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Time Series Objects 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!