0

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

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

我尝试使用numpy.stackand 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 个[0,0]向量是对角线上的 3 个向量。我怎样才能得到它们?

4

2 回答 2

1

你快到了。您需要在第 1 维和第 3 维上添加对角线索引,如下所示:

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]])
于 2018-06-12T13:28:15.063 回答
1

我发现的另一种方法是使用numpy.diagonal

np.diagonal(np.dot(R_stack, p_stack)[:,:,:,0], axis1=0, axis2=2)

在每一列中给出一个向量:

array([[0., 0., 0.],
   [0., 0., 0.]])
于 2018-06-12T13:42:05.733 回答