Примечание : все остальные ответы здесь потерпят неудачу, если два вектора имеют одинаковое направление (например, (1, 0, 0)
, (1, 0, 0)
) или противоположные направления (например, (-1, 0, 0)
, (1, 0, 0)
).
Вот функция, которая будет правильно обрабатывать эти случаи:
import numpy as np
def unit_vector(vector):
""" Returns the unit vector of the vector. """
return vector / np.linalg.norm(vector)
def angle_between(v1, v2):
""" Returns the angle in radians between vectors 'v1' and 'v2'::
>>> angle_between((1, 0, 0), (0, 1, 0))
1.5707963267948966
>>> angle_between((1, 0, 0), (1, 0, 0))
0.0
>>> angle_between((1, 0, 0), (-1, 0, 0))
3.141592653589793
"""
v1_u = unit_vector(v1)
v2_u = unit_vector(v2)
return np.arccos(np.clip(np.dot(v1_u, v2_u), -1.0, 1.0))