我有一组许多矩阵,每个矩阵对应一个向量。我想巧妙地将每个矩阵乘以其向量。我知道我可以将所有矩阵放在一个大块对角线形式中,然后将它乘以一个大的组合向量。
我想知道是否有一种方法可以有效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 个向量。我怎样才能得到它们?