python根据点计算直线方程

# 根据已知两点坐标,求过这两点的直线解析方程: a*x+b*y+c = 0  (a >= 0)
def getLinearEquation(p1x, p1y, p2x, p2y):
    sign = 1
    a = p2y - p1y
    if a < 0:
        sign = -1
        a = sign * a
    b = sign * (p1x - p2x)
    c = sign * (p1y * p2x - p1x * p2y)
    return [a, b, c]


# 根据直线的起点与终点计算出平行距离D的平行线的方程
def getLinearEquation(p1x, p1y, p2x, p2y, distance):
    """
    :param p1x: 起点X
    :param p1y: 起点Y
    :param p2x: 终点X
    :param p2y: 终点Y
    :param distance: 平距
    :param left_right: 向左还是向右
    """
    e = getLinearEquation(p1x, p1y, p2x, p2y)
    f = distance * math.sqrt(e.a * e.a + e.b * e.b)
    m1 = e.c + f
    m2 = e.c - f
    # result = 值1 if 条件 else 值2
    c2 = m1 if p2y - p1y < 0 else m2
    return [e.a, e.b, c2]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值