我有两个由3D向量(numpy 1D数组)组成的矩阵,我需要逐行计算向量之间的角度,并将结果返回到一个1D数组中。我知道如何计算两个1D向量之间的角度。请问应该如何正确实现?
*** 计算结果的单位是度而不是弧度。
目前我已经有以下代码:
*** 计算结果的单位是度而不是弧度。
目前我已经有以下代码:
import numpy as np
A = np.array([[1,0,0],
[0,1,0],
[0,0,1]])
B = np.array([[1,0,1],
[1,1,0],
[0,1,0]])
def angle(V1,V2):
"""
angle between vectors V1 and V2 in degrees using
angle = arccos ( V1 dot V2 / norm(V1) * norm(V2) ) *180/np.pi
"""
cos_of_angle = V1.dot(V2) / (np.linalg.norm(V1) * np.linalg.norm(V2))
return np.arccos(np.clip(cos_of_angle,-1,1)) * 180/np.pi
注意缩放项180/np.pi用于将弧度转换为角度。
我希望有一个数组:
C = [ angle(A[0],B[0]) , angle(A[1],B[1])...... and so on]
如果有人能帮忙,将不胜感激。