91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用pytorch怎么將圖片數據轉換成tensor

發布時間:2021-03-05 14:49:21 來源:億速云 閱讀:373 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關使用pytorch怎么將圖片數據轉換成tensor,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

一、數據轉換

把圖片轉成成torch的tensor數據,一般采用函數:torchvision.transforms。通過一個例子說明,先用opencv讀取一張圖片,然后在轉換;注意一點是:opencv儲存圖片的格式和torch的儲存方式不一樣,opencv儲存圖片格式是(H,W,C),而torch儲存的格式是(C,H,W)。

import torchvision.transforms as transforms
import cv2 as cv
img = cv.imread('image/000001.jpg')
print(img.shape)  # numpy數組格式為(H,W,C)
transf = transforms.ToTensor()
img_tensor = transf(img) # tensor數據格式是torch(C,H,W)
print(img_tensor.size())

使用pytorch怎么將圖片數據轉換成tensor

注意:使用torchvision.transforms時要注意一下,其子函數 ToTensor() 是沒有參數輸入的,以下用法是會報錯的

img_tensor = transforms.ToTensor(img)

必須是先定義和賦值轉換函數,再調用并輸入參數,正確用法:

img = cv.imread('image/000001.jpg')
transf = transforms.ToTensor()
img_tensor = transf(img)

再轉換過程中正則化

在使用 transforms.ToTensor() 進行圖片數據轉換過程中會對圖像的像素值進行正則化,即一般讀取的圖片像素值都是8 bit 的二進制,那么它的十進制的范圍為 [0, 255],而正則化會對每個像素值除以255,也就是把像素值正則化成 [0.0, 1.0]的范圍。通過例子理解一下:

import torchvision.transforms as transforms
import cv2 as cv
img = cv.imread('image/000001.jpg')
transf = transforms.ToTensor()
img_tensor = transf(img)
print('opencv', img)
print('torch', img_tensor)

使用pytorch怎么將圖片數據轉換成tensor

使用pytorch怎么將圖片數據轉換成tensor

三、自行修改正則化的范圍

使用transforms.Compose函數可以自行修改正則化的范圍,下面舉個例子正則化成 [-1.0, 1.0]

transf2 = transforms.Compose(
  [
    transforms.ToTensor(),
    transforms.Normalize(mean=(0.5, 0.5, 0.5), std=(0.5, 0.5, 0.5))
  ]
)
img_tensor2 = transf2(img)
print(img_tensor2)

使用pytorch怎么將圖片數據轉換成tensor

計算方式就是:

C=(C-mean)/ std

C為每個通道的所有像素值,彩色圖片為三通道圖像(BGR),所以mean和std是三個數的數組。

使用transforms.ToTensor()時已經正則化成 [0,0, 0,1]了,那么(0.0 - 0.5)/0.5=-1.0,(1.0 - 0.5)/0.5=1.0,所以正則化成 [-1.0, 1.0]

補充:Python: 記錄一個關于圖片直接轉化為pytorch.tensor和numpy.array的不同之處的問題

img = Image.open(img_path).convert("RGB")
img2 = torchvision.transforms.functional.to_tensor(img)
print(img2)
img1 = np.array(img)
print(img1)

輸出是這樣的:

使用pytorch怎么將圖片數據轉換成tensor

不僅shape不一樣,而且值也是不一樣的。

解釋如下:

tensor = torch.from_numpy(np.asarray(PIL.Image.open(path))).permute(2, 0, 1).float() / 255
tensor = torchvision.transforms.functional.to_tensor(PIL.Image.open(path)) # 兩種方法是一樣的

PIL.Image.open()得到HWC格式,直接使用numpy 去轉換得到(h,w,c)格式,而用to_tensor得到(c,h,w)格式且值已經除了255。

byte()相當于to(torch.uint8),tensor.numpy()是把tensor 轉化為numpy.array格式。

在這里需要注意的是PIL和OPENCV的圖像讀取得到的格式都是HWC格式,一般模型訓練使用的是CHW格式, H為Y軸是豎直方向,W為X軸水平方向。

且torchvision.transforms.functional.to_tensor()對所有輸入都是有變換操作。

上述就是小編為大家分享的使用pytorch怎么將圖片數據轉換成tensor了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

淮阳县| 宁蒗| 海原县| 延吉市| 南华县| 资兴市| 广州市| 肃北| 溧水县| 石河子市| 铜川市| 禹州市| 皮山县| 武平县| 长寿区| 布尔津县| 原阳县| 白银市| 商河县| 广东省| 滦南县| 威宁| 集安市| 固阳县| 兴和县| 和平区| 项城市| 永新县| 昌乐县| 泸定县| 中山市| 云霄县| 安宁市| 茌平县| 莆田市| 石家庄市| 苍溪县| 永年县| 上饶市| 福安市| 疏勒县|