Find a 4-point polygon enclosing scattered points

10 visualizaciones (últimos 30 días)
Albert
Albert el 8 de Jun. de 2021
Comentada: Scott MacKenzie el 9 de Jul. de 2021
I have a set of scattered points (x,y) as in the attached figure and I want to find the polygon defined only by 4 points that encloses those scattered points. Those 4 points will belong to the original set of (x,y) points because they are quite regularly spaced as in the figure. How could I find the vertices of the shape? thanks

Respuesta aceptada

Scott MacKenzie
Scott MacKenzie el 8 de Jun. de 2021
Editada: Scott MacKenzie el 8 de Jun. de 2021
No doubt this can be simplified, but I think it meets your objective of finding the vertices (4) enclosing the points:
% create sample of regularly-spaced points, as per question
g = 0:0.1:1;
x = [];
y = [];
for i=1:10
x = [x i+g];
y = [y i-g];
end
ax = gca;
ax.XTick = 0:12;
ax.YTick = -2:12;
hold on;
plot(x,y,'.');
k = boundary(x',y');
[~, xMinIdx] = min(x(k));
[~, xMaxIdx] = max(x(k));
[~, yMinIdx] = min(y(k));
[~, yMaxIdx] = max(y(k));
xx = x(k);
yy = y(k);
p = polyshape([xx(xMinIdx) xx(yMinIdx) xx(xMaxIdx) xx(yMaxIdx)], ...
[yy(xMinIdx) yy(yMinIdx) yy(xMaxIdx) yy(yMaxIdx)]);
plot(p);
v = p.Vertices % output vertices (4)
Command window output:
v =
1 1
10 10
11 9
2 0
Figure window:

Más respuestas (1)

Matt J
Matt J el 8 de Jul. de 2021
k=convhull(x,y);
xc=x(k); yc=y(k); %corners
  5 comentarios
Matt J
Matt J el 8 de Jul. de 2021
Editada: Matt J el 8 de Jul. de 2021
@Scott MacKenzie similar to your solution, polyshape is a pretty good tool for weeding out the non-vertex boundary points that convhull() doesn't manage to find:
g = 0:0.1:1;
x = [];
y = [];
for i=1:10
x = [x i+g];
y = [y i-g];
end
k=convhull(x,y);
p=polyshape(x(k),y(k));
Warning: Polyshape has duplicate vertices, intersections, or other inconsistencies that may produce inaccurate or unexpected results. Input data has been modified to create a well-defined polyshape.
v=p.Vertices
v = 4×2
1 1 10 10 11 9 2 0
Scott MacKenzie
Scott MacKenzie el 9 de Jul. de 2021
@Matt J Hey, that's great. Thanks for the follow-up and clarification.

Iniciar sesión para comentar.

Categorías

Más información sobre Elementary Polygons en Help Center y File Exchange.

Productos


Versión

R2020a

Community Treasure Hunt

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

Start Hunting!

Translated by