如何对2D数组和另一个向量之间的操作进行向量化? - python

我有一个像这样的numpy 2D数组:

[[1, 2], [3, 4]]

还有一个像这样的单独向量:
[5, 6]

在这种情况下,操作是np.inner,这是我在2D数组的每一行和单独的向量之间进行余弦相似度的一项较大任务的一部分。

我的预期输出是[np.inner([1, 2], [5, 6]), np.inner([3, 4], [5, 6]]。我可以使用apply_along_axis完成此操作,但是有什么方法可以向量化此操作并使它比apply_along_axis更具性能吗?

关于如何在两个2D数组的成对行之间对这些类型的操作进行矢量处理,有很多已回答的问题,但是在这种情况下,我需要对一个2D数组与另一个矢量之间的操作进行矢量化。我可以将[5, 6]转换为[[5, 6], [5, 6]],然后进行矢量化处理,但是在大规模情况下,我需要一个解决方案,在该操作中,我可以在操作中使用其他矢量本身,而不是将其转换为带有一排行的2D数组副本。

参考方案

听起来您需要`np.dot'

In [3]: a = np.array([[1, 2], [3, 4]])

In [4]: b = np.array([5, 6])

In [5]: a.dot(b)
Out[5]: array([17, 39])

In [6]: np.inner(a[0], b)
Out[6]: 17

In [7]: np.inner(a[1], b)
Out[7]: 39

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

python:ConfigParser对象,然后再阅读一次 - python

场景:我有一个配置文件,其中包含要执行的自动化测试的列表。这些测试是长期循环执行的。   配置文件的设计方式使ConfigParser可以读取它。由于有两个三个参数,因此我需要通过每个测试。现在,此配置文件由script(s1)调用,并且按照配置文件中的列表执行测试。Script(s1)第一次读取配置,并且在每次测试完成后都会执行。阅读两次的要求:由于可能会…

Python exchangelib在子文件夹中读取邮件 - python

我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…

Python Pickle调用构造函数 - python

我想使用Python的pickle序列化器提供缺少值的默认值。由于类很简单,因此默认值自然存在于类的__init__方法中。我从pickle documentation看到有__getnewargs__。但是,这仅适用于在“酸洗”之前存在__getnewargs__的情况。有什么方法可以让python pickle始终调用构造函数,而不是从未初始化的对象开始…