【python】Calculate the Angle of a Triangle

要计算三个点形成的三角形每个角的角度,可以按照以下步骤进行:

  • 计算边的长度:使用欧几里得距离公式计算三角形三边的长度。

  • 应用余弦定理:对于每个角,使用余弦定理计算角度。余弦定理公式为:

c o s ( θ ) = a 2 + b 2 − c 2 2 a b cos(\theta) = \frac{a^2 + b^2 - c^2}{2ab} cos(θ)=2aba2+b2−c2

其中 θ \theta θ 是角, a a a 和 b b b 是角的两边, c c c 是对边。

python 代码实现

python 复制代码
import math

def calculate_angle(a, b, c):
    """
    计算三角形中顶点b的角度(使用余弦定理)
    :param a: 点a的坐标 (x, y)
    :param b: 点b的坐标 (x, y)
    :param c: 点c的坐标 (x, y)
    :return: 顶点b的角度(弧度制)
    """
    # 计算边长
    ba = math.sqrt((a[0] - b[0])**2 + (a[1] - b[1])**2)
    bc = math.sqrt((c[0] - b[0])**2 + (c[1] - b[1])**2)
    ac = math.sqrt((a[0] - c[0])**2 + (a[1] - c[1])**2)
    
    # 应用余弦定理
    cos_theta = (ba**2 + bc**2 - ac**2) / (2 * ba * bc)
    # 处理浮点数精度问题,确保cos_theta在[-1, 1]范围内
    cos_theta = max(min(cos_theta, 1.0), -1.0)
    angle = math.acos(cos_theta)
    return angle

def calculate_triangle_angles(p1, p2, p3):
    """
    计算三角形三个顶点的角度
    :param p1: 点1的坐标 (x, y)
    :param p2: 点2的坐标 (x, y)
    :param p3: 点3的坐标 (x, y)
    :return: 三个角度(弧度制),按p1, p2, p3的顺序
    """
    angle1 = calculate_angle(p2, p1, p3)  # 角1在p1
    angle2 = calculate_angle(p1, p2, p3)  # 角2在p2
    angle3 = calculate_angle(p1, p3, p2)  # 角3在p3
    return angle1, angle2, angle3

# 示例使用
if __name__ == "__main__":
    # 三个点的坐标(示例)
    point_a = (0, 0)
    point_b = (1, 0)
    point_c = (0, 1)
    
    # 计算角度
    angle_a, angle_b, angle_c = calculate_triangle_angles(point_a, point_b, point_c)
    
    # 转换为角度制
    angle_a_deg = math.degrees(angle_a)
    angle_b_deg = math.degrees(angle_b)
    angle_c_deg = math.degrees(angle_c)
    
    print(f"角A: {angle_a_deg:.2f}°")
    print(f"角B: {angle_b_deg:.2f}°")
    print(f"角C: {angle_c_deg:.2f}°")

代码说明:

calculate_angle函数:计算顶点 b 的角度。通过计算三边长度,应用余弦定理得到角度(弧度制)。

calculate_triangle_angles函数:分别计算三个顶点的角度。

math.degrees 可以把弧度转为角度

示例:计算直角三角形的三个角度(45°, 90°, 45°)。

上面的例子用的笛卡尔坐标系,也适用于图像坐标系(原点在左上角)

相关推荐
A7bert7771 分钟前
【YOLOv8pose部署至RDK X5】模型训练→转换bin→Sunrise 5部署
c++·python·深度学习·yolo·目标检测
生成论实验室14 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
We་ct42 分钟前
深度剖析浏览器跨域问题
开发语言·前端·浏览器·跨域·cors·同源·浏览器跨域
风筝在晴天搁浅43 分钟前
字节高频题 小于n的最大数
算法
LabVIEW开发1 小时前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星1 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
skywalk81631 小时前
在考虑双轨制,即在中文语法的基础上,加上数学公式的支持,这样像很多计算将更加简单方便,就像现在的小学数学课本里面一样,比如:定x=2*x + 1
开发语言
风筝在晴天搁浅1 小时前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
小书房1 小时前
Kotlin的by
android·开发语言·kotlin·委托·by
gqk011 小时前
【无标题】
python