gpt4 book ai didi

geometry - 求多边形的内角

转载 作者:行者123 更新时间:2023-12-05 00:33:29 27 4
gpt4 key购买 nike

我有一些 线路 他们的交集描述了一个多边形,如下所示:

main polygon

我知道线条的顺序,以及它们的方程。

为了找到内角,我找到了每条线的方向。但是我很困惑,因为减去两条线的方向会给出两个不同的角度,即使我是按照多边形的边的顺序来做的。

例如,在下图中,如果我只减去线条的方向,我将得到以下任何角度:

defect 1

让我更困惑的是,当多边形不是凸面时,我的角度将大于 180,而使用我的方法我根本没有得到正确的角度:

defect 2

我发现这种处理问题的方式是错误的。

那么,使用 找到内角的最佳方法是什么?只是线条 ?我知道对于凸多边形,我可能会找到向量,然后找到它们之间的角度,但即使对于我的示例中的 P6,向量方法也失败了。

无论如何,我更喜欢一种不包含解决该凹度问题的条件情况的方法。

谢谢。

最佳答案

对于有序线,可以按顺时针顺序找到交点(多边形顶点)。然后你可以计算内角:

Angle[i] =  Pi + ArcTan2(V[i] x V[i+1], V[i] * V[i+1]) 

(每个顶点的传入和传出向量的叉积和点积)

或者
Angle[i] = Pi + ArcTan2( dx_in*dy_out-dx_out*dy_in, dx_in*dx_out+dy_in*dy_out2 )

注意:在 Pi之后更改加号减号为逆时针方向。

编辑:

请注意,叉积和点积是标量,而不是向量。

您的数据示例:
dx1 = 5; dy1 = -15; dx2 = -15; dy2 = 5

Angle = Pi + ArcTan2(5*5-15*15, -5*15-5*15) = Pi - 2.11 radians ~ 59 degrees

向量示例:
(0,-1) (1,0) (L-curve)

Angle = Pi + ArcTan2(1, 0) = 270 degrees

关于geometry - 求多边形的内角,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12083480/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com