Hi,
I have a set of 2D data in the format [X Y] and am going to thin them based on a certain distance threshold,i.e. if points are very close less than a threshold, one is eliminated. This process continues until the distance between any two points is bigger than the threshold. I developed a code to do that but it is very time consuming. I am wondering if there is a better way of doing this in Matlab.
Thank you.
Mehdi

답변 (1개)

Andrei Bobrov
Andrei Bobrov 2015년 7월 17일
편집: Andrei Bobrov 2015년 7월 17일

0 개 추천

X = randi([5,100],20,1);
Y = randi([-100,10],20,1);
trld = 10; % threshold
n = numel(X);
ii = nchoosek(1:n,2);
a = hypot(X(ii(:,1))-X(ii(:,2)),Y(ii(:,1))-Y(ii(:,2)));
lo = a > trld;
ind = unique(ii(lo,:));
out = [X(ind),Y(ind)];

댓글 수: 1

Mehdi Ravanbakhsh
Mehdi Ravanbakhsh 2015년 7월 17일
Thanks Andrei. I tested your code and it never goes beyond nchoosek(1:n,2); Why it is so? nchoosek seems to be computationally heavy.
I test my own code which takes 3 minutes for 150000 points but your code goes forever. Any advice?

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 Just for fun에 대해 자세히 알아보기

질문:

2015년 7월 17일

댓글:

2015년 7월 17일

Community Treasure Hunt

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

Start Hunting!

Translated by