查找两条直线的交点位置

直接贴代码,摘自问题

import numpy as np

def perp(a):
    b = np.empty_like(a)
    b[0] = -a[1]
    b[1] = a[0]
    return b

# line segment a given by endpoints a1, a2
# line segment b given by endpoints b1, b2
# return


def seg_intersect(a1, a2, b1, b2):
    '''
    查找交点位置两条直线
    '''
    da = a2 - a1
    db = b2 - b1
    dp = a1 - b1
    dap = perp(da)
    denom = np.dot(dap, db)
    num = np.dot(dap, dp)
    return (num / denom.astype(float)) * db + b1

def main():


    p1 = np.array([2.0, 2.0])
    p2 = np.array([4.0, 3.0])

    p3 = np.array([6.0, 0.0])
    p4 = np.array([6.0, 3.0])

    print(seg_intersect(p1, p2, p3, p4))

main()
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 177,264评论 25 709
  • 之前一直想写,但因为考试周,复习的晕头转向的就放弃了,毕竟不挂科最重要,哈哈,结束考试之后还是决定要写一写自己的大...
    纆菡阅读 3,188评论 12 9
  • 一月份,参加完研究生初试后,虽然整个人如释重负,但每天早上六点多的时候就已经清醒,思绪活跃,想骑车穿过北区的军威苑...
    林苏景云阅读 1,580评论 0 0

友情链接更多精彩内容