欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Pytorch 實(shí)現(xiàn)sobel算子的卷積操作詳解

 更新時(shí)間:2020年01月10日 17:13:21   作者:洪流之源  
今天小編就為大家分享一篇Pytorch 實(shí)現(xiàn)sobel算子的卷積操作詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧

卷積在pytorch中有兩種實(shí)現(xiàn),一種是torch.nn.Conv2d(),一種是torch.nn.functional.conv2d(),這兩種方式本質(zhì)都是執(zhí)行卷積操作,對(duì)輸入的要求也是一樣的,首先需要輸入的是一個(gè)torch.autograd.Variable()的類型,大小是(batch,channel, H,W),其中batch表示輸入的一批數(shù)據(jù)的數(shù)目,channel表示輸入的通道數(shù)。

一般一張彩色的圖片是3,灰度圖片是1,而卷積網(wǎng)絡(luò)過程中的通道數(shù)比較大,會(huì)出現(xiàn)幾十到幾百的通道數(shù)。H和W表示輸入圖片的高度和寬度,比如一個(gè)batch是32張圖片,每張圖片是3通道,高和寬分別是50和100,那么輸入的大小就是(32,3,50,100)。

如下代碼是卷積執(zhí)行soble邊緣檢測(cè)算子的實(shí)現(xiàn):

import torch
import numpy as np
from torch import nn
from PIL import Image
from torch.autograd import Variable
import torch.nn.functional as F
 
 
def nn_conv2d(im):
  # 用nn.Conv2d定義卷積操作
  conv_op = nn.Conv2d(1, 1, 3, bias=False)
  # 定義sobel算子參數(shù)
  sobel_kernel = np.array([[-1, -1, -1], [-1, 8, -1], [-1, -1, -1]], dtype='float32')
  # 將sobel算子轉(zhuǎn)換為適配卷積操作的卷積核
  sobel_kernel = sobel_kernel.reshape((1, 1, 3, 3))
  # 給卷積操作的卷積核賦值
  conv_op.weight.data = torch.from_numpy(sobel_kernel)
  # 對(duì)圖像進(jìn)行卷積操作
  edge_detect = conv_op(Variable(im))
  # 將輸出轉(zhuǎn)換為圖片格式
  edge_detect = edge_detect.squeeze().detach().numpy()
  return edge_detect
 
def functional_conv2d(im):
  sobel_kernel = np.array([[-1, -1, -1], [-1, 8, -1], [-1, -1, -1]], dtype='float32') #
  sobel_kernel = sobel_kernel.reshape((1, 1, 3, 3))
  weight = Variable(torch.from_numpy(sobel_kernel))
  edge_detect = F.conv2d(Variable(im), weight)
  edge_detect = edge_detect.squeeze().detach().numpy()
  return edge_detect
 
def main():
  # 讀入一張圖片,并轉(zhuǎn)換為灰度圖
  im = Image.open('./cat.jpg').convert('L')
  # 將圖片數(shù)據(jù)轉(zhuǎn)換為矩陣
  im = np.array(im, dtype='float32')
  # 將圖片矩陣轉(zhuǎn)換為pytorch tensor,并適配卷積輸入的要求
  im = torch.from_numpy(im.reshape((1, 1, im.shape[0], im.shape[1])))
  # 邊緣檢測(cè)操作
  # edge_detect = nn_conv2d(im)
  edge_detect = functional_conv2d(im)
  # 將array數(shù)據(jù)轉(zhuǎn)換為image
  im = Image.fromarray(edge_detect)
  # image數(shù)據(jù)轉(zhuǎn)換為灰度模式
  im = im.convert('L')
  # 保存圖片
  im.save('edge.jpg', quality=95)
 
if __name__ == "__main__":
  main()

原圖片:cat.jpg

結(jié)果圖片:edge.jpg

以上這篇Pytorch 實(shí)現(xiàn)sobel算子的卷積操作詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python sorted排序方法如何實(shí)現(xiàn)

    Python sorted排序方法如何實(shí)現(xiàn)

    這篇文章主要介紹了Python sorted排序方法如何實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Keras在訓(xùn)練期間可視化訓(xùn)練誤差和測(cè)試誤差實(shí)例

    Keras在訓(xùn)練期間可視化訓(xùn)練誤差和測(cè)試誤差實(shí)例

    這篇文章主要介紹了Keras在訓(xùn)練期間可視化訓(xùn)練誤差和測(cè)試誤差實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2020-06-06
  • Python辦公自動(dòng)化SFTP詳解

    Python辦公自動(dòng)化SFTP詳解

    這篇文章主要介紹了Python辦公自動(dòng)化SFTP詳解,sftp和ftp的區(qū)別在安全通道,使用的協(xié)議,鏈接方式,安全性等方面都有不同,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-08-08
  • python簡(jiǎn)單實(shí)現(xiàn)刷新智聯(lián)簡(jiǎn)歷

    python簡(jiǎn)單實(shí)現(xiàn)刷新智聯(lián)簡(jiǎn)歷

    本文給大家分享的是個(gè)人弄的一個(gè)使用Python簡(jiǎn)單實(shí)現(xiàn)刷新智聯(lián)招聘簡(jiǎn)歷的小工具的代碼,非常的簡(jiǎn)單,給大家參考下吧。
    2016-03-03
  • Python 探針的實(shí)現(xiàn)原理

    Python 探針的實(shí)現(xiàn)原理

    本文將簡(jiǎn)單講述一下 Python 探針的實(shí)現(xiàn)原理。 同時(shí)為了驗(yàn)證這個(gè)原理,我們也會(huì)一起來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的統(tǒng)計(jì)指定函數(shù)執(zhí)行時(shí)間的探針程序。
    2016-04-04
  • 使用python svm實(shí)現(xiàn)直接可用的手寫數(shù)字識(shí)別

    使用python svm實(shí)現(xiàn)直接可用的手寫數(shù)字識(shí)別

    這篇文章主要介紹了使用python svm實(shí)現(xiàn)直接可用的手寫數(shù)字識(shí)別,現(xiàn)在網(wǎng)上很多代碼是良莠不齊,真是一言難盡,于是記錄一下,能夠運(yùn)行成功并識(shí)別成功的一個(gè)源碼
    2021-08-08
  • Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序

    Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序

    這篇文章主要介紹了Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2019-06-06
  • pygame實(shí)現(xiàn)井字棋之第三步邏輯優(yōu)化

    pygame實(shí)現(xiàn)井字棋之第三步邏輯優(yōu)化

    這篇文章主要介紹了pygame實(shí)現(xiàn)井字棋之第三步邏輯優(yōu)化,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們也有非常好的幫助,需要的朋友可以參考下
    2021-05-05
  • Python使用日志模塊快速調(diào)試代碼并記錄異常信息

    Python使用日志模塊快速調(diào)試代碼并記錄異常信息

    本文詳細(xì)介紹了Python logging日志模塊的使用方法,包括如何在代碼中使用logging記錄調(diào)試信息、如何設(shè)置日志級(jí)別、如何記錄異常信息等。通過本文的指南,讀者可以快速學(xué)會(huì)如何使用logging模塊進(jìn)行調(diào)試,并保留有用的日志信息,便于后續(xù)排查問題和優(yōu)化代碼
    2023-04-04
  • 利用Python做一個(gè)電腦通知小工具

    利用Python做一個(gè)電腦通知小工具

    Windows不是有個(gè)消息通知功能,挺喜歡這個(gè)功能的,但是不太方便使用,也懶得去研究,于是準(zhǔn)備用Python自己寫一個(gè),感興趣的可以了解一下
    2022-12-12

最新評(píng)論