当前位置: 首页 > news >正文

PyTorch 中 Tensor 交换维度(transpose、permute、view)详解

请添加图片描述

在深度学习中,数据的形状(shape)非常重要。
例如,卷积层、全连接层、RNN 都要求输入张量的维度排列符合特定格式。

很多时候,我们需要对张量的维度(dimension)进行 交换、调整或重新排列
PyTorch 提供了多种方式实现这一点,比如:

  • tensor.t()
  • tensor.transpose()
  • tensor.permute()
  • tensor.view() / tensor.reshape()

本文将系统讲解这些操作的原理、区别与常见用法。


文章目录

    • 一、什么是“交换维度”?
    • 二、基础准备
    • 三、方法一:`tensor.t()` —— 仅限二维矩阵转置
    • 四、方法二:`tensor.transpose(dim0, dim1)` —— 交换两个指定维度
    • 五、方法三:`tensor.permute(dims)` —— 任意维度重排
    • 六、方法四:`tensor.view()` 与 `tensor.reshape()` —— 改变形状(非严格意义上的交换)


一、什么是“交换维度”?

在 PyTorch 中,张量(Tensor)是一个多维数组。
“交换维度”指的是改变这些维度(axes)的顺序或位置。

比如一个形状为

[batch, channel, height, width] = [32, 3, 224, 224]

的图像张量,如果模型要求输入为 [batch, height, width, channel]
我们就需要进行维度交换。


二、基础准备

让我们先创建一个简单的 3 维张量来演示:

import torchx = torch.randn(2, 3, 4)  # shape: [2, 3, 4]
print(x.shape)

输出:

torch.Size([2, 3, 4])

表示一个形状为 (2, 3, 4) 的三维张量。


三、方法一:tensor.t() —— 仅限二维矩阵转置

如果你的张量是 二维矩阵(2D Tensor),可以使用 t()

x = torch.randn(2, 3)
print(x.shape)     # torch.Size([2, 3])
print(x.t().shape) # torch.Size([3, 2])

📌 注意:

t() 只能用于二维张量(矩阵),否则会报错。


四、方法二:tensor.transpose(dim0, dim1) —— 交换两个指定维度

transpose /trænˈspoʊz/ 中文翻译为"调换"

transpose() 用于交换两个指定的维度,不改变其他维度的顺序。

示例:

x = torch.randn(2, 3, 4)     # shape: [2, 3, 4]
y = x.transpose(1, 2)        # 交换第1维和第2维
print(y.shape)

输出:

torch.Size([2, 4, 3])

也就是说:

原: [batch, channel, length]
新: [batch, length, channel]

⚠️ 注意:

transpose()不会拷贝数据,而是返回一个新的视图(view),节省内存。

有关拷贝的问题,可参考深入理解 Python 的 copy() 函数:浅拷贝与深拷贝详解_python .copy()函数-CSDN博客


五、方法三:tensor.permute(dims) —— 任意维度重排

permute /pərˈmjʊt/ 中文翻译为"重新排列"

permute() 是更通用的维度交换方式。
它允许你指定所有维度的新顺序

✅ 示例:

x = torch.randn(2, 3, 4)
y = x.permute(1, 0, 2)
print(y.shape)

输出:

torch.Size([3, 2, 4])

📘 解释:

  • 原始顺序是 [0, 1, 2]
  • 新顺序 [1, 0, 2] 表示:
    • 第 0 维 → 原第 1 维
    • 第 1 维 → 原第 0 维
    • 第 2 维 → 保持不变

transpose() vs permute()

特性transpose()permute()
功能交换两个维度任意排列多个维度
参数两个整数维度索引维度索引序列
返回新视图新视图
使用场景常用于2维或3维简单交换用于复杂维度调整

举例:

# transpose 只能交换两个维度
x.transpose(0, 1)# permute 可以任意排列
x.permute(2, 0, 1)

六、方法四:tensor.view()tensor.reshape() —— 改变形状(非严格意义上的交换)

view()reshape() 是用于改变张量形状(Shape)的操作,
并不直接交换维度,但在实际中常与 permute() 连用。

✅ 示例:

x = torch.randn(2, 3, 4)
y = x.permute(0, 2, 1).contiguous().view(2, -1)
print(y.shape)

输出:

torch.Size([2, 12])

📘 解释:

  • 先用 permute() 调整维度顺序;
  • 再用 view() 拉平成一个新的形状。

⚠️ 注意:

  • permute() 后的张量在内存中可能不是连续存储的;
  • 因此通常需要 .contiguous() 之后再调用 view()

http://www.dtcms.com/a/536029.html

相关文章:

  • WebGL低端设备优化全攻略
  • 网站顶部素材校园文创产品设计
  • 无界微前端学习和使用
  • FPGA DDR3实战(十一):基于DDR3的高速故障录播系统(三)—— 地址管理与故障定位机制
  • 自定义协议、序列化与守护进程:构建可靠后端服务
  • 【FPGA】时序逻辑计数器——Verilog实现
  • 示范专业网站建设wordpress 添加二级
  • 【LeetCode】88. 合并两个有序数组
  • Redis键过期策略深度剖析:惰性删除与定期删除的完美平衡
  • 【紧急救援】MySQL root密码忘记?一键重置脚本和全平台解决方案
  • Redis Commander:一款基于Web、免费开源的Redis管理工具
  • 云南省住房和城乡建设局网站做投标的在什么网站找信息
  • 操作系统5.3.4 磁盘的管理
  • Go 编程基础
  • 【Go】P13 Go 语言核心概念:指针 (Pointer) 详解
  • oss中的文件替换后chrome依旧下载到缓存文件概述
  • Go Web 编程快速入门 08 - JSON API:编码、解码与内容协商
  • Golang交叉编译到Android上运行
  • 学网站开发去哪学最好的公文写作网站
  • F035 vue+neo4j中医南药药膳知识图谱可视化系统 | vue+flask
  • 图形数据库Neo4J简介
  • QR算法:矩阵特征值计算的基石
  • 宁波网站建设公司代理珠海集团网站建设报价
  • 「用Python来学微积分」17. 导数与导函数
  • RAID技术:RAID 0/1/5/10 原理、配置与故障恢复
  • 7.1-性能与测试工具
  • linux磁盘使用流程
  • KVM虚拟化部署全流程指南
  • 【用homebrew配置nginx+配置前端项目与后端联调】Macbook M1(附一些homebrew操作)
  • 建立个人博客网站wordpress免费发布信息大全