iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >如何在Pytorch中对tensor进行扩充
  • 482
分享到

如何在Pytorch中对tensor进行扩充

2023-06-06 19:06:35 482人浏览 安东尼
摘要

今天就跟大家聊聊有关如何在PyTorch中对tensor进行扩充,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。b = torch.zeros((3, 2

今天就跟大家聊聊有关如何在PyTorch中对tensor进行扩充,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

b = torch.zeros((3, 2, 6, 6))a = torch.zeros((3, 2, 1, 1))a.expand_as(b).size()Out[32]: torch.Size([3, 2, 6, 6])a = torch.zeros((3, 2, 2, 1))a.expand_as(b).size()Traceback (most recent call last): File "/home/lart/.conda/envs/pt/lib/python3.6/site-packages/Ipython/core/interactiveshell.py", line 3267, in run_code  exec(code_obj, self.user_global_ns, self.user_ns) File "<iPython-input-34-972575f79e92>", line 1, in <module>  a.expand_as(b).size()RuntimeError: The expanded size of the tensor (6) must match the existing size (2) at non-singleton dimension 2. Target sizes: [3, 2, 6, 6]. Tensor sizes: [3, 2, 2, 1]a = torch.zeros((3, 2, 1, 2))a.expand_as(b).size()Traceback (most recent call last): File "/home/lart/.conda/envs/pt/lib/python3.6/site-packages/IPython/core/interactiveshell.py", line 3267, in run_code  exec(code_obj, self.user_global_ns, self.user_ns) File "<ipython-input-36-972575f79e92>", line 1, in <module>  a.expand_as(b).size()RuntimeError: The expanded size of the tensor (6) must match the existing size (2) at non-singleton dimension 3. Target sizes: [3, 2, 6, 6]. Tensor sizes: [3, 2, 1, 2]a = torch.zeros((3, 2, 2, 2))a.expand_as(b).size()Traceback (most recent call last): File "/home/lart/.conda/envs/pt/lib/python3.6/site-packages/IPython/core/interactiveshell.py", line 3267, in run_code  exec(code_obj, self.user_global_ns, self.user_ns) File "<ipython-input-38-972575f79e92>", line 1, in <module>  a.expand_as(b).size()RuntimeError: The expanded size of the tensor (6) must match the existing size (2) at non-singleton dimension 3. Target sizes: [3, 2, 6, 6]. Tensor sizes: [3, 2, 2, 2]a = torch.zeros((3, 2, 6, 2))a.expand_as(b).size()Traceback (most recent call last): File "/home/lart/.conda/envs/pt/lib/python3.6/site-packages/IPython/core/interactiveshell.py", line 3267, in run_code  exec(code_obj, self.user_global_ns, self.user_ns) File "<ipython-input-40-972575f79e92>", line 1, in <module>  a.expand_as(b).size()RuntimeError: The expanded size of the tensor (6) must match the existing size (2) at non-singleton dimension 3. Target sizes: [3, 2, 6, 6]. Tensor sizes: [3, 2, 6, 2]a = torch.zeros((3, 2, 6, 1))a.expand_as(b).size()Out[44]: torch.Size([3, 2, 6, 6])a = torch.zeros((3, 2, 1, 6))a.expand_as(b).size()Out[46]: torch.Size([3, 2, 6, 6])

tensor.expand_as在这里用于扩展tensor到目标形状,常用的多是在H和W方向上的扩展。

假设目标形状为N, C, H, W,则要求tensor.size()=n, c, h, w(这里假设N,C不变):

h=w=1

h=1, w!=1

h!=1, w=1

补充:tensorflow 利用expand_dims和squeeze扩展和压缩tensor维度

在利用Tensorflow进行文本挖掘工作的时候,经常涉及到维度扩展和压缩工作。

比如对文本进行embedding操作完成之后,若要进行卷积操作,就需要对embedded的向量扩展维度,将[batch_size, embedding_dims]扩展成为[batch_size, embedding_dims, 1],利用tf.expand_dims(input, -1)就可实现,反过来用squeeze(input, -1)或者tf.squeeze(input)也可以把最第三维去掉。

tf.expand_dims()

tf.squeeze()

tf.expand_dims()

tf.expand_dims(input, axis=None, name=None, dim=None)

在第axis位置增加一个维度.

给定张量输入,此操作在输入形状的维度索引轴处插入1的尺寸。 尺寸索引轴从零开始; 如果您指定轴的负数,则从最后向后计数。

如果要将批量维度添加到单个元素,则此操作非常有用。 例如,如果您有一个单一的形状[height,width,channels],您可以使用expand_dims(image,0)使其成为1个图像,这将使形状[1,高度,宽度,通道]。

例子

# 't' is a tensor of shape [2]shape(expand_dims(t, 0)) ==> [1, 2]shape(expand_dims(t, 1)) ==> [2, 1]shape(expand_dims(t, -1)) ==> [2, 1]# 't2' is a tensor of shape [2, 3, 5]shape(expand_dims(t2, 0)) ==> [1, 2, 3, 5]shape(expand_dims(t2, 2)) ==> [2, 3, 1, 5]shape(expand_dims(t2, 3)) ==> [2, 3, 5, 1]

tf.squeeze()

tf.squeeze(input, axis=None, name=None, squeeze_dims=None)

直接上例子

# 't' is a tensor of shape [1, 2, 1, 3, 1, 1] shape(squeeze(t)) ==> [2, 3]# 't' is a tensor of shape [1, 2, 1, 3, 1, 1] shape(squeeze(t, [2, 4])) ==> [1, 2, 3, 1]

看完上述内容,你们对如何在Pytorch中对tensor进行扩充有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网精选频道,感谢大家的支持。

--结束END--

本文标题: 如何在Pytorch中对tensor进行扩充

本文链接: https://www.lsjlt.com/news/248255.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何在Pytorch中对tensor进行扩充
    今天就跟大家聊聊有关如何在Pytorch中对tensor进行扩充,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。b = torch.zeros((3, 2...
    99+
    2023-06-06
  • LVM中如何对xfs进行扩展
    本篇内容介绍了“LVM中如何对xfs进行扩展”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. LVM基本术语物理卷 (physical v...
    99+
    2023-06-28
  • 如何进行Python 音频的数据扩充
    今天就跟大家聊聊有关如何进行Python 音频的数据扩充,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。经典的深度学习网络AlexNet使用数据扩充(Data Augmentation...
    99+
    2023-06-02
  • pytorch中如何保存tensor数据
    在PyTorch中,可以使用torch.save()函数将Tensor数据保存到文件中。以下是保存和加载Tensor数据的示例代码:...
    99+
    2024-04-02
  • 如何在PyTorch中进行超参数搜索
    在PyTorch中进行超参数搜索通常有两种常用的方法: 使用Grid Search:通过定义一个超参数的候选值列表,对所有可能的组...
    99+
    2024-03-14
    PyTorch
  • 如何在PyTorch中进行模型的微调
    在PyTorch中进行模型微调的步骤如下: 加载预训练模型:首先,你需要加载一个预训练的模型。PyTorch提供了许多常见的预训练...
    99+
    2024-03-14
    PyTorch
  • 如何对Flume进行水平扩展
    Flume是一个可扩展的日志收集系统,可以通过增加更多的Flume agent或者启动更多的Flume节点来实现水平扩展。以下是一些...
    99+
    2024-03-08
    Flume
  • 如何在PyTorch中进行模型的可视化
    在PyTorch中进行模型的可视化通常使用第三方库如torchviz或tensorboard。以下是如何使用这两个库进行模型可视化的...
    99+
    2024-03-14
    PyTorch
  • 怎么在Pytorch 中对TORCH.NN.INIT 参数进行初始化
    怎么在Pytorch 中对TORCH.NN.INIT 参数进行初始化?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。初始化函数:torch.nn.init#&nb...
    99+
    2023-06-06
  • C#中如何进行UDP编程补充
    这期内容当中小编将会给大家带来有关C#中如何进行UDP编程补充,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。下面就直接介绍实现过程和代码以及运行的结果。一、程序实现UDP广播程序的实现代码:using&n...
    99+
    2023-06-17
  • 如何在PyTorch中进行模型的集成学习
    在PyTorch中进行模型的集成学习可以通过以下步骤实现: 定义多个不同的神经网络模型:首先,定义多个不同的神经网络模型,可以是不...
    99+
    2024-03-06
    PyTorch
  • C#如何对扩展进行分组管理
    本篇内容主要讲解“C#如何对扩展进行分组管理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#如何对扩展进行分组管理”吧!从系列文章开篇到现在,已经实现的很多扩展了,但过多的扩展会给我们带来很多...
    99+
    2023-06-17
  • PyTorch中如何进行模型蒸馏
    模型蒸馏(model distillation)是一种训练较小模型以近似较大模型的方法。在PyTorch中,可以通过以下步骤进行模型...
    99+
    2024-03-05
    PyTorch
  • 如何在java中对json进行处理
    这篇文章主要介绍了如何在java中对json进行处理,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,...
    99+
    2023-05-30
    java json
  • 如何在CLion中对openMP进行配置
    本篇文章为大家展示了如何在CLion中对openMP进行配置,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。使用MinGW64在Clion中配置openMP的开发 安装MinGW64和CLion配置C...
    99+
    2023-06-06
  • 如何在SpringBoot中对Swagger进行配置
    如何在SpringBoot中对Swagger进行配置?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。导入SpringBoot集成Swagger所需要的依赖 <...
    99+
    2023-06-06
  • 如何在IDEA中对Docker进行配置
    如何在IDEA中对Docker进行配置?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。配置docker远程连接端口vi /usr/lib/systemd/system/...
    99+
    2023-06-06
  • 在PyTorch中如何进行模型权重的正则化
    在PyTorch中,可以使用torch.nn.Module类中的parameters()方法来获取模型的权重参数,然后使用正则化方法...
    99+
    2024-03-05
    PyTorch
  • 如何对Graylog进行性能调优和扩展
    要对Graylog进行性能调优和扩展,可以考虑以下几个方面: 调整Graylog的配置:可以通过修改Graylog的配置文件来调...
    99+
    2024-04-02
  • 使用Tensorflow怎么对ckpt文件中的tensor进行读取
    本篇文章给大家分享的是有关使用Tensorflow怎么对ckpt文件中的tensor进行读取,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。在使用pre-train model时...
    99+
    2023-06-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作