Polyshape: stop Connecting first and last points.

7 Ansichten (letzte 30 Tage)
Armin Mashhadi
Armin Mashhadi am 12 Nov. 2019
Kommentiert: Adam Danz am 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 Kommentare
Adam Danz
Adam Danz am 13 Nov. 2019
Armin Mashhadi's answer moved here as a comment.
Got it.
Adam Danz
Adam Danz am 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.

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Stijn Haenen
Stijn Haenen am 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 Kommentar
Armin Mashhadi
Armin Mashhadi am 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.

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Elementary Polygons finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by