Voronoi polygons distance between points

10 次查看(过去 30 天)
Hello
I have set of 2D points and after creation of voronoi polygons I want to calculeate distance between poit from one polygone and all neighborhood points (as in picture). Blue dots are my 2D points

采纳的回答

Matt J
Matt J 2019-6-26
编辑:Matt J 2019-6-26
This returns the result as a distance matrix such as produced by pdist2, except that all entries not corresponding to neighboring points are set to NaN. Neighbors are defined as points whose Voronoi polygons share one or more (finite) vertices.
[V,C]=voronoin(points);
F=all(isfinite(V),2);
D=pdist2(points,points);
D(~common_vertex(C,F))=nan, %the result
function map = common_vertex(C,F)
n=numel(C);
map=false(n);
for i=1:n
for j=1:i-1
map(i,j)=any( F(intersect(C{i},C{j})) );
end
end
map=logical(map+map.');
map(1:n+1:end)=1;
end
  4 个评论
Matt J
Matt J 2019-7-4
编辑:Matt J 2019-7-4
hope that is correct way
Only you can know if it serves your needs, but I'm not sure it is equivalent to the neighborhood analysis you were originally pursuing. It assumes that points belonging to a common Delaunay triangle always occupy neighboring Voronoi poygons, and I'm not sure that's true.
giometar
giometar 2019-7-9
that is the reason why I wrote "hope that is correct way"
I use both ways, to be sure that results are good :-)

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Voronoi Diagram 的更多信息

产品


版本

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by