python 矩阵乘法 跳过nan_张量流:矩阵乘法和加法中的nan

我使用的是一个函数(ndegree_poly),它可以得到一个张量和一个权重数组,并从中计算出多项式的结果。在

代码看起来很直接,但是当度数增加,或者函数被多次重复时,得到的张量包含一堆nan和inf。INF是合理的。但是,如果数字变得非常小,它们不应该变成零而不是nan吗?在import tensorflow as tf

function_degree = 10

def ndegree_poly(x, a, degree=6):

op = tf.add_n([tf.multiply(tf.pow(x, i), a[i]) for i in range(1, degree)])

return tf.add(op, a[0])

with tf.Session() as sess:

poly_weight = tf.Variable(tf.random_normal([function_freedom, 1, 5]))

mat = tf.Variable(tf.random_normal([2, 5]))

result0 = ndegree_poly(mat, poly_weight, function_degree)

result1 = ndegree_poly(result0, poly_weight, function_degree)

result2 = ndegree_poly(result1, poly_weight, function_degree)

result3 = ndegree_poly(result2, poly_weight, function_degree)

result4 = ndegree_poly(result3, poly_weight, function_degree)

sess.run(tf.global_variables_initializer())

print(sess.run(result4))

它打印:

^{pr2}$

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
张量乘法和矩阵乘法在某些方面是相似的,但也有一些关键的区别。首先,张量乘法和矩阵乘法都是将张量和矩阵相乘的操作。然而,在执行乘法运算时,它们的结果不同。 在矩阵乘法,我们使用标准的矩阵乘法规则,即将矩阵的行与另一个矩阵的列进行对应相乘,并将结果相加。这种乘法规则只适用于二维矩阵。例如,对于一个2x2的矩阵A和一个2x1的矩阵B,矩阵乘法的结果将是一个2x1的矩阵C。 与此不同,张量乘法是一种更通用的乘法形式,可以适用于任意维度的张量。在张量乘法,我们将张量的元素与另一个张量的元素进行逐个相乘,并将结果相加。这种乘法规则可以用于处理高维数据。例如,对于一个2x2的矩阵A和一个2x1x3的张量B,张量乘法的结果将是一个2x1x3的张量。 此外,不同的模式(mode)可以导致张量乘法的结果不同。在张量乘法,我们可以根据不同的维度对张量进行矩阵化,然后进行乘法运算。这种方式可以在处理多维数据时提供更大的灵活性。然而,需要注意的是,不同的模式会导致不同的乘法结果。 综上所述,张量乘法和矩阵乘法在使用的乘法规则、适用范围和结果方面存在一些区别。张量乘法是一种更通用的乘法形式,适用于任意维度的张量,而矩阵乘法仅适用于二维矩阵。此外,不同的模式也会导致张量乘法的结果不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值