tf.reduce_sum()函数[转]

本文详细解析了TensorFlow中的reduce_sum函数,包括其参数、使用方法及示例。reduce_sum用于对张量的指定维度进行求和,可选择是否保持维度。文章通过实例展示了如何在不同场景下应用此函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文:https://blog.youkuaiyun.com/georgeai/article/details/81030811 

reduce_sum(
    input_tensor,
    axis=None,
    keep_dims=False,
    name=None,
    reduction_indices=None
)

reduce_sum 是 tensor 内部求和的工具。其参数中:

  1. input_tensor 是要求和的 tensor
  2. axis 是要求和的 rank,如果为 none,则表示所有 rank 都要求和
  3. keep_dims 求和后是否要降维
  4. 这个操作的名称,可能在 graph 中 用,已被淘汰的,被参数 axis 替代
x = tf.constant([[1, 1, 1], [1, 1, 1]])
tf.reduce_sum(x, 0)  # 对 tensor 的 0 级进行求和,[1,1,1] + [1,1,1] =  [2, 2, 2]
tf.reduce_sum(x, 1)  # 对 tensor 的 1 级进行仇和,[1+1+1, 1+1+1] = [3, 3]
tf.reduce_sum(x, 1, keep_dims=True)  # 对第 1 级进行求和,但不降维, [[3], [3]]
tf.reduce_sum(x, [0, 1])  # 0 级和 1级都要求和,6
tf.reduce_sum(x)  # 因为 x 只有 2 级,所以结果同上一个,6

上面是TensorFlow官方文档中的函数解释。

其实在reduce_sum()中,是从维度上去考虑的(感觉这个Matlab中数据的概念比较像)
è¿éåå¾çæè¿°

调用reduce_sum(arg1, arg2)时

  • 参数arg1即为要求和的数据,arg2有两个取值分别为0和1
  • 通常用reduction_indices=[0]或reduction_indices=[1]来传递参数。

从上图可以看出,

  • 当arg2 = 0时,是纵向对矩阵求和,原来矩阵有几列就得到几个值;
  • 当arg2 = 1时,是横向对矩阵求和; 
  • 省略arg2参数时,默认对矩阵所有元素进行求和

函数名的前缀为什么是reduce_其实也就很容易理解了

reduce就是“对矩阵降维”的含义下划线后面的部分就是降维的方式在reduce_sum()中就是按照求和的方式对矩阵降维。

那么其他reduce前缀的函数也举一反三了,比如reduce_mean()就是按照某个维度求平均值,等等。
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值