日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python實現高斯模糊及原理詳解

瀏覽:27日期:2022-06-19 16:04:49

高斯模糊是一種常見的模糊技術,相關知識點有:高斯函數、二維卷積。

python實現高斯模糊及原理詳解

(一)一維高斯分布函數

一維(連續變量)高斯函數形式如下,高斯函數又稱“正態分布函數”:

python實現高斯模糊及原理詳解

μ是分布函數的均值(或者期望),sigma是標準差。

一維高斯分布函數的圖形:

python實現高斯模糊及原理詳解

從圖可知,以x=0為中心,x取值距離中心越近,概率密度函數值越大,距離中心越遠,密度函數值越小。

(二)二維高斯分布函數

二維高斯分布函數的形式:

python實現高斯模糊及原理詳解

特別說明,當變量x和y相互獨立時,則相關系數ρ=0,二維高斯分布函數可以簡化為:

python實現高斯模糊及原理詳解

二維高斯分布函數的圖形:

python實現高斯模糊及原理詳解

對于一維高斯分布,函數中心是平面上的一個點;而對于二維高斯分布,函數中心是一個三維立體空間上的一個點,即上圖中山峰的最頂端處的點。

(三)高斯模糊

高斯模糊本質上一種數據平滑技術,可以用于一維、二維甚至多維空間。數據經高斯模糊處理之后,數據會趨向于周邊鄰近的其他數據,導致各個數據“趨同”。

在圖像領域,各個位置的像素值使用“周邊鄰居像素點加權平均”重新賦值。對于每個像素點,由于計算時均以當前像素點為中心,所以均值μ=0。使用時有2個超參數需要設置:高斯核大小和高斯函數標準差σ。高斯核大小表示“影響當前點的最大鄰域范圍”,而標準差表示“鄰域中的其他像素點對當前點的影響力”。

從下而上觀察下圖各個函數圖像,各個函數的均值相同,而方差逐步減小。

python實現高斯模糊及原理詳解

方差衡量數據的分散程度,方差越大,數據越分散,圖形就越扁平,數據的集中趨勢越弱,應用到高斯模糊中方差越大圖形越模糊。

高斯模糊涉及到2個關鍵技術點:

(1)如何計算高斯卷積核

3×3大小的高斯卷積核的計算示意圖

python實現高斯模糊及原理詳解

直接計算二維高斯函數值后,卷積核的各個位置取值(截圖自pycharm的debug):

python實現高斯模糊及原理詳解

卷積核歸一化后的各個位置取值(截圖自pycharm的debug):

python實現高斯模糊及原理詳解

高斯卷積核的python代碼:

def gaussian_kernel(self):kernel = np.zeros(shape=(self.kernel_size, self.kernel_size), dtype=np.float)radius = self.kernel_size//2for 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)如何在二維圖像上進行卷積

對于二維矩陣,卷積時卷積核從左向右、從上而下的滑動,對應位置求加權和。一般圖像是RGB三通道,需要逐個通道卷積,每個通道是一個二維矩陣。灰度圖只有一個通道,直接卷積即可。

自行實現的二維離散卷積的python代碼:

def my_conv2d(inputs: np.ndarray, kernel: np.ndarray): # 計算需要填充的行列數目,這里假定mode為“same” # 一般卷積核的hw都是奇數,這里實現方式也是基于奇數尺寸的卷積核 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中已經提供二維卷積函數scipy.signal.convolve2d,可以直接調用,下圖是和自行實現的對比效果。

python實現高斯模糊及原理詳解

運行之后結果一致,驗證自行實現的二維卷積正確。

python實現高斯模糊及原理詳解

補充:scipy.signal.convolve2d的參數說明

in1:輸入矩陣

in2:卷積核

mode:指示輸出矩陣的尺寸,full代表完全離散線性卷積, valid代表輸出尺寸等于輸入尺寸-卷積核+1, same代表輸出尺寸與輸入尺寸一致。

boundary:需要填充時邊界填充方式,fill代表使用常量值填充, wrap代表循環方式填充, symm代表以四周邊為對稱軸對稱填充。

fillvalue:常量填充時的填充值

(四)完整代碼和運行效果

完整的python代碼​​​​​​

class GaussianBlur(object): def __init__(self, kernel_size=3, sigma=1.5):self.kernel_size = kernel_sizeself.sigma = sigmaself.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//2for 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

代碼運行效果,發現經高斯模糊處理之后,圖片發生明顯模糊。

python實現高斯模糊及原理詳解

python實現高斯模糊及原理詳解

到此這篇關于python實現高斯模糊及原理詳解的文章就介紹到這了,更多相關python 高斯模糊內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
丰满少妇一区| 国产日韩欧美三级| 黄在线观看免费网站ktv| 欧美欧美黄在线二区| 日韩av中文字幕一区| 亚洲精品乱码久久久久久蜜桃麻豆| 久久亚洲二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩一级欧洲| 欧美亚洲精品在线| 久久免费视频66| 国产一区二区久久久久| 在线看片福利| 亚洲二区视频| 久久xxxx| 久久精品99国产精品日本| 欧美韩一区二区| 国产一区二区久久久久| 99久久99视频只有精品| 国产毛片一区| 欧美日韩一区二区三区在线电影| 精品在线网站观看| 高潮一区二区| 亚洲激情国产| 亚洲综合精品| 亚洲人www| 国产精品久久国产愉拍| 国产suv精品一区二区四区视频| 久久久久久婷| 亚洲精品成人| 日韩不卡在线观看日韩不卡视频 | 免费精品国产的网站免费观看| 在线亚洲国产精品网站| 欧美一区自拍| 97在线精品| 一区二区视频欧美| 亚洲精品动态| 欧美一级一区| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 国产午夜久久av| 水蜜桃久久夜色精品一区| 欧美成人国产| 日本视频中文字幕一区二区三区| 福利一区视频| 美女黄网久久| 国产不卡一区| 免费在线视频一区| 国产一区 二区| 性欧美xxxx免费岛国不卡电影| 亚洲97av| 在线看片国产福利你懂的| 亚洲字幕久久| 日本欧美国产| 日韩一区二区三免费高清在线观看| 国产一区二区三区四区五区| 亚洲一区欧美激情| 成午夜精品一区二区三区软件| 午夜久久福利| 国产精品久久免费视频| 91国语精品自产拍| 精品福利久久久| 亚洲网址在线观看| 福利一区二区| 欧美伊人影院| 99国产精品久久久久久久成人热 | 国产麻豆久久| 国产日韩视频在线| 中文久久精品| 午夜av不卡| 欧美日一区二区在线观看| 亚洲网站视频| 精品中文在线| 奇米777国产一区国产二区| 欧美不卡视频| 欧美aa在线视频| 亚洲免费观看高清完整版在线观| 婷婷激情一区| 精品国产不卡一区二区| 日韩中文字幕一区二区高清99| 婷婷久久一区| 欧美日韩国产观看视频| 久久激五月天综合精品| 先锋影音久久久| 亚洲1234区| 精品一区二区三区亚洲| 日韩不卡一区二区三区| 亚洲在线观看| 在线日韩电影| 国产在线观看www| 国产调教精品| 亚洲精品一二三**| 免费看黄色91| 欧美日韩免费观看一区=区三区| 日韩亚洲一区在线| 成人在线丰满少妇av| 嫩草伊人久久精品少妇av杨幂 | 日韩1区2区日韩1区2区| 久久先锋影音| 999在线观看精品免费不卡网站| 亚洲va中文在线播放免费| 国产suv精品一区二区四区视频| 国产日韩一区二区三区在线 | 尤物精品在线| 久久一区二区三区喷水| 在线一区视频观看| 精品欧美一区二区三区在线观看| 国产高清亚洲| 久久99性xxx老妇胖精品| 日本特黄久久久高潮| 日本在线成人| 日韩av在线播放中文字幕| 亚洲资源在线| 中文不卡在线| 鲁大师影院一区二区三区| 亚洲精品电影| 国产精品美女久久久| 一区免费在线| 欧美日韩日本国产亚洲在线| 在线一区免费| 欧美在线网站| 亚洲一区久久| 鲁大师成人一区二区三区| 日韩中文字幕一区二区三区| 制服诱惑一区二区| 免播放器亚洲一区| 亚洲91网站| 国产乱码精品一区二区三区四区 | 日韩av午夜在线观看| 日韩av一区二区三区| 91麻豆精品激情在线观看最新| 欧美午夜网站| 久久久精品国产**网站| 国产一区二区三区国产精品| 水蜜桃久久夜色精品一区| 亚洲成av在线| 一区二区三区视频免费观看| 国内精品福利| 国产手机视频一区二区| 日韩中文av| 国产精品欧美在线观看| 国产一区二区久久久久| 日韩一区二区三区免费播放| 亚洲高清二区| 亚洲日本国产| 国产精品成人**免费视频| 久久尤物视频| 99精品美女| 亚洲欧洲专区| 精品国产乱码久久久久久樱花| 精品美女视频| 久久青草久久| 亚洲影视一区二区三区| 国产精品第十页| 日韩不卡在线| 视频一区在线视频| 欧美日韩亚洲三区| 精品国产欧美日韩| 国模 一区 二区 三区| 日韩精品一区二区三区中文在线 | 久久av影视| 亚洲精品一级二级| 亚洲一卡久久| 国产精品最新| 999久久久91| 亚洲免费福利一区| 国产一区二区三区91| 99在线精品视频在线观看| 久久精品99久久久| 久久精品高清| 日韩高清一级| 一区二区三区四区日本视频| 99国产精品久久久久久久成人热| 日韩av三区| 久久人人97超碰国产公开结果| 亚洲人成在线影院| 日韩av有码| 黑丝一区二区| 国产精品1luya在线播放| 婷婷丁香综合| 久久久91麻豆精品国产一区| 伊人久久婷婷| 精品一区二区三区中文字幕 | 国产乱码午夜在线视频| 久久99伊人| 国产美女高潮在线观看| 男人操女人的视频在线观看欧美| 麻豆精品在线视频| 久久都是精品| 麻豆成人av在线| 国产精品三上| 国产一区二区视频在线看| 免费黄网站欧美| 97在线精品| 日本久久一区| av亚洲免费| 麻豆国产精品| 亚洲精品少妇| 不卡中文一二三区| 精品国产一区二区三区噜噜噜| 免费在线观看精品|