python - numpy - 许多矩阵乘以许多向量

python - numpy - many matrices multiplying many vectors

我有一组矩阵,每个矩阵对应一个向量。我想巧妙地将每个矩阵与其向量相乘。我知道我可以将所有矩阵放在一个大块对角线形式中,然后将其乘以一个大的组合向量。

我想知道是否有一种方法可以使用 numpy.dot 以有效的方式将它们全部相乘。

我已经尝试使用 numpy.stacknumpy.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.]])