溫馨提示×

溫馨提示×

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

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

pytorch?tensor計算三通道均值方式是什么

發(fā)布時間:2022-07-18 10:07:14 來源:億速云 閱讀:180 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“pytorch tensor計算三通道均值方式是什么”,在日常操作中,相信很多人在pytorch tensor計算三通道均值方式是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”pytorch tensor計算三通道均值方式是什么”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

tensor計算三通道均值

今天用pytorch處理圖像時,涉及到了計算均值的問題,整理一下解決思路。

第一種思路

tensor轉(zhuǎn)換為numpy再進(jìn)行處理

import torch
import cv2
img = cv2.imread("image path")
tensor_img = torch.from_numpy((img[:, :, ::-1] / 255.0)[None, ...].transpose(0, 3, 1, 2)).cuda()
 
...
 
numpy_img = (tensor_img.detach().cpu().numpy().transpose(2, 3, 1, 0).squeeze() * 255)[:, :, ::-1]
 
ave_color = np.mean(numpy_img , axis=(0, 1))

如果圖像里有0值,不想計入運算:

numpy_img[numpy_img == 0] = np.nan
ave_color = np.nanmean(numpy_img, axis=(0, 1))

由于tensor和numpy來回轉(zhuǎn)換會消耗資源、性能。

又查了一番,直接在tensor中計算(非零均值計算)

reshape_tensor_img = tensor_img.view(tensor_img.size(0), tensor_img.size(1), -1)
ave_color = reshape_tensor_img.mean(2)
 
# mean value without 0
non_zero_img = reshape_tensor_img[reshape_tensor_img.nonzero(as_tuple=True)]
ave_color = non_zero_img.view(reshape_tensor_img.size(0), reshape_tensor_img.size(1), -1).mean(2)

計算完均值,想要加法運算的時候也會碰上一點維度上的麻煩,需要維度轉(zhuǎn)換一下。

reshape_ave_color = ave_color.view(ave_color.size(0), ave_color.size(1), 1, 1)
add_img = tensor_img + reshape_ave_color

Pytorch tensor的運算

tensor操作

1. 新建

A、torch.Tensor(shape)/torch.FloatTensor(shape):隨機(jī)初始化一個維度為shape的張量。

pytorch?tensor計算三通道均值方式是什么

B、torch.randn(shape):用均值為0,方差為1的高斯分布初始化一個shape的張量。

pytorch?tensor計算三通道均值方式是什么

C、torch.rand(shape):在區(qū)間[0,1]上均勻分布,初始化一個shape的張量。

pytorch?tensor計算三通道均值方式是什么

2、Tensor的變換

A、view / reshape

兩個用法差不多,都是用來改變一個張量的數(shù)據(jù)分布。

pytorch?tensor計算三通道均值方式是什么

注:(2,-1)中的-1會自動計算剩下的維度。

B、squeeze / unsqueeze

第一個是用來壓縮維度為1的張量,如(6,1,32,32).squeeze()之后就變?yōu)?6,32,32);第二個是用來增加一個維度。具體看實例如下:

pytorch?tensor計算三通道均值方式是什么

注:squeeze中不帶參數(shù),是將所有維度為1的地方去掉,帶參數(shù)是去指定維度為1的地方,若指定的維度不為1,則不變。

pytorch?tensor計算三通道均值方式是什么

注:在指定的維度上插入一個大小為1的新維度。

C、expand / repeat

這兩個都是進(jìn)行數(shù)據(jù)的擴(kuò)充操作,第一個是擴(kuò)充到指定的維度大小,第二個函數(shù)的參數(shù)維度上擴(kuò)充的倍數(shù)。一般結(jié)合上面2.B中的函數(shù)使用。

pytorch?tensor計算三通道均值方式是什么

D、 t / transpose / permute

這三個函數(shù)用來數(shù)據(jù)維度之間的調(diào)整,第一個只能用于2D。

pytorch?tensor計算三通道均值方式是什么

E、broadcasting機(jī)制

相當(dāng)于自動完成了unsqueeze+expand的操作,但是相比節(jié)省內(nèi)存空間。

pytorch?tensor計算三通道均值方式是什么

通過broadcasting機(jī)制,張量可以直接和標(biāo)量進(jìn)行相加。

到此,關(guān)于“pytorch tensor計算三通道均值方式是什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI