關(guān)于Python卷積函數(shù)詳解
卷積函數(shù)
python提供了多種卷積方案,相比之下,定義在ndimage中的卷積函數(shù),在功能上比numpy和signal中的卷積要稍微復(fù)雜一些,這點(diǎn)僅從輸入?yún)?shù)的多少就可略窺一二
numpy.convolve(a, v, mode='full') scipy.ndimage.convolve1d(input, weights, axis=-1, output=None, mode='reflect', cval=0.0, origin=0) scipy.signal.convolve(in1, in2, mode='full', method='auto') scipy.ndimage.convolve(input, weights, output=None, mode='reflect', cval=0.0, origin=0)
前兩者為1維卷積函數(shù),且ndimage可對(duì)多維數(shù)組沿著單個(gè)坐標(biāo)軸進(jìn)行卷積操作,后兩者為多維卷積。
numpy和signal中的卷積函數(shù),其mode都有三種,用以調(diào)節(jié)卷積后的邊緣特性,如果輸入的兩個(gè)卷積對(duì)象的維度分別是N NN和M MM,則這三種模式的輸出結(jié)果為
full: 輸出維度N + M − 1 N+M-1N+M−1,其最后一點(diǎn)的信號(hào)完全不交疊,故而邊緣效應(yīng)明顯。same:輸出維度max ? ( M , N ) \max(M,N)max(M,N),邊緣效應(yīng)仍然可見valid:輸出維度∣ M − N ∣ |M-N|∣M−N∣,只返回完全交疊的區(qū)域,相當(dāng)于把存在邊緣效應(yīng)的點(diǎn)都率除掉了
ndimage中的convolve針對(duì)邊緣效應(yīng),對(duì)圖像進(jìn)行擴(kuò)展,而其mode決定的就是擴(kuò)展之后的填充格式,設(shè)待濾波數(shù)組為a b c d,則在不同的模式下,對(duì)邊緣進(jìn)行如下填充
| 左側(cè)填充 | 數(shù)據(jù) | 右側(cè)填充 | |
|---|---|---|---|
reflect | d c b a | a b c d | d c b a |
constant | k k k k | a b c d | k k k k |
nearest | a a a a | a b c d | d d d d |
mirror | d c b | a b c d | c b a |
wrap | a b c d | a b c d | a b c d |
其中,k通過參數(shù)cval設(shè)定。
這五種修改邊界的方法,在scipy.ndimage的函數(shù)中十分普遍,尤其是涉及到卷積的濾波函數(shù),堪稱標(biāo)配。
對(duì)比測試
接下來針對(duì)這些不同的卷積函數(shù),做一下性能測試,用5 × 5的卷積模板,對(duì)1000 × 1000的矩陣進(jìn)行卷積計(jì)算,來看一下不同實(shí)現(xiàn)方案的卷積,其速度如何
import numpy as np import scipy.signal as ss import scipy.ndimage as sn from timeit import timeit A = np.random.rand(1000,1000) B = np.random.rand(5,5) timeit(lambda : ss.convolve(A, B), number=10) # 0.418 timeit(lambda : sn.convolve(A, B), number=10) # 0.126
相比之下,ndimage中的卷積顯然是更高效的。
接下來測試一下一維卷積的表現(xiàn)
A = np.random.rand(10000) B = np.random.rand(15) timeit(lambda : np.convolve(A, B), number=1000) # 0.15256029999727616 timeit(lambda : ss.convolve(A, B), number=1000) # 0.1231262000001152 timeit(lambda : sn.convolve(A, B), number=1000) # 0.09218210000108229 timeit(lambda : sn.convolve1d(A, B), number=1000) # 0.03915820000111125
相比之下,convolve1d不愧是寫明了1d的卷積函數(shù),速度最快,而numpy中提供的函數(shù)速度最慢。
卷積應(yīng)用
卷積操作經(jīng)常被作用在圖像濾波以及邊緣提取上,例如,通過類似下面這樣的矩陣,可以將圖像的縱向的邊緣提取出來。

下面做一個(gè)簡單的測試
from scipy.misc import ascent import matplotlib.pyplot as plt img = ascent() temp = np.zeros([3,3]) temp[:,0] = -1 temp[:,2] = 1 edge = sn.convolve(img, temp) fig = plt.figure() ax = fig.add_subplot(121) ax.imshow(img) ax = fig.add_subplot(122) ax.imshow(edge) plt.show()
效果如下,非常明顯

到此這篇關(guān)于關(guān)于Python卷積函數(shù)詳解的文章就介紹到這了,更多相關(guān)Python卷積詳解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python如何實(shí)現(xiàn)圖片轉(zhuǎn)文字
這篇文章主要介紹了python如何實(shí)現(xiàn)圖片轉(zhuǎn)文字問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
對(duì)pandas的行列名更改與數(shù)據(jù)選擇詳解
今天小編就為大家分享一篇對(duì)pandas的行列名更改與數(shù)據(jù)選擇詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11
PyTorch線性回歸和邏輯回歸實(shí)戰(zhàn)示例
這篇文章主要介紹了PyTorch線性回歸和邏輯回歸實(shí)戰(zhàn)示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05
Python命令行參數(shù)argv和argparse該如何使用
這篇文章主要介紹了Python命令行參數(shù)argv和argparse該如何使用,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-02-02
Python光學(xué)仿真學(xué)習(xí)Gauss高斯光束在空間中的分布
這篇文章主要介紹了Python光學(xué)仿真學(xué)習(xí)中Gauss高斯光束在空間中的分布理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-10-10
Pygame實(shí)現(xiàn)游戲最小系統(tǒng)功能詳解
這篇文章主要介紹了Pygame實(shí)現(xiàn)游戲最小系統(tǒng),Pygame是一個(gè)專門用來開發(fā)游戲的 Python 模塊,主要為開發(fā)、設(shè)計(jì) 2D 電子游戲而生,具有免費(fèi)、開源,支持多種操作系統(tǒng),具有良好的跨平臺(tái)性等優(yōu)點(diǎn)2022-11-11

