set of points form a polygon?

2 ビュー (過去 30 日間)
kai
kai 2020 年 8 月 24 日
コメント済み: kai 2020 年 8 月 24 日
Hello,
Is there a way to tell if a set of vertices can form a closed polygon or not in genear or in matlab ?
Example:
[1,1], [3,1],[2,2] form a triangle when connected.
How do you conclude that these points can form a polygon.
Is there any algorithm to follow ?.
Thank you.
  2 件のコメント
KSSV
KSSV 2020 年 8 月 24 日
Always more than two non-collinear points can form a polygon. If they are on striaght line/ collinear they cannot and this can be obtained by using area; you can use polyarea to get the area. If area is zero then they are collinear. If you have a value they can form polygon.
kai
kai 2020 年 8 月 24 日
Thank you KSSV for you answer
it helped me.

サインインしてコメントする。

採用された回答

Bruno Luong
Bruno Luong 2020 年 8 月 24 日
編集済み: Bruno Luong 2020 年 8 月 24 日
If your list of points are ordered of the boundary of the polygonal, you can detect if the list of points self intersect thus NOT represent a valid polygonal by using polyshape, catch the warning or get the number of regions, if it's larger than 1 it's not valid:
EDIT: you can also use ISSIMPLIFIED function
>> x=rand(1,5)
x =
0.1419 0.4218 0.9157 0.7922 0.9595
>> y=rand(1,5)
y =
0.6557 0.0357 0.8491 0.9340 0.6787
>> issimplified(polyshape(x,y,'Simplify',false))
ans =
logical
0 % <= NOT VALID
  1 件のコメント
kai
kai 2020 年 8 月 24 日
Thank you Bruno Luong for commenting the question and helping me.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeElementary Polygons についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by