查找兩條直線的交點位置

直接貼代碼,摘自問題

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()
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,036評論 25 709
  • 之前一直想寫,但因為考試周,復習的暈頭轉(zhuǎn)向的就放棄了,畢竟不掛科最重要,哈哈,結束考試之后還是決定要寫一寫自己的大...
    纆菡閱讀 472評論 12 9
  • 一月份,參加完研究生初試后,雖然整個人如釋重負,但每天早上六點多的時候就已經(jīng)清醒,思緒活躍,想騎車穿過北區(qū)的軍威苑...
    林蘇景云閱讀 248評論 0 0

友情鏈接更多精彩內(nèi)容