data:image/s3,"s3://crabby-images/4133c/4133cbec03fc5a6d54dc4fccdb3e354908bf2a52" alt=""
How to reduce the executation time for the below operation
1 回表示 (過去 30 日間)
古いコメントを表示
SatyaPrakash Gupta
2020 年 4 月 20 日
コメント済み: SatyaPrakash Gupta
2020 年 4 月 22 日
Hi,
Loc = [m*n] ; % size of X has 1500000*2
image_spots = [m*n] ; % size of X has 500000*2
distance_thresh = 0.5;
mask = false([length(Loc),1]);
tic,for i = 1:length(Loc)
if distance_thresh > min(pdist2(Loc(i,:),image_spots))
mask(i)= true;
end
end,toc;
the above for loop take atleast 12mins, is there a method or a way where i can reduce the times for the executation ?
採用された回答
Walter Roberson
2020 年 4 月 20 日
I suggest that you redesign to use knnsearch https://www.mathworks.com/help/stats/knnsearch.html asking for 1 neighbour, and comparing that one resulting distance to the threshold.
knnsearch with euclidean distance function and as few as 2 dimensions, will construct a quadtree to be able to find the distances much faster. It becomes like a 2D binary search.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Get Started with MATLAB についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!