python - numpy - 许多矩阵乘以许多向量
python - numpy - many matrices multiplying many vectors
我有一组矩阵,每个矩阵对应一个向量。我想巧妙地将每个矩阵与其向量相乘。我知道我可以将所有矩阵放在一个大块对角线形式中,然后将其乘以一个大的组合向量。
我想知道是否有一种方法可以使用 numpy.dot
以有效的方式将它们全部相乘。
我已经尝试使用 numpy.stack
和 numpy.dot
,但我不能只得到想要的向量。
更具体一点。我的矩阵看起来像:
R_stack = np.stack((R, R2, R3))
即
array([[[-0.60653066, 1.64872127],
[ 0.60653066, -1.64872127]],
[[-0.36787944, 2.71828183],
[ 0.36787944, -2.71828183]],
[[-0.22313016, 4.48168907],
[ 0.22313016, -4.48168907]]])
我的矢量看起来像:
p_stack = np.stack((p0, p0_2, p0_3))
这是
array([[[0.73105858],
[0.26894142]],
[[0.88079708],
[0.11920292]],
[[0.95257413],
[0.04742587]]])
我想乘以下数:R*p0, R2*p0_2, R3*p0_3
.
当我执行 dot
时:
np.dot(R_stack, p_stack)[:,:,:,0]
我明白了
array([[[ 0. , -0.33769804, -0.49957337],
[ 0. , 0.33769804, 0.49957337]],
[[ 0.46211716, 0. , -0.22151555],
[-0.46211716, 0. , 0.22151555]],
[[ 1.04219061, 0.33769804, 0. ],
[-1.04219061, -0.33769804, 0. ]]])
我感兴趣的 3 个向量是对角线上的 3 个 [0,0]
向量。我怎样才能得到它们?
你快到了。您需要在第一个和第三个维度上添加对角线索引,如下所示:
np.dot(R_stack, p_stack)[np.arange(3),:,np.arange(3),0]
结果中的每一行都对应于您想要的向量之一:
array([[-3.48805945e-09, 3.48805945e-09],
[-5.02509157e-09, 5.02509157e-09],
[-1.48245199e-08, 1.48245199e-08]])
我发现的另一种方法是使用 numpy.diagonal
np.diagonal(np.dot(R_stack, p_stack)[:,:,:,0], axis1=0, axis2=2)
它在每列中给出一个向量:
array([[0., 0., 0.],
[0., 0., 0.]])
我有一组矩阵,每个矩阵对应一个向量。我想巧妙地将每个矩阵与其向量相乘。我知道我可以将所有矩阵放在一个大块对角线形式中,然后将其乘以一个大的组合向量。
我想知道是否有一种方法可以使用 numpy.dot
以有效的方式将它们全部相乘。
我已经尝试使用 numpy.stack
和 numpy.dot
,但我不能只得到想要的向量。
更具体一点。我的矩阵看起来像:
R_stack = np.stack((R, R2, R3))
即
array([[[-0.60653066, 1.64872127],
[ 0.60653066, -1.64872127]],
[[-0.36787944, 2.71828183],
[ 0.36787944, -2.71828183]],
[[-0.22313016, 4.48168907],
[ 0.22313016, -4.48168907]]])
我的矢量看起来像:
p_stack = np.stack((p0, p0_2, p0_3))
这是
array([[[0.73105858],
[0.26894142]],
[[0.88079708],
[0.11920292]],
[[0.95257413],
[0.04742587]]])
我想乘以下数:R*p0, R2*p0_2, R3*p0_3
.
当我执行 dot
时:
np.dot(R_stack, p_stack)[:,:,:,0]
我明白了
array([[[ 0. , -0.33769804, -0.49957337],
[ 0. , 0.33769804, 0.49957337]],
[[ 0.46211716, 0. , -0.22151555],
[-0.46211716, 0. , 0.22151555]],
[[ 1.04219061, 0.33769804, 0. ],
[-1.04219061, -0.33769804, 0. ]]])
我感兴趣的 3 个向量是对角线上的 3 个 [0,0]
向量。我怎样才能得到它们?
你快到了。您需要在第一个和第三个维度上添加对角线索引,如下所示:
np.dot(R_stack, p_stack)[np.arange(3),:,np.arange(3),0]
结果中的每一行都对应于您想要的向量之一:
array([[-3.48805945e-09, 3.48805945e-09],
[-5.02509157e-09, 5.02509157e-09],
[-1.48245199e-08, 1.48245199e-08]])
我发现的另一种方法是使用 numpy.diagonal
np.diagonal(np.dot(R_stack, p_stack)[:,:,:,0], axis1=0, axis2=2)
它在每列中给出一个向量:
array([[0., 0., 0.],
[0., 0., 0.]])