Azzera filtri
Azzera filtri

Polyshape: stop Connecting first and last points.

3 visualizzazioni (ultimi 30 giorni)
Armin Mashhadi
Armin Mashhadi il 12 Nov 2019
Commentato: Adam Danz il 13 Nov 2019
Hello all, How you doin? Can you please help me with an issue?
Problem:
I have many sets of Data (Like attached one), in two vectors that are produced seperetly by another script.
Now, I need to plot them, devide them between "Closed" and "Open" , Then search between "Closed" ones to see which one is the stable one.
I used "polyshape" like it:
load('Data');
a = polyshape(Data(:,1),Data(:,2),'Simplify',true);
b =regions(a);
plot(b)
the problem is that polyshape connects first and last point automaticlly (even when simplify is off). So all regions are closed now and finding stable region encounter with wrong answers.
Do you have any idea, about disabling this feature (to leave the plot as it is), Or any alternative command that works like "polyshape" and has ability to recognize regions with their boundry points?
Thanks a lot for your time.
----------------------------------------------------------------------------------------------------
Another Example:
how to find boundries of JUST closed area of this points? (Data2.m)
ee.JPG
  5 Commenti
Adam Danz
Adam Danz il 13 Nov 2019
Armin Mashhadi's answer moved here as a comment.
Got it.
Adam Danz
Adam Danz il 13 Nov 2019
@ Armin Mashhadi, if you'd like to share your solution, please add it as an answer. "got it" isn't an answer.

Accedi per commentare.

Risposte (1)

Stijn Haenen
Stijn Haenen il 12 Nov 2019
Hi,
do you mean this?
load('Data');
a=polyshape(Data(:,1),Data(:,2));
b=regions(a);
area=[b(2,1).Vertices(:,1) b(2,1).Vertices(:,2)];
line=[b(3,1).Vertices(:,1) b(3,1).Vertices(:,2);b(1,1).Vertices(:,1) b(1,1).Vertices(:,2)];
shape_area=polyshape(area);
plot(regions(shape_area));
hold on
[c,d]=max(line(1:end-1,1)-line(2:end,1));
plot(line(d+1:end,1),line(d+1:end,2),'black');
plot(line(1:d-1,1),line(1:d-1,2),'black');
  1 Commento
Armin Mashhadi
Armin Mashhadi il 12 Nov 2019
Hi,
I really appreciate your efford and spending time.
But no, that was not wat i meant.
The question is how to find that region2 is closed and others are not , automaticlly.
But you assumed that region2 is closed then drew using its vertices.

Accedi per commentare.

Categorie

Scopri di più su Elementary Polygons in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by