numpy.dot docstring说:
对于2-D阵列,它相当于矩阵乘法,对于1-D阵列相当于向量的内积(没有复共轭)。对于N维,它是a的最后一个轴上的和积,而b
的倒数第二个
但是它并没有说明numpy.dot如何用2-D数组计算1-D数组。那么Numpy如何使用2-D数组(矩阵)处理1-D数组(向量)?
我做了一些测试:
In [27]: a
Out[27]:
array([[0, 1, 2],
[3, 4, 5],
[6, 7, 8]])
In [28]: b
Out[28]: array([0, 1, 2])
In [29]: np.dot(a,b)
Out[29]: array([ 5, 14, 23])
In [30]: np.dot(a, b.reshape(-1,1))
Out[30]:
array([[ 5],
[14],
[23]])
In [31]: np.dot(a, b.reshape(-1,1)).ravel() # same as np.dot(a,b)
Out[31]: array([ 5, 14, 23])
In [32]: np.dot(b,a)
Out[32]: array([15, 18, 21])
In [33]: np.dot(b.reshape(1,-1), a)
Out[33]: array([[15, 18, 21]])
In [34]: np.dot(b.reshape(1,-1), a).ravel() # same as np.dot(b,a)
Out[34]: array([15, 18, 21])
上述测试表明numpy.dot可以处理具有二维数组的一维数组。这样对吗?
答案 0 :(得分:5)
只有一个案例未在文档中明确描述,但有点暗示,即如何应用于2D和1D输入规则:
它是a的最后一个轴上的和积,倒数第二个 B'/ P>
在您的情况下,当您执行np.dot(a, b)
时,b
没有“倒数第二”的轴。那么numpy是什么,是为了最后解决。因此,它会将a
与b
的每一行的总和产生,正如您的测试所示。
您的所有其他示例都符合上述规则。
答案 1 :(得分:4)
1-d阵列和2-d阵列作为矩阵矢量(或矢量矩阵)产品处理。实际上,实现使用BLAS *gemv
函数来处理浮点输入的这种情况。