pytorch 自定義卷積核進(jìn)行卷積操作方式
一 卷積操作:在pytorch搭建起網(wǎng)絡(luò)時(shí),大家通常都使用已有的框架進(jìn)行訓(xùn)練,在網(wǎng)絡(luò)中使用最多就是卷積操作,最熟悉不過的就是
torch.nn.Conv2d(in_channels, out_channels, kernel_size, stride=1, padding=0, dilation=1, groups=1, bias=True)
通過上面的輸入發(fā)現(xiàn)想自定義自己的卷積核,比如高斯核,發(fā)現(xiàn)是行不通的,因?yàn)樯厦娴膮?shù)里面只有卷積核尺寸,而權(quán)值weight是通過梯度一直更新的,是不確定的。
二 需要自己定義卷積核的目的:目前是需要通過一個(gè)VGG網(wǎng)絡(luò)提取特征特后需要對其進(jìn)行高斯卷積,卷積后再繼續(xù)輸入到網(wǎng)絡(luò)中訓(xùn)練。
三 解決方案。使用
torch.nn.functional.conv2d(input, weight, bias=None, stride=1, padding=0, dilation=1, groups=1)
這里注意下weight的參數(shù)。與nn.Conv2d的參數(shù)不一樣
可以發(fā)現(xiàn)F.conv2d可以直接輸入卷積的權(quán)值weight,也就是卷積核。那么接下來就要首先生成一個(gè)高斯權(quán)重了。這里不直接一步步寫了,直接輸入就行。
kernel = [[0.03797616, 0.044863533, 0.03797616], [0.044863533, 0.053, 0.044863533], [0.03797616, 0.044863533, 0.03797616]]
四 完整代碼
class GaussianBlur(nn.Module): def __init__(self): super(GaussianBlur, self).__init__() kernel = [[0.03797616, 0.044863533, 0.03797616], [0.044863533, 0.053, 0.044863533], [0.03797616, 0.044863533, 0.03797616]] kernel = torch.FloatTensor(kernel).unsqueeze(0).unsqueeze(0) self.weight = nn.Parameter(data=kernel, requires_grad=False) def forward(self, x): x1 = x[:, 0] x2 = x[:, 1] x3 = x[:, 2] x1 = F.conv2d(x1.unsqueeze(1), self.weight, padding=2) x2 = F.conv2d(x2.unsqueeze(1), self.weight, padding=2) x3 = F.conv2d(x3.unsqueeze(1), self.weight, padding=2) x = torch.cat([x1, x2, x3], dim=1) return x
這里為了網(wǎng)絡(luò)模型需要寫成了一個(gè)類,這里假設(shè)輸入的x也就是經(jīng)過網(wǎng)絡(luò)提取后的三通道特征圖(當(dāng)然不一定是三通道可以是任意通道)
如果是任意通道的話,使用torch.expand()向輸入的維度前面進(jìn)行擴(kuò)充。如下:
def blur(self, tensor_image): kernel = [[0.03797616, 0.044863533, 0.03797616], [0.044863533, 0.053, 0.044863533], [0.03797616, 0.044863533, 0.03797616]] min_batch=tensor_image.size()[0] channels=tensor_image.size()[1] out_channel=channels kernel = torch.FloatTensor(kernel).expand(out_channel,channels,3,3) self.weight = nn.Parameter(data=kernel, requires_grad=False) return F.conv2d(tensor_image,self.weight,1,1)
以上這篇pytorch 自定義卷積核進(jìn)行卷積操作方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
pytorch查看通道數(shù) 維數(shù) 尺寸大小方式
這篇文章主要介紹了pytorch查看通道數(shù) 維數(shù) 尺寸大小方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05python 類對象和實(shí)例對象動(dòng)態(tài)添加方法(分享)
下面小編就為大家分享一篇python 類對象和實(shí)例對象動(dòng)態(tài)添加方法。具有很的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12Python3使用騰訊云文字識(shí)別(騰訊OCR)提取圖片中的文字內(nèi)容實(shí)例詳解
這篇文章主要介紹了Python3使用騰訊云文字識(shí)別(騰訊OCR)提取圖片中的文字內(nèi)容方法詳解,需要的朋友可以參考下2020-02-02Python、 Pycharm、Django安裝詳細(xì)教程(圖文)
這篇文章主要介紹了Python、 Pycharm、Django安裝詳細(xì)教程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04python數(shù)據(jù)清洗中的時(shí)間格式化實(shí)現(xiàn)
本文主要介紹了python數(shù)據(jù)清洗中的時(shí)間格式化實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05Python調(diào)用百度AI實(shí)現(xiàn)人像分割詳解
本文主要介紹了如何通過Python調(diào)用百度AI從而實(shí)現(xiàn)人像的分割與合成,文中的示例代碼對我們的工作或?qū)W習(xí)有一定的幫助,需要的朋友可以參考一下2021-12-12Python操作Oracle數(shù)據(jù)庫的簡單方法和封裝類實(shí)例
這篇文章主要介紹了Python操作Oracle數(shù)據(jù)庫的簡單方法和封裝類,結(jié)合實(shí)例形式分析了Python簡單連接、查詢、關(guān)閉Oracle數(shù)據(jù)庫基本操作,并給出了一個(gè)Python針對Oracle各種操作的封裝類,需要的朋友可以參考下2018-05-05