torch.mean
官方文档: pytorch
pytorch的
torch.mean函数有两种用法: 一种是不带任何参数的,他返回的是tensor中所有元素的均值;第二种是带参数的,他返回某一维度的均值,这里分别介绍
第一种
torch.mean(input)
Returns the mean value of all elements in the input tensor.
返回所有元素的均值
1 | a = torch.rand(2,2) |
第二种
torch.mean(input, dim, keepdim=False, *, out=None)
返回对应维度元素的均值
- input: 需要求均值的tensor
- dim: 求均值的维度,参考normalize,第几维度,就是求那一维度的均值,例如tensor维度为(3,4,5),dim=1,那么就是求第一维度,每一组有四个元素的均值
- keepdim: 是否保持以前的维度数量,而不是大小
下面举两个例子
1 | a = torch.rand((2,3,4)) |
这个例子可以看出,dim=1计算的是3那一维的最大值,可以看出0.5543=mean(0.9809, 0.5214, 0.1607),此时维度从(2,3,4)变为了(2,4)
然后我们通过下面这个例子看一下keepdim的作用
1 | c = torch.max(a, dim=1, keepdim=True) |
c的维度变为了(2,1,4),发现最后c的维度还是三维,不过求mean的那一维度从3变成了1