Numpy:列表中所有向量的点积

问题描述

假设我有一个包含 800 个向量的列表,每个向量由 1440 个标量组成。

List = [(1,2,3,...,1440),(1,...]

如何使用 python 和 numpy 以最快的方式计算每个向量与其他向量的点积?

解决方法

如果您想要对称矩阵,其中 x_ija_ia_j 的点积,则:

a = np.array(List)
x = a @ a.T
,

您可以使用 np.triu_indicesnp.tril_indices 来避免计算矩阵的后半部分。这不会影响计算的复杂度,但可以为足够数量的长向量节省一些时间:

a = np.array(x)
n = a.shape[0]
r,c = np.triu_indices(n)
result = np.empty((n,n))
result[r,c] = result[c,r] = np.sum(a[r] * a[c],axis=1)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...