Matlab:求出n边凹多边形内角

求凹多边形内角

我们常见的多边形多为凸多边形,即其每个内角θ小于180°的多边形。而凹多边形的一些内角θ大于180°。在Matlab求多边形内角时,通常已知条件是多边形所有顶点的坐标。若是一般的凸多边形,我们可以使用相邻三点的坐标,将其视为三角形的三个顶点,求出两边夹角,即多边形顶点的内角。公式如下:

在这里插入图片描述
或者将这三点视为两条向量,通过点积与范数来计算向量之间的夹角。公式如下:
请添加图片描述
使用手算时,对于凹多边形的内角,只需找到相应的内角,使用 360°-θ即可。然而,Matlab在用以上公式进行计算时,并不能识别出哪个内角是凹或凸,计算出来的结果都是凸的内角,小于180°。因此,需要通过其他功能函数先判断内角的凹凸性质,才能正确计算出凹多边形的内角。
Matlab社区里面已经有大佬Are Mjaavatten将判断内角凹凸性质写成一个功能函数:convex,可以在matlab官网上登录后直接下载下来调用。
在Matlab社区File Exchange内可以搜索到许多大佬贡献的优秀功能函数,推荐在里面找到一些便利的扩展函数。

% ps包含着多边形的坐标的nx2矩阵
c = convex(ps); % convex函数是判断对应顶点内角是否大于180°
for k = 1 : size(ps, 1)-2
    point1 = ps(k, :);
    vertex = ps(k+1, :);
    point2 = ps(k+2, :);
    v1 = point1 - vertex;
    v2 = point2 - vertex;   
    % 使用点积与范数求角度,需要用c值判断内角是否大于180°
    theta(k) = dot(v1, v2)/(norm(v1)*norm(v2));  % dot点积函数,norm范数取模函数
    if c(k)>0  
        angle(k) = (acos(theta(k)))*180/pi;
    else
        angle(k) = 360 - (acos(theta(k)))*180/pi;
    end
end

完整代码

Matlab:获取图形边缘轮廓,将轮廓图形n等分,并求出n边凹多边形内角

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值