主頁(yè) > 知識(shí)庫(kù) > python 求兩個(gè)向量的順時(shí)針夾角操作

python 求兩個(gè)向量的順時(shí)針夾角操作

熱門(mén)標(biāo)簽:呼叫中心市場(chǎng)需求 企業(yè)做大做強(qiáng) 硅谷的囚徒呼叫中心 電話運(yùn)營(yíng)中心 百度AI接口 客戶服務(wù) Win7旗艦版 語(yǔ)音系統(tǒng)

以上述圖片舉例,要求 相對(duì) 的順時(shí)針夾角。注意:這里使用圖像坐標(biāo)系

1 定義求順時(shí)針角度的函數(shù)

import numpy as np
def clockwise_angle(v1, v2):
 x1,y1 = v1
 x2,y2 = v2
 dot = x1*x2+y1*y2
 det = x1*y2-y1*x2
 theta = np.arctan2(det, dot)
 theta = theta if theta>0 else 2*np.pi+theta
 return theta

2 求 , 然后求夾角

v1 = [2-0, 1-0] = [2,1]
v2 = [4-0, 5-0] = [4,5]
theta = clockwise_angle(v1,v2)
print(theta*180/np.pi) # 24.77

補(bǔ)充:求2個(gè)向量順逆時(shí)針(最小角度)旋轉(zhuǎn)角度 Python

求向量 a 旋轉(zhuǎn)到向量 b 的順時(shí)針(逆時(shí)針)最小角度。

正常求2個(gè)向量夾角用內(nèi)積公式就可以計(jì)算,然而求得的結(jié)果不包含方向信息。

如果需要方向信息的話需要引入向量的外積來(lái)幫助我們判斷。

theta是兩個(gè)向量的夾角,n是垂直與2維平面的方向向量,由右手定則可以判斷方向。

根據(jù)定義可以通過(guò)向量的坐標(biāo)計(jì)算外積

這里面由于u,v是二維平面上的向量, u3 v3 都為0。 所以 u叉乘v = (u1v2 - u2v1)*K。

所以等式兩邊的標(biāo)量相等可以求夾角rho。

rho 是帶正負(fù)號(hào)的和旋轉(zhuǎn)方向有關(guān),但是范圍在 -90 ~ 90度。

可以通過(guò)rho正負(fù)號(hào),結(jié)合向量的點(diǎn)乘重新計(jì)算帶方向的夾角。

這里面順時(shí)針旋轉(zhuǎn)為負(fù),逆時(shí)針旋轉(zhuǎn)為正。

def GetClockAngle(v1, v2):
 # 2個(gè)向量模的乘積
 TheNorm = np.linalg.norm(v1)*np.linalg.norm(v2)
 # 叉乘
 rho = np.rad2deg(np.arcsin(np.cross(v1, v2)/TheNorm))
 # 點(diǎn)乘
 theta = np.rad2deg(np.arccos(np.dot(v1,v2)/TheNorm))
 if rho  0:
  return - theta
 else:
  return theta
a = [0,1]
b = [1,0]
c = [-1,0]
d = [0, -1]
e = [-1, -1]
f = [1, -1]
g = [1, 1]
h = [-1, 1]
print(GetClockAngle(a,g), GetClockAngle(a,b), GetClockAngle(a,f), GetClockAngle(a,d), \

 GetClockAngle(a,e), GetClockAngle(a,c), GetClockAngle(a,h))
'''
結(jié)果
(-45.00000000000001, -90.0, -135.0, 180.0, 135.0, 90.0, 45.00000000000001)
'''

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Python 計(jì)算任意兩向量之間的夾角方法
  • Python 求向量的余弦值操作
  • 在python Numpy中求向量和矩陣的范數(shù)實(shí)例

標(biāo)簽:海南 長(zhǎng)沙 山西 山西 崇左 安康 濟(jì)南 喀什

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python 求兩個(gè)向量的順時(shí)針夾角操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266