Pytorch--tensor.view()

在 PyTorch 中,tensor.view() 是一个常用的方法,用于改变张量(Tensor)的形状(shape),但不会改变其数据本身。它类似于 NumPy 的 reshape(),但有一些关键区别。


1. 基本用法

import torchx = torch.arange(1, 10)  # shape: [9]
print(x)
# tensor([1, 2, 3, 4, 5, 6, 7, 8, 9])# 改变形状为 (3, 3)
y = x.view(3, 3)  
print(y)
# tensor([[1, 2, 3],
#         [4, 5, 6],
#         [7, 8, 9]])

关键点

  • 不改变数据,只是重新排列维度。
  • 新形状的元素数量必须与原张量一致,否则会报错:
    x.view(2, 5)  # ❌ 错误!因为 2×5=10,但 x 只有 9 个元素
    

2. 自动推断维度(-1 的作用)

如果不想手动计算某个维度的大小,可以用 -1,PyTorch 会自动计算:

x = torch.arange(1, 10)  # shape: [9]# 自动计算行数,确保列数是 3
y = x.view(-1, 3)  # shape: [3, 3]
print(y)
# tensor([[1, 2, 3],
#         [4, 5, 6],
#         [7, 8, 9]])# 自动计算列数,确保行数是 3
z = x.view(3, -1)  # shape: [3, 3]
print(z)
# 输出同上

3. view() vs reshape()

方法是否共享内存是否适用于非连续存储适用场景
view()✅ 共享内存(修改会影响原张量)❌ 仅适用于连续存储的张量高效改变形状(推荐优先使用)
reshape()✅ 可能共享内存(如果可能)✅ 适用于非连续存储更通用,但可能额外复制数据

示例对比

x = torch.arange(1, 10)  # 连续存储# view() 可以正常工作
y = x.view(3, 3)  # 如果张量不连续(如转置后),view() 会报错
x_transposed = x.t()  # 转置后存储不连续
# z = x_transposed.view(9)  # ❌ RuntimeError: view size is not compatible with input tensor's size and stride# reshape() 可以处理非连续存储
z = x_transposed.reshape(9)  # ✅

4. 常见用途

(1) 展平张量(Flatten)

x = torch.randn(4, 5)  # shape: [4, 5]
flattened = x.view(-1)  # shape: [20]

(2) 调整 CNN 特征图维度

# 假设 CNN 输出是 [batch_size, channels, height, width]
features = torch.randn(32, 64, 7, 7)  # shape: [32, 64, 7, 7]# 展平成 [batch_size, channels * height * width] 用于全连接层
flattened = features.view(32, -1)  # shape: [32, 64*7*7] = [32, 3136]

