python中求两个向量的夹角方式

 更新时间:2023年06月14日 16:03:46   作者:sugar椰子皮  
这篇文章主要介绍了python中求两个向量的夹角方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

python求两个向量的夹角

import numpy as np
x=np.array([3,5])
y=np.array([4,2])
# 两个向量
Lx=np.sqrt(x.dot(x))
Ly=np.sqrt(y.dot(y))
#相当于勾股定理,求得斜线的长度
cos_angle=x.dot(y)/(Lx*Ly)
#求得cos_sita的值再反过来计算,绝对长度乘以cos角度为矢量长度,初中知识。。
print(cos_angle)
angle=np.arccos(cos_angle)
angle2=angle*360/2/np.pi
#变为角度
print(angle2)
#x.dot(y) =  y=∑(ai*bi)

矩阵相乘的算法

>> a=[1,2,3;4,5,6;7,8,9];
>> b=[6,6,6;6,6,6;6,6,6];
>> dot(a,
ans =
    72    90   108
1*6+4*6+7*6=72
#三个相加
#dot 是矩阵相乘
#print(np.dot(x,x))
#34
# a=np.linalg.norm(x-y)
# print(a)
costheta=x.dot(y)/(np.linalg.norm(x)*np.linalg.norm(y))
#范数
# #[-1  3]
# a=np.square(x-y)
# #[1,9]
# print(np.sum(a))
# #10
# print(np.sqrt(10))

NumPy.array求点乘,向量长度,向量夹角的方法

求点乘方法有

  • 1. np.sum(a*b)
  • 2. (a*b).sum()
  • 3. np.dot(a, b)
  • 4. a.dot(b)
  • 5. b.dot(a)

求向量长度方法有

  • 1. np.sqrt((a*a).sum()) 
  • 2. np.linalg.norm(a)

求两个向量夹角

根据点乘定义,cosangle = a.dot(b)/(np.linalg.norm(a) * np.linalg.norm(b))  

In [25]: a = np.array([1,2])                                                    
In [26]: b = np.array([2, 1])                                                   
In [27]: dot = 0                                                                
In [28]: for e, f in zip(a, b): 
    ...:     dot += e*f 
    ...:                                                                        
In [29]: dot                                                                    
Out[29]: 4
In [30]: a*b                                                                    
Out[30]: array([2, 2])
In [31]: np.sum(a*b)                                                            
Out[31]: 4
In [32]: (a*b).sum()                                                            
Out[32]: 4
In [33]: np.dot(a,b)                                                            
Out[33]: 4
In [34]: a.dot(b)                                                               
Out[34]: 4
In [35]: b.dot(a)                                                               
Out[35]: 4
In [36]: amag = np.sqrt((a*a).sum())                                            
In [37]: amag                                                                   
Out[37]: 2.23606797749979
In [38]: amag = np.linalg.norm(a)                                               
In [39]: amag                                                                   
Out[39]: 2.23606797749979
In [40]: cosangle = a.dot(b)/(np.linalg.norm(a) * np.linalg.norm(b))            
In [41]: cosangle                                                               
Out[41]: 0.7999999999999998
In [42]: angle = np.arccos(cosangle)                                            
In [43]: angle                                                                  
Out[43]: 0.6435011087932847

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python Selenium库的基本使用教程

    Python Selenium库的基本使用教程

    这篇文章主要给大家介绍了关于Python Selenium库的基本使用教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Python hashlib模块详细讲解使用方法

    Python hashlib模块详细讲解使用方法

    hashlib 是一个提供了一些流行的hash算法的 Python 标准库.其中所包括的算法有 md5, sha1, sha224, sha256, sha384, sha512. 另外,模块中所定义的 new(name, string=”) 方法可通过指定系统所支持的hash算法来构造相应的hash对象
    2022-11-11
  • Python代码块及缓存机制原理详解

    Python代码块及缓存机制原理详解

    这篇文章主要介绍了Python代码块及缓存机制原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • Python爬虫之批量下载喜马拉雅音频

    Python爬虫之批量下载喜马拉雅音频

    今天教大家如何利用Python爬虫批量下载喜马拉雅音频,文中有非常详细的代码示例,对正在学习python的小伙伴们很有帮助,需要的朋友可以参考下
    2021-05-05
  • 如何用python批量调整视频声音

    如何用python批量调整视频声音

    这篇文章主要介绍了如何用python批量调整视频声音,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-12-12
  • pyqt串口通信的项目实践

    pyqt串口通信的项目实践

    串口通信工业控制上面常用的,本文主要介绍了pyqt串口通信的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • 利用Pandas读取某列某行数据之loc和iloc用法总结

    利用Pandas读取某列某行数据之loc和iloc用法总结

    loc是location的意思,和iloc中i的意思是指integer,所以它只接受整数作为参数,下面这篇文章主要给大家介绍了关于利用Pandas读取某列某行数据之loc和iloc用法的相关资料,需要的朋友可以参考下
    2022-03-03
  • python迷宫问题深度优先遍历实例

    python迷宫问题深度优先遍历实例

    这篇文章主要给大家介绍了关于python迷宫问题深度优先遍历的相关资料,深度优先搜索算法(Depth-First-Search),是搜索算法的一种,需要的朋友可以参考下
    2021-06-06
  • Python 内置函数sorted()的用法

    Python 内置函数sorted()的用法

    这篇文章主要介绍了Python 内置函数sorted()的用法,文章内容介绍详细具有一的参考价值,需要的小伙伴可以参考一下,希望对你的学习有所帮助
    2022-03-03
  • Python中的字典合并与列表合并技巧

    Python中的字典合并与列表合并技巧

    这篇文章主要介绍了Python中的字典合并与列表合并技巧,下文围绕主题展开详细的内容介绍,具有一的的参考价值,需要的小伙伴可以参考一下
    2022-05-05

最新评论