栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python点到向量的距离,夹角

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

python点到向量的距离,夹角

图像坐标系,0,0在左上角 向右x正方向,向下y轴正方向。

y轴与标准坐标系方向相反。

import numpy as np

def angle(v1, v2):
    dx1 = v1[2] - v1[0]
    dy1 = -(v1[3] - v1[1])
    dx2 = v2[2] - v2[0]
    dy2 = -(v2[3] - v2[1])
    angle1 = math.atan2(dy1, dx1)
    angle1 = -int(angle1 * 180 / math.pi)
    if angle1 < 0:
        angle1 = 360 + angle1

    # print(angle1)
    angle2 = math.atan2(dy2, dx2)
    angle2 = - int(angle2 * 180 / math.pi)
    if angle2 < 0:
        angle2 = 360 + angle2

    print(angle1, angle2)

    included_angle = angle1 - angle2
    if abs(included_angle) > 180:
        included_angle = included_angle / abs(included_angle) * (360 - abs(included_angle))
    else:
        included_angle *= -1
    return included_angle

if __name__ == '__main__':
    import math

    AB = [2, 5, 4, 1]
    CD = [2, 5, 5, 3]
    ang1 = angle(AB, CD)
    print("AB和CD的夹角")
    print(ang1)
    ang1 = angle(CD, AB)
    print("CD和AB的夹角")
    print(ang1)

    dis_long=np.sqrt((CD[3]-CD[1])**2+(CD[2]-CD[0])**2)

    print(dis_long)

    dis2= (ang1 / 180 * math.pi)*dis_long

    print(abs(dis2))




转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/290851.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号