我是Pytorch的新手。我想知道如何将大小为torch.Size([1, 3, 224, 224])
的张量转换为图像格式显示在Jupyter笔记本上。PIL格式或CV2格式就可以了。
我尝试使用transforms.ToPILImage(x)
,但得到了不同的格式:ToPILImage(mode=ToPILImage(mode=tensor([[[[1.3034e-16, 1.3034e-16, 1.3034e-16, ..., 1.4475e-16,.
也许我做错了什么,:no_mouth:
发布于 2020-04-23 02:40:02
由于您的图像是标准化的,因此您需要对其进行非标准化。您必须执行标准化过程中所做的反向操作。一种方法是
class UnNormalize(object):
def __init__(self, mean, std):
self.mean = mean
self.std = std
def __call__(self, tensor):
"""
Args:
tensor (Tensor): Tensor image of size (C, H, W) to be normalized.
Returns:
Tensor: Normalized image.
"""
for t, m, s in zip(tensor, self.mean, self.std):
t.mul_(s).add_(m)
# The normalize code -> t.sub_(m).div_(s)
return tensor
要使用它,您将需要平均值和标准差(用于归一化图像)。然后,
unorm = UnNormalize(mean = [0.35675976, 0.37380189, 0.3764753], std = [0.32064945, 0.32098866, 0.32325324])
image = unorm(normalized_image)
https://stackoverflow.com/questions/61368632
复制相似问题