问题

torch.flatten()与nn.Flatten()都可以实现展开Tensor,那么二者的区别是什么呢?

方法

经过查阅相关资料,发现二者主要区别有:
(1) 默认的dim不同,torch.flatten()默认的dim=0,而nn.Flatten()默认的dim=1,例如输入数据的尺寸是[3,1,4,4],经过torch.flatten()展开后的尺寸变为[48],而经过nn.Flatten()后得到的结果是[3, 16];
(2) nn.Flatten是一个类,而torch.flatten()则是一个函数。

相关实验代码如下所示:

import torch
from torch import nn

'''torch.flatten与nn.Flatten的区别
- torch.flatten()的dim默认是从0维开始;
- nn.Flatten()的dim默认是从1维开始;
'''

if __name__ == '__main__':
x = torch.rand(3, 1, 4, 4)

m = nn.Flatten()
out1 = m(x)
print(f'nn.Flatten(x) size is: {out1.size()}')

out2 = torch.flatten(x)
print(f'torch.flatten(x) size is: {out2.size()}')

结语

本文主要介绍了nn.Flatten()与torch.flatten()二者的区别,深入理解二者细微的区别方能更好的应用。