python - 在 Tensorflow 中将一组常量(一维数组)与一组矩阵(三维数组)相乘

标签 python tensorflow matrix matrix-multiplication

我的最终目标是训练一个基于均值和协方差参数化的 4D 多元高斯分布

enter image description here

在哪里,

enter image description here

和,

enter image description here

目前我有以下代码:

import tensorflow as tf
import numpy as np

value = [[1,2.0,3,4,5],[0,2,4,6,8],[80,7,6,5,4]]

value=tf.constant(value)

cov= tf.slice(value,[0,int(value.shape[1])-1],[int(value.shape[0]),1])
mean= tf.slice(value,[0,0],[int(value.shape[0]),int(value.shape[1])-1])

eyes=tf.eye(int(mean.shape[1]),batch_shape=[int(value.shape[0])])


#eyes = tf.multiply(eyes,cov)



normal = tf.contrib.distributions.MultivariateNormalFullCovariance(
                 loc=mean,
                 covariance_matrix=eyes) 

value = [[1,2.0,3,4,5],[0,2,4,6,8],[80,7,6,5,4]] 是其余代码可能接收的示例。

在上面的例子中

cov = <tf.Tensor 'Slice_2:0' shape=(3, 1) dtype=float32>
eyes = <tf.Tensor 'eye_1/MatrixDiag:0' shape=(3, 4, 4) dtype=float32>

                     cov =  [[5.] [8.] [4.]]` 
                     eyes =  [[[1. 0. 0. 0.]
                              [0. 1. 0. 0.]
                              [0. 0. 1. 0.]
                              [0. 0. 0. 1.]]

                             [[1. 0. 0. 0.]
                              [0. 1. 0. 0.]
                              [0. 0. 1. 0.]
                              [0. 0. 0. 1.]]

                             [[1. 0. 0. 0.]
                              [0. 1. 0. 0.]
                              [0. 0. 1. 0.]
                              [0. 0. 0. 1.]]]`

我的问题是,如何在给定 coveyes 的情况下获得 result?结果如下:

result = [[[5., 0., 0., 0.],
           [0., 5., 0., 0.],
           [0., 0., 5., 0.],
           [0., 0., 0., 5.]],

          [[8., 0., 0., 0.],
           [0., 8., 0., 0.],
           [0., 0., 8., 0.],
           [0., 0., 0., 8.]],

          [[4., 0., 0., 0.],
           [0., 4., 0., 0.],
           [0., 0., 4., 0.],
           [0., 0., 0., 4.]]]

enter image description here

提前致谢

最佳答案

Tensorflow 使用与 numpy 相同类型的索引,这可能非常强大。

您可以在这里查看详细信息:https://docs.scipy.org/doc/numpy-1.13.0/user/basics.broadcasting.html请注意,np.newaxis 定义为与 None 相同。

对于您的问题,您可以为数据添加一个额外的维度,以确保数组相乘的方式没有歧义。

import numpy as np
cov = np.array([[5.],[8.],[4.]])
eyes = np.array([[[1.0,0,0,0],[0.0,1.0,0.0,0],[0.0,0.0,1.0,0],[0.0,0.0,0.0,1.0]],[[1.0,0,0,0],[0.0,1.0,0.0,0],[0.0,0.0,1.0,0],[0.0,0.0,0.0,1.0]],[[1.0,0,0,0],[0.0,1.0,0.0,0],[0.0,0.0,1.0,0],[0.0,0.0,0.0,1.0]]])
result = cov[:,:,None]*eyes

在这里使用 None 增加了一个额外的维度,使 cov 成为一个 3x1x1 数组,它可以明确地与 3x4x4 数组相乘。您也可以在 tensorflow 中以这种方式使用 None

如果每个对应的维度大小相同,或者其中一个维度的大小为 1,则两个数组可以明确相乘。

关于python - 在 Tensorflow 中将一组常量(一维数组)与一组矩阵(三维数组)相乘,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52087206/

相关文章:

python - OpenCV 在 Python 和 C++ 实现中对 HOG 对象检测的不同结果

python - 如何使用 golang 从重定向的 url 获取响应内容

python - 如果输入子项,则不应触发 PyGTK 离开通知事件

tensorflow - 如何从 tfrecords 目录创建 tf.data.dataset?

python - 为 Keras 逐个元素编写自定义损失函数

tensorflow - 在 keras 中连接和添加有什么区别?

R获得矩阵中每一行的最小值,并返回行名和列名

opengl - 如何计算相机的UP和位置?

arrays - 如何获取矩阵列中最后一个非零值的数组?

python: iif 或 (x ? a : b)