transforms的resize和CenterCrop

我最近疑惑為什么使用transforms.resize(image_size)后跟著transforms.CenterCrop(image_size), 代碼實現(xiàn)看下
1.新建文件夾 image_folder 放張圖片進(jìn)去
2.定義DataSet

class Cudata(Dataset):

    def __init__(self):
        super(Cudata, self).__init__()
        self.data_dir = r'./image_folder/'
        self.datalist = os.listdir(self.data_dir)
        self.cu_transform = transforms.Compose([
            transforms.ToTensor(),
            transforms.Resize(120),
            transforms.CenterCrop(120),
        ])

    def __getitem__(self, index):
        id = self.datalist[index]
        img_path = os.path.join(self.data_dir, id)
        img = Image.open(img_path)
        img = self.cu_transform(img)
        return img

    def __len__(self):
        return len(self.datalist)

3.調(diào)用

cu_data = Cudata()
for idx, x in enumerate(cu_data):
    print(x.shape)
    save_image(x, './image_folder/out_{}.jpeg'.format(idx))

圖片原圖大小是

torch.Size([3, 1104, 736])

執(zhí)行 transforms.Resize(120)后圖片大小為

torch.Size([3, 180, 120]) 

執(zhí)行transforms.CenterCrop(120)后圖片大小為

torch.Size([3, 120, 120])

所以執(zhí)行代碼后會得到一個不怎么會拉伸變形又包含大部分圖像信息的正方形圖片

 transforms.Compose([
            transforms.ToTensor(),
            transforms.Resize(120),
            transforms.CenterCrop(120),
        ])
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容