(3) 交换维度(类似 permute

x = torch.randn(2, 3, 4)  # shape: [2, 3, 4]
y = x.view(2, 4, 3)  # shape: [2, 4, 3](相当于交换最后两维)

5. 注意事项

  1. view() 只适用于连续存储的张量,否则会报错,此时应该用 reshape() 或先 .contiguous()
    x_non_contiguous = x.t()  # 转置后不连续
    x_contiguous = x_non_contiguous.contiguous()  # 变成连续存储
    y = x_contiguous.view(...)  # 现在可以用 view()
    
  2. view() 返回的新张量与原张量共享内存,修改其中一个会影响另一个:
    x = torch.arange(1, 10)
    y = x.view(3, 3)
    y[0, 0] = 100  # 修改 y 会影响 x
    print(x)  # tensor([100, 2, 3, 4, 5, 6, 7, 8, 9])
    

总结

操作推荐方法
改变形状(连续张量)view()
改变形状(非连续张量)reshape().contiguous().view()
展平张量x.view(-1)torch.flatten(x)
调整 CNN 特征图维度features.view(batch_size, -1)

view() 是 PyTorch 中高效调整张量形状的首选方法,但要注意内存共享和连续性限制! 🚀
展平(Flatten)或改变形状(如 viewreshape)的核心原则是保持张量的总元素个数(numel())不变,只是重新排列这些元素的维度。


1. 元素总数不变原则

无论原始张量是几维的(1D、2D、3D 或更高维),转换后的新形状必须满足:
原形状的元素总数 = 新形状的元素总数 \text{原形状的元素总数} = \text{新形状的元素总数} 原形状的元素总数=新形状的元素总数
即:
元素总数需满足:
dim 1 × dim 2 × ⋯ × dim n = new_dim 1 × new_dim 2 × ⋯ × new_dim m \text{dim}_1 \times \text{dim}_2 \times \dots \times \text{dim}_n = \text{new\_dim}_1 \times \text{new\_dim}_2 \times \dots \times \text{new\_dim}_m dim1×dim2××dimn=new_dim1×new_dim2××new_dimm

示例:
import torchx = torch.arange(24)  # 1D 张量,24 个元素
print(x.numel())      # 输出:24# 转换为 2D 张量:4 行 × 6 列(4×6=24)
y = x.view(4, 6)      # 形状 [4, 6]# 转换为 3D 张量:2×3×4(2×3×4=24)
z = x.view(2, 3, 4)   # 形状 [2, 3, 4]

2. 自动推断维度(-1 的作用)

在指定新形状时,可以用 -1 代表“自动计算该维度大小”,PyTorch 会根据总元素数和其他已知维度推导出 -1 的值。
规则:
推断的维度 = 总元素数 已知维度的乘积 \text{推断的维度} = \frac{\text{总元素数}}{\text{已知维度的乘积}} 推断的维度=已知维度的乘积总元素数

示例:
x = torch.arange(24)  # 24 个元素# 自动计算行数,确保列数为 6
y = x.view(-1, 6)     # 形状 [4, 6](因为 24/6=4)# 自动计算列数,确保行数为 3
z = x.view(3, -1)     # 形状 [3, 8](因为 24/3=8)
错误示例:

如果维度乘积不匹配总元素数,会报错:

x.view(5, -1)  # ❌ 报错!24 无法被 5 整除

3. 展平(Flatten)的本质

展平是将任意维度的张量转换为一维或二维的形式:

  • 一维展平x.view(-1)x.flatten()
    将所有元素排成一行,形状变为 [num_elements]
  • 二维展平(保留批处理维度)x.view(batch_size, -1)nn.Flatten()
    保持 batch_size 不变,其余维度合并为第二维,形状变为 [batch_size, features]
示例:
x = torch.randn(2, 3, 4)  # 形状 [2, 3, 4],总元素数=24# 一维展平
flatten_1d = x.view(-1)    # 形状 [24]# 二维展平(保留第0维 batch_size=2)
flatten_2d = x.view(2, -1) # 形状 [2, 12](因为 3×4=12)

4. 为什么需要手动指定部分维度?

  • 全连接层的输入要求
    通常需要二维张量 [batch_size, features],因此需明确保留 batch_size,其余维度展平。
  • 避免歧义
    例如,若张量形状为 [32, 64, 7, 7],想展平成 [32, 3136],需明确第二维是 3136(即 64×7×7),而 -1 让 PyTorch 自动计算。
代码对比:
# 明确指定第二维
flatten_explicit = x.view(32, 64*7*7)  # 形状 [32, 3136]# 用 -1 自动计算
flatten_auto = x.view(32, -1)          # 形状 [32, 3136](推荐)

5. 关键总结

  1. 元素总数不变:形状变换的本质是重新排列数据,不增删元素。
  2. -1 的作用:自动计算该维度大小,确保总元素数匹配。
  3. 展平的应用场景
    • 全连接层前必须将多维特征转换为一维向量(如 CNN 的 [batch, C, H, W][batch, C*H*W])。
    • 数据预处理时调整输入形状(如图像展平为向量)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/76269.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机器学习】——机器学习思考总结

摘要 这篇文章深入探讨了机器学习中的数据相关问题,重点分析了神经网络(DNN)的学习机制,包括层级特征提取、非线性激活函数、反向传播和梯度下降等关键机制。同时,文章还讨论了数据集大小的标准、机器学习训练数据量的…

CoAP Shell 笔记

CoAP Shell 笔记 1. 概述 CoAP (Constrained Application Protocol) 是一种专为物联网 (IoT) 中资源受限的节点和网络设计的 RESTful Web 传输协议。CoAP Shell 是一个基于命令行的交互式工具,用于与支持 CoAP 的服务器进行交互。 2. 主要功能 协议支持&#xff…

【最新】探索CFD的未来:从OpenFOAM到深度学习,全面解析计算流体力学的顶级资源与前沿技术

计算流体力学(CFD)作为现代工程与科学研究的核心工具,正以前所未有的速度迈向智能化与多物理场耦合的新时代。本文全面梳理了在线学习CFD的顶级资源,涵盖了从传统数值模拟到深度学习驱动的物理信息模型的广泛领域,旨在为研究者、工程师和学生提供一站式参考指南。内容分为…

[leetcode]2492. 两个城市间路径的最小分数(并查集 排序后建边)

题目链接 题意 给定一个 n n n个点 m m m条边的无向图 每条边有边权 求1-n的路径中最小的边权是多少 每条路可以重复走 思路 把边按边权降序排序 用并查集维护连通性 遍历每条边 每次合并边的起点和终点 如果1和n联通 并且这条边在1和n的这个连通块中 就对ans取min Code…

Windows中IDEA2024.1的安装和使用

如果你也喜欢,记得一键三连啊 一、卸载 二、安装 三、注册 1、打开Crack文件,直接双击 “安装.bat”,否则可能安装会出错!! 2、选择【Activation code】(不要关闭该界面继续后面的步骤)。 …

【C#】构造协议帧通过串口下发

构造一个“协议帧”&#xff0c;打包串口/网络通信帧头部结构的核心部分 &#x1f527; 代码&#xff1a; List<byte> frame new List<byte>();// 1. 固定帧头 frame.AddRange(BitConverter.GetBytes(0x0130)); // 帧头 (4B) frame.AddRange(BitConverter…

04_SQL概述及DDL

文章目录 一、关于SQL1.1、SQL概述1.2、SQL分类 二、数据库操作2.1、查看数据库2.2、切换数据库2.3、查询当前使用的数据库2.4、创建数据库2.5、查看数据库创建信息2.6、修改数据库2.7、删除数据库 三、表的操作3.1、数据类型3.1.1、数值类型3.1.2、字符串类型3.1.3、日期时间类…

HCIA-数据通信datacom认证

文章目录 一、数据通信简介1.1 标准协议1.2 数据传输过程 二、通用路由平台VRP2.1 VRP简介2.2 命令行基础 三 、网络层协议IP3.1 数据封装3.2 数据包传输2.3 IP地址2.4 子网划分2.5 ICMP 四、IP路由基础4.1 路由概述4.2 路由表4.3 路由转发4.4 静态路由4.5 动态路由4.6 路由高级…

fast_pow(),c语言幂函数

double fast_pow(double a, int n) { double res 1.0; while (n > 0) { if (n & 1) res * a; // 如果当前位是1&#xff0c;累乘 a * a; // 平方 n >> 1; // 右移一位&#xff08;相当于 n / 2&…

OpenBMC:BmcWeb 处理http请求2 查找路由对象

OpenBMC:BmcWeb 处理http请求1 生成Request和AsyncResp对象_bmc web-CSDN博客 当接收到http请求,并且完成解析后,调用了App::handle处理请求 而App::handle又调用了router.handle(req, asyncResp);来处理请求 1.Router::handle void handle(const std::shared_ptr<Requ…

[Mac]利用hexo-theme-fluid美化个人博客

接上文,使用Fluid美化个人博客 文章目录 一、安装hexo-theme-fluid安装依赖指定主题创建「关于页」效果展示 二、修改个性化配置1. 修改网站设置2.修改文章路径显示3.体验分类和标签4.左上角博客名称修改5.修改背景图片6.修改关于界面 欢迎大家参观 一、安装hexo-theme-fluid 参…

深入理解二叉树、B树与B+树:原理、应用与实现

文章目录 引言一、二叉树&#xff1a;基础而强大的结构基本概念特性分析Java实现应用场景 二、B树&#xff1a;适合外存的多路平衡树基本概念关键特性查询流程示例Java简化实现典型应用 三、B树&#xff1a;数据库索引的首选核心改进优势分析范围查询示例Java简化实现实际应用 …

8.4考研408简单选择排序与堆排序知识点深度解析

考研408「简单选择排序与堆排序」知识点全解析 一、简单选择排序 1.1 定义与核心思想 简单选择排序(Selection Sort)是一种选择排序算法,其核心思想是: 每趟选择:从待排序序列中选择最小(或最大)的元素,与当前位置的元素交换。逐步构建有序序列:经过 n − 1 n-1

为什么需要开源成分分析?库博同源分析工具介绍

在当今的软件开发世界中&#xff0c;开源组件已经成为不可或缺的一部分。无论是加速开发进程&#xff0c;还是降低开发成本&#xff0c;开源组件都为我们带来了巨大的便利。然而&#xff0c;随着开源组件的广泛使用&#xff0c;安全风险也随之而来。你是否曾担心过&#xff0c;…

ros2 humble无法识别头文件<rclcpp/rclcpp.hpp>

首先在C/C配置中设置路径&#xff1a; 可以编辑文件.vscode/c_cpp_properties.json ${workspaceFolder}/**/opt/ros/humble/include/**编译配置 确保配置好了CMakeLists.txt文件。 colcon build --cmake-args -DCMAKE_EXPORT_COMPILE_COMMANDSON这样会在目录下生成compile_com…

常用的排序算法及对比

1. 选择排序&#xff08;Selection Sort&#xff09; 算法思想与理论推导 基本思想&#xff1a; 每次从待排序数组中选择最小&#xff08;或最大&#xff09;的元素&#xff0c;将它与当前序列的起始位置交换&#xff0c;逐步将整个数组排序。 推导过程&#xff1a; 设数组长…

Linux基础入门:从零开始掌握Linux命令行操作

&#x1f64b;大家好&#xff01;我是毛毛张! &#x1f308;个人首页&#xff1a; 神马都会亿点点的毛毛张 &#x1f388;有没有觉得电影里的黑客&#x1f412;酷毙了&#xff1f;他们只用键盘⌨就能搞定一切。今天&#xff0c;毛毛张要带你们体验这种快感&#x1f600;&…

OpenAI发布的《Addendum to GPT-4o System Card: Native image generation》文件的详尽笔记

Native_Image_Generation_System_Card 文件基本信息 文件名称&#xff1a;《Addendum to GPT-4o System Card: Native image generation》发布机构&#xff1a;OpenAI发布日期&#xff1a;2025年3月25日主要内容&#xff1a;介绍GPT-4o模型中新增的原生图像生成功能&#xff…

5.02 WPF的 Combox、ListBox,slider、ProgressBar使用

1. 关于Combox\ListBox使用&#xff1a; 1.1 内容绑定有两种方法&#xff0c; 优先使用方法1&#xff0c;因为列表变化的时候&#xff0c;Combox会自动显示新的内容。而方法2并不会实时更新。 方法1&#xff1a;使用DataContext this.comboBox1.DisplayMemberPath "na…

《孟婆汤的SHA-256加密》

点击下面图片带您领略全新的嵌入式学习路线 &#x1f525;爆款热榜 88万阅读 1.6万收藏 文章目录 **第一章&#xff1a;黄泉路上的数据风暴****第二章&#xff1a;碱基对的非对称加密****第三章&#xff1a;RAFT协议暴动事件****第四章&#xff1a;灵魂分叉与硬重放****终章&…