Pytorch中四维Tensor转图片并保存(维度顺序调整)

最近在复现一篇论文代码的过程中,想要输出中间图片的结果图,通过debug发现在pytorch网络中是用Tensor存储的四维张量。

在这里插入图片描述

 

1、维度顺序转换

第一维代表的是batch_size,然后是通道数和图像尺寸,首先要进行维度顺序的转换
通过permute函数实现

outputRs = outputR.permute(0,2,3,1)

shape转为96 * 128 * 3

在这里插入图片描述

2、转为numpy数组

		#由于代码中的中间结果是带有梯度的要进行detach()操作
		k = outputRs.cpu().detach().numpy()

 

3、根据第一维度batch_size逐个读取中间结果,并存储到磁盘中

Image需导入from PIL import Image

		for i in range(10):
			res = k[i] #得到batch中其中一步的图片
			image = Image.fromarray(np.uint8(res)).convert('RGB')
			#image.show()
			#通过时间命名存储结果
			timestamp = datetime.datetime.now().strftime("%M-%S")
			savepath = timestamp + '_r.jpg'
			image.save(savepath)

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch,可以通过reshape函数将四维张量变成三维张量。reshape函数是一个用于改变张量形状的函数,它可以在不改变元素数量的情况下,重新排列张量的维度。 具体来说,我们可以通过指定目标形状来将四维张量变为三维张量。例如,假设我们有一个形状为[N, C, H, W]的四维张量,其N表示样本数量,C表示通道数,H表示高度,W表示宽度。 如果我们想要将这个四维张量变成一个形状为[N, H, W]的三维张量,我们可以使用reshape函数如下: ```python import torch # 假设四维张量名为four_dim_tensor three_dim_tensor = four_dim_tensor.reshape(N, H, W) ``` 在这个例子,reshape函数通过指定新的维度大小N、H和W,以此来将四维张量变成了三维张量。 需要注意的是,对于能够提前确定的维度大小,我们可以在函数调用直接指定其值;但对于未知维度大小,我们可以用-1表示,PyTorch会根据其它维度的大小自动计算出该维度的大小。例如,如果我们想将形状为[N, C, H, W]的四维张量变成一个形状为[N, H*W*C]的二维张量,可以使用如下代码: ```python two_dim_tensor = four_dim_tensor.reshape(N, -1) ``` 这里我们将第二个维度的大小指定为-1,PyTorch会根据样本数量、通道数以及高度和宽度的乘积自动计算出这个维度的大小。 通过使用reshape函数,我们可以方便地在PyTorch四维张量变成三维张量,实现对张量形状的灵活调整

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值