torch中维度操作总结(repeat,squeeze,unsqueeze,flatten,transpose)

文章目录

repeat 函数

1.repeat参数个数与tensor向量维数一致

bash 复制代码
a = torch.tensor([[1, 2, 3],
                  [1, 2, 3]])
b = a.repeat(2, 2)
print(b.shape)

结果为:

c 复制代码
torch.Size([4,6])

即repeat的参数是对应维度的复制个数,上段代码为0维复制两次,1维复制两次,则得到以上运行结果。其余扩展情况依此类推。

2.repeat参数个数与tensor向量维数不一致

在参数个数大于原tensor维度个数时,总是先在第0维扩展一个维数为1的维度,然后按照参数指定的复制次数进行复制。计算输出的形状时,可以按照 对应参数*对应维度维数 得到结果

bash 复制代码
# a形状(2,3)
a = torch.tensor([[1, 2, 3],
                  [1, 2, 3]])
# repeat参数比维度多
# 首先在第0维扩展一个维度,维数为1,然后按照参数指定的次数进行复制
# 在扩展前先将a的形状扩展为(1,2,3)然后复制
b = a.repeat(1, 2, 1)
print(b.shape)  # 得到结果torch.Size([1, 4, 3])
bash 复制代码
# a形状(2,3)
a = torch.tensor([[1, 2, 3],
                  [1, 2, 3]])
# repeat参数比维度多,在扩展前先将a的形状扩展为(1,2,3)然后复制
b = a.repeat(1, 1, 2)
print(b.shape)  # 得到结果torch.Size([1, 2, 6])
bash 复制代码
# a形状(2,3)
a = torch.tensor([[1, 2, 3],
                  [1, 2, 3]])
# repeat参数比维度多,在扩展前先将a的形状扩展为(1,2,3)然后复制
b = a.repeat(2, 1, 1)
print(b.shape)  # 得到结果torch.Size([2, 2, 3])

squeeze 函数

bash 复制代码
torch.squeeze(A,N)

torch.unsqueeze()函数:减少数组A指定位置N的维度。

如果不指定位置参数N,如果数组A的维度为(1,1,3)。

如果指定位置参数,执行 torch.squeeze(A,1) ,A的维度变为 (1,3),中间的维度被删除。

注:

  1. 如果指定的维度大于1,那么将操作无效
  2. 如果不指定维度N,那么将删除所有维度为1的维度
bash 复制代码
a=torch.randn(1,1,3)
print(a.shape) # torch.Size([1, 1, 3])
b=torch.squeeze(a)
print(b.shape)	# torch.Size([3])
c=torch.squeeze(a,0)
print(c.shape)  # torch.Size([1, 3])
d=torch.squeeze(a,1)
print(d.shape)	# torch.Size([1, 3])
e=torch.squeeze(a,2)#如果去掉第三维,则数不够放了,所以直接保留
print(e.shape)	# torch.Size([1, 1, 3])

unsqueeze 函数

bash 复制代码
torch.unsqueeze(A,N)

torch.unsqueeze()函数:增加数组A指定位置N的维度。

两行三列的数组A维度为(2,3),那么这个数组就有三个位置可以增加维度,分别是

bash 复制代码
([位置0], 2,[位置1], 3, [位置2]) 
或者
( [位置-3] ,2,[位置-2], 3 ,[位置-1] )

如果执行 torch.unsqueeze(A,1),数据的维度就变为了 (2,1,3)

bash 复制代码
a=torch.randn(1,3)
print(a.shape)	# torch.Size([1, 3])
b=torch.unsqueeze(a,0)
print(b.shape)	# torch.Size([1, 1, 3])
c=torch.unsqueeze(a,1)
print(c.shape)	# torch.Size([1, 1, 3])
d=torch.unsqueeze(a,2)
print(d.shape)	# torch.Size([1, 3, 1])

flatten 函数

flatten() 是对多维数据的降维函数。

flatten(),默认缺省参数为0,也就是说flatten()和flatte(0)效果一样。

python里的flatten(dim)表示,从第dim个维度开始展开,将后面的维度转化为一维.也就是说,只保留dim之前的维度,其他维度的数据全都挤在dim这一维。

bash 复制代码
import torch
a = torch.rand(2,3,4)
print(a.shape) # torch.Size([2, 3, 4])
b = a.flatten()
print(b.shape)  # torch.Size([24])
c = a.flatten(0)
print(c.shape)  # torch.Size([24])
d = a.flatten(1)
print(d.shape)  # torch.Size([2, 12])
e = a.flatten(2)
print(e.shape)	 # torch.Size([2, 3, 4])

transpose函数

二维数组

python 复制代码
import numpy as np
X=np.arange(6).reshape((2,3))
print(X)
#[[0 1 2]
# [3 4 5]]

print(X.transpose())
#[[0 3]
# [1 4]
# [2 5]]

print(X.T)
#[[0 3]
# [1 4]
# [2 5]]

多维数组

python 复制代码
x=np.arange(24).reshape((2,3,4))
print(x.shape)
y = x.transpose((0,1,2))
print(y.shape)
y = x.transpose((0,2,1))
print(y.shape)
y = x.transpose((2,1,0))
print(y.shape)

#(2, 3, 4)
#(2, 3, 4)
#(2, 4, 3)
#(4, 3, 2)

参考网址

https://blog.csdn.net/tequila53/article/details/119183678

https://blog.csdn.net/kuan__/article/details/116987162

说明

说明如下,如有侵权,十分抱歉,可联系本人删除对应内容。

会根据平时使用不断更新博客内容。

相关推荐
Bruce_Liuxiaowei13 分钟前
基于Flask的勒索病毒应急响应平台架构设计与实践
后端·python·flask
Channing Lewis21 分钟前
python headq包介绍
python
Freak嵌入式28 分钟前
一文速通 Python 并行计算:06 Python 多线程编程-基于队列进行通信
开发语言·python·多线程·面向对象·并行计算
_一条咸鱼_44 分钟前
深入剖析 AI 大模型的 Embeddings 原理
人工智能·深度学习·机器学习
Elendill1 小时前
【算法笔记】并查集详解
笔记·python·算法
databook1 小时前
当决策树遇上脏数据:连续值与缺失值的解决方案
python·机器学习·scikit-learn
狗蛋不是狗1 小时前
Python 实现的运筹优化系统数学建模详解(最大最小化模型)
python·数学建模·优化算法·狗蛋不是狗·最大最小化模型
小白—人工智能1 小时前
数据可视化 —— 折线图应用(大全)
python·信息可视化·数据可视化
hvinsion1 小时前
从PPT到PNG:Python实现的高效PPT转图工具
python·powerpoint·ppt转图片
Aerkui2 小时前
Python面向对象-开闭原则(OCP)
开发语言·python·开闭原则