- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) >
- python實(shí)現高斯模糊及原理詳解
高斯模糊是一種常見(jiàn)的模糊技術(shù),相關(guān)知識點(diǎn)有:高斯函數、二維卷積。
一維(連續變量)高斯函數形式如下,高斯函數又稱(chēng)“正態(tài)分布函數”:
μ是分布函數的均值(或者期望),sigma是標準差。
一維高斯分布函數的圖形:
從圖可知,以x=0為中心,x取值距離中心越近,概率密度函數值越大,距離中心越遠,密度函數值越小。
二維高斯分布函數的形式:
特別說(shuō)明,當變量x和y相互獨立時(shí),則相關(guān)系數ρ=0,二維高斯分布函數可以簡(jiǎn)化為:
二維高斯分布函數的圖形:
對于一維高斯分布,函數中心是平面上的一個(gè)點(diǎn);而對于二維高斯分布,函數中心是一個(gè)三維立體空間上的一個(gè)點(diǎn),即上圖中山峰的最頂端處的點(diǎn)。
高斯模糊本質(zhì)上一種數據平滑技術(shù),可以用于一維、二維甚至多維空間。數據經(jīng)高斯模糊處理之后,數據會(huì )趨向于周邊鄰近的其他數據,導致各個(gè)數據“趨同”。
在圖像領(lǐng)域,各個(gè)位置的像素值使用“周邊鄰居像素點(diǎn)加權平均”重新賦值。對于每個(gè)像素點(diǎn),由于計算時(shí)均以當前像素點(diǎn)為中心,所以均值μ=0。使用時(shí)有2個(gè)超參數需要設置:高斯核大小和高斯函數標準差σ。高斯核大小表示“影響當前點(diǎn)的最大鄰域范圍”,而標準差表示“鄰域中的其他像素點(diǎn)對當前點(diǎn)的影響力”。
從下而上觀(guān)察下圖各個(gè)函數圖像,各個(gè)函數的均值相同,而方差逐步減小。
方差衡量數據的分散程度,方差越大,數據越分散,圖形就越扁平,數據的集中趨勢越弱,應用到高斯模糊中方差越大圖形越模糊。
(1)如何計算高斯卷積核
3×3大小的高斯卷積核的計算示意圖
直接計算二維高斯函數值后,卷積核的各個(gè)位置取值(截圖自pycharm的debug):
卷積核歸一化后的各個(gè)位置取值(截圖自pycharm的debug):
高斯卷積核的python代碼:
def gaussian_kernel(self): kernel = np.zeros(shape=(self.kernel_size, self.kernel_size), dtype=np.float) radius = self.kernel_size//2 for y in range(-radius, radius + 1): # [-r, r] for x in range(-radius, radius + 1): # 二維高斯函數 v = 1.0 / (2 * np.pi * self.sigma ** 2) * np.exp(-1.0 / (2 * self.sigma ** 2) * (x ** 2 + y ** 2)) kernel[y + radius, x + radius] = v # 高斯函數的x和y值 vs 高斯核的下標值 kernel2 = kernel / np.sum(kernel) return kernel2
(2)如何在二維圖像上進(jìn)行卷積
對于二維矩陣,卷積時(shí)卷積核從左向右、從上而下的滑動(dòng),對應位置求加權和。一般圖像是RGB三通道,需要逐個(gè)通道卷積,每個(gè)通道是一個(gè)二維矩陣?;叶葓D只有一個(gè)通道,直接卷積即可。
自行實(shí)現的二維離散卷積的python代碼:
def my_conv2d(inputs: np.ndarray, kernel: np.ndarray): # 計算需要填充的行列數目,這里假定mode為“same” # 一般卷積核的hw都是奇數,這里實(shí)現方式也是基于奇數尺寸的卷積核 h, w = inputs.shape kernel = kernel[::-1, ...][..., ::-1] # 卷積的定義,必須旋轉180度 h1, w1 = kernel.shape h_pad = (h1 - 1) // 2 w_pad = (w1 - 1) // 2 inputs = np.pad(inputs, pad_width=[(h_pad, h_pad), (w_pad, w_pad)], mode="constant", constant_values=0) outputs = np.zeros(shape=(h, w)) for i in range(h): # 行號 for j in range(w): # 列號 outputs[i, j] = np.sum(np.multiply(inputs[i: i + h1, j: j + w1], kernel)) return outputs
scipy中已經(jīng)提供二維卷積函數scipy.signal.convolve2d,可以直接調用,下圖是和自行實(shí)現的對比效果。
運行之后結果一致,驗證自行實(shí)現的二維卷積正確。
補充:scipy.signal.convolve2d的參數說(shuō)明
in1:輸入矩陣
in2:卷積核
mode:指示輸出矩陣的尺寸,full代表完全離散線(xiàn)性卷積, valid代表輸出尺寸等于輸入尺寸-卷積核+1, same代表輸出尺寸與輸入尺寸一致。
boundary:需要填充時(shí)邊界填充方式,fill代表使用常量值填充, wrap代表循環(huán)方式填充, symm代表以四周邊為對稱(chēng)軸對稱(chēng)填充。
fillvalue:常量填充時(shí)的填充值
完整的python代碼
class GaussianBlur(object): def __init__(self, kernel_size=3, sigma=1.5): self.kernel_size = kernel_size self.sigma = sigma self.kernel = self.gaussian_kernel() def gaussian_kernel(self): kernel = np.zeros(shape=(self.kernel_size, self.kernel_size), dtype=np.float) radius = self.kernel_size//2 for y in range(-radius, radius + 1): # [-r, r] for x in range(-radius, radius + 1): # 二維高斯函數 v = 1.0 / (2 * np.pi * self.sigma ** 2) * np.exp(-1.0 / (2 * self.sigma ** 2) * (x ** 2 + y ** 2)) kernel[y + radius, x + radius] = v # 高斯函數的x和y值 vs 高斯核的下標值 kernel2 = kernel / np.sum(kernel) return kernel2 def filter(self, img: Image.Image): img_arr = np.array(img) if len(img_arr.shape) == 2: new_arr = signal.convolve2d(img_arr, self.kernel, mode="same", boundary="symm") else: h, w, c = img_arr.shape new_arr = np.zeros(shape=(h, w, c), dtype=np.float) for i in range(c): new_arr[..., i] = signal.convolve2d(img_arr[..., i], self.kernel, mode="same", boundary="symm") new_arr = np.array(new_arr, dtype=np.uint8) return Image.fromarray(new_arr) def main(): img = Image.open("Jeep-cd.jpg").convert("RGB") img2 = GaussianBlur(sigma=2.5).filter(img) plt.subplot(1, 2, 1) plt.imshow(img) plt.subplot(1, 2, 2) plt.imshow(img2) # dpi參數維持圖片的清晰度 plt.savefig("gaussian.jpg", dpi=500) plt.show() pass
代碼運行效果,發(fā)現經(jīng)高斯模糊處理之后,圖片發(fā)生明顯模糊。
到此這篇關(guān)于python實(shí)現高斯模糊及原理詳解的文章就介紹到這了,更多相關(guān)python 高斯模糊內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自互聯(lián)網(wǎng)轉載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權請聯(lián)系QQ:712375056 進(jìn)行舉報,并提供相關(guān)證據,一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容。
Copyright ? 2009-2021 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 珠海市特網(wǎng)科技有限公司 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站