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实现E-Mail收集插件实例教程

    Python实现E-Mail收集插件实例教程

    这篇文章主要给大家介绍了关于Python实现E-Mail收集插件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧
    2019-02-02
  • Python读写二进制文件的实现

    Python读写二进制文件的实现

    本文主要介绍了Python读写二进制文件的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Python利用Selenium实现弹出框的处理

    Python利用Selenium实现弹出框的处理

    经常出现在网页上的基于JavaScript实现的弹出框有三种,分别是 alert、confirm、prompt 。本文主要是学习如何利用selenium处理这三种弹出框,感兴趣的可以了解一下
    2022-06-06
  • python实现监控windows服务并自动启动服务示例

    python实现监控windows服务并自动启动服务示例

    这篇文章主要介绍了python实现监控windows服务并自动启动服务示例,需要的朋友可以参考下
    2014-04-04
  • Python.append()与Python.expand()用法详解

    Python.append()与Python.expand()用法详解

    今天小编就为大家分享一篇Python.append()与Python.expand()用法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • 基于Python实现人脸自动戴口罩系统

    基于Python实现人脸自动戴口罩系统

    2019年新型冠状病毒感染的肺炎疫情发生以来,牵动人心,举国哀痛,口罩、酒精、消毒液奇货可居。这篇文章主要介绍了基于Python的人脸自动戴口罩系统,需要的朋友可以参考下
    2020-02-02
  • 举例讲解Python中的算数运算符的用法

    举例讲解Python中的算数运算符的用法

    这篇文章主要介绍了举例讲解Python中的算数运算符的用法,是Python学习当中的基础知识,需要的朋友可以参考下
    2015-05-05
  • python中利用Future对象异步返回结果示例代码

    python中利用Future对象异步返回结果示例代码

    future是一种对象,表示异步执行的操作。下面这篇文章主要给大家介绍了关于python中利用Future对象异步返回结果的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-09-09
  • 一文详细NumPy中np.zeros的使用

    一文详细NumPy中np.zeros的使用

    np.zeros是NumPy库中一个非常实用的函数,用于快速创建指定形状和大小的全零数组,本文主要介绍了NumPy中np.zeros的使用,感兴趣的可以了解一下
    2024-03-03
  • python django model联合主键的例子

    python django model联合主键的例子

    今天小编就为大家分享一篇python django model联合主键的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08

最新评论