真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用pytorch怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor-創(chuàng)新互聯(lián)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)使用pytorch怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)阜新免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了數(shù)千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

一、數(shù)據(jù)轉(zhuǎn)換

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

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

使用pytorch怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor

注意:使用torchvision.transforms時(shí)要注意一下,其子函數(shù) ToTensor() 是沒有參數(shù)輸入的,以下用法是會(huì)報(bào)錯(cuò)的

img_tensor = transforms.ToTensor(img)

必須是先定義和賦值轉(zhuǎn)換函數(shù),再調(diào)用并輸入?yún)?shù),正確用法:

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

再轉(zhuǎn)換過程中正則化

在使用 transforms.ToTensor() 進(jìn)行圖片數(shù)據(jù)轉(zhuǎn)換過程中會(huì)對(duì)圖像的像素值進(jìn)行正則化,即一般讀取的圖片像素值都是8 bit 的二進(jìn)制,那么它的十進(jìn)制的范圍為 [0, 255],而正則化會(huì)對(duì)每個(gè)像素值除以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怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor

使用pytorch怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor

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

使用transforms.Compose函數(shù)可以自行修改正則化的范圍,下面舉個(gè)例子正則化成 [-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怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor

計(jì)算方式就是:

C=(C-mean)/ std

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

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

補(bǔ)充:Python: 記錄一個(gè)關(guān)于圖片直接轉(zhuǎn)化為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怎么將圖片數(shù)據(jù)轉(zhuǎn)換成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 去轉(zhuǎn)換得到(h,w,c)格式,而用to_tensor得到(c,h,w)格式且值已經(jīng)除了255。

byte()相當(dāng)于to(torch.uint8),tensor.numpy()是把tensor 轉(zhuǎn)化為numpy.array格式。

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

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

上述就是小編為大家分享的使用pytorch怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


分享文章:使用pytorch怎么將圖片數(shù)據(jù)轉(zhuǎn)換成tensor-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://weahome.cn/article/dgoiih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部