OpenCV實現(xiàn)圖像平滑處理的方法匯總
本文是OpenCV圖像視覺入門之路的第10篇文章,本文詳細的在圖像上面進行了圖像均值濾波、方框濾波 、高斯濾波、中值濾波、雙邊濾波、2D卷積等操作。

1 均值濾波
OpenCV 中的簡單濾波(例如均值濾波或中值濾波)可能會使圖像變得模糊,因為它們會平滑圖像中的細節(jié)和邊緣。如果濾波的程度過強,則可能會導致圖像失真,使其看起來更差。因此,濾波的程度需要適當?shù)乜刂?,以獲得最佳效果。
import cv2
import numpy as np
from numpy import unicode
if __name__ == '__main__':
img1 = cv2.imread("D:/Jupyter_Notebooks/0.jpg") # 讀取彩色圖像(BGR)
# 均值濾波
# 簡單的平均卷積操作
img_blur1 = cv2.blur(img1, (3, 3)) # 使用3*3的卷積核
img_blur2 = cv2.blur(img1, (30, 30)) # 使用30*30的卷積核
cv2.imshow("blur1", img_blur1) # 顯示疊加圖像 dst
cv2.imshow("blur2", img_blur2) # 顯示疊加圖像 dst
cv2.imshow("image", img1) # 顯示疊加圖像 dst
cv2.waitKey(0)
cv2.destroyAllWindows()

2 方框濾波
方框濾波是一種圖像平滑技術(shù),在 OpenCV 中可以使用。方框濾波的主要作用是對圖像進行去噪和平滑處理,使圖像變得更加平滑,減少圖像的鋸齒狀、噪聲等不規(guī)則的部分。在圖像處理中,方框濾波通常作為預處理步驟,以提高圖像的質(zhì)量和處理效果。
import cv2
import numpy as np
from numpy import unicode
if __name__ == '__main__':
img1 = cv2.imread("D:/Jupyter_Notebooks/0.jpg") # 讀取彩色圖像(BGR)
# 方框濾波
# 基本和均值一樣,可以選擇歸一化
img_box1 = cv2.boxFilter(img1, -1, (3, 3), normalize=True)
img_box2 = cv2.boxFilter(img1, -1, (2, 2), normalize=False)
cv2.imshow("box1", img_box1) # 顯示疊加圖像 dst
cv2.imshow("box2", img_box2) # 顯示疊加圖像 dst
cv2.imshow("image", img1) # 顯示疊加圖像 dst
cv2.waitKey(0)
cv2.destroyAllWindows()

3 高斯濾波
高斯濾波是圖像處理中一種常用的平滑處理方法。在使用OpenCV處理圖像時,高斯濾波可以用于減少圖像中的噪聲和模糊不清的細節(jié)。此外,它還可以用于圖像的邊緣檢測和圖像分割,因為高斯濾波能夠保留圖像的主要特征,同時去除小的干擾。
import cv2
import numpy as np
from numpy import unicode
if __name__ == '__main__':
img1 = cv2.imread("D:/Jupyter_Notebooks/0.jpg") # 讀取彩色圖像(BGR)
# 高斯濾波
# 高斯模糊的卷積核里的數(shù)值是滿足高斯分布,相當于更重視中間的
img_aussian1 = cv2.GaussianBlur(img1, (5, 5), 0, 0)
img_aussian2 = cv2.GaussianBlur(img1, (5, 5), 13, 13)
cv2.imshow("aussian1", img_aussian1) # 顯示疊加圖像 dst
cv2.imshow("aussian2", img_aussian2) # 顯示疊加圖像 dst
cv2.imshow("image", img1) # 顯示疊加圖像 dst
cv2.waitKey(0)
cv2.destroyAllWindows()

4 中值濾波
OpenCV 中值濾波是一種圖像去噪方法,它通過在圖像上選擇一個掩碼,并將其中的每個像素與周圍像素值進行比較,以計算該像素的新值。新值是該像素周圍像素值的中位數(shù)。這樣,中值濾波能夠有效去除圖像中的噪聲和椒鹽噪聲,使圖像更清晰、更加穩(wěn)定。
import cv2
import numpy as np
from numpy import unicode
if __name__ == '__main__':
img1 = cv2.imread("D:/Jupyter_Notebooks/0.jpg") # 讀取彩色圖像(BGR)
# 中值濾波
# 相當于用中值代替
img_median1 = cv2.medianBlur(img1, 3) # 中值濾波
img_median2 = cv2.medianBlur(img1, 9) # 中值濾波
cv2.imshow("median1", img_median1) # 顯示疊加圖像 dst
cv2.imshow("median2", img_median2) # 顯示疊加圖像 dst
cv2.imshow("image", img1) # 顯示疊加圖像 dst
cv2.waitKey(0)
cv2.destroyAllWindows()

5 雙邊濾波
雙邊濾波是一種圖像模糊技術(shù),它在保持圖像邊緣清晰的同時,對圖像中的噪聲進行有效去除。雙邊濾波算法通過比較圖像上相鄰像素的顏色差異和空間差異來確定每個像素的權(quán)重,從而決定每個像素的最終顏色值。在OpenCV中,雙邊濾波算法可用于處理圖像的模糊、去噪、抗抖動等問題。
均值濾波、方框濾波、高斯濾波、中值濾波都是只單純的考慮了像素點之間的空間信息而進行濾波的方式,這些方式都或多或少都會模糊圖像的邊緣信息,就是把圖像里面的邊緣線條弄模糊了,就是在去除圖像噪音的同時把圖像也弄模糊了,造成圖像邊界信息的部分丟失,這是這些方法的一個共同的缺點。
雙邊濾波就可以很好的規(guī)避這個缺點。因為雙邊濾波不僅考慮了像素的空間信息(距離越遠權(quán)重越小)同時還考慮了像素的色彩信息(色彩差別越大,權(quán)重越小),這樣就可以很好的去除噪聲還可以較好的保護邊緣信息,所以雙邊濾波器也是一個保邊去噪的濾波器。
import cv2
import numpy as np
from numpy import unicode
if __name__ == '__main__':
img1 = cv2.imread("D:/Jupyter_Notebooks/0.jpg") # 讀取彩色圖像(BGR)
img_bilateralFilter1 = cv2.bilateralFilter(img1, 15, 150, 1000)
img_bilateralFilter2 = cv2.bilateralFilter(img1, 3, 255, 1000)
cv2.imshow("bilateralFilter2", img_bilateralFilter2) # 顯示疊加圖像 dst
cv2.imshow("bilateralFilter1", img_bilateralFilter1) # 顯示疊加圖像 dst
cv2.imshow("image", img1) # 顯示疊加圖像 dst
cv2.waitKey(0)
cv2.destroyAllWindows()

6 2D卷積(自定義卷積核實現(xiàn)卷積)
OpenCV 中的 2D 卷積的作用是圖像濾波,它可以用來消除圖像中的噪聲、提取圖像的特征、邊緣檢測等。它通過對圖像中的每一個像素與一個固定的卷積核進行卷積操作來實現(xiàn)這些目的。
如果上面的均值濾波卷積核、方框濾波卷積核、高斯濾波卷積核、中值濾波卷積核、雙邊濾波卷積核都不能滿足我們對圖像的處理要求,此時我們就需要一個更加靈活的核——即我們自定義一個我們想要的核。如何實現(xiàn)呢?opencv中的cv2.filter2D()函數(shù)可以幫助我們實現(xiàn):
cv2.filter2D(img, ddepth, kernel, anchor, delta, borderType)
- img:要處理的原圖
- ddepth: 默認-1,表示與原圖圖像相同的深度
- kernel: 卷積核,是一個單通道的數(shù)組。如果想處理彩圖時,讓每個通道使用不同的核,就必須先將彩圖分解后再使用不同的核去卷積操作。
- anchor: 默認值是(-1,-1),默認計算的結(jié)果位于核的中心位置。
- delta:這個參數(shù)可寫可不寫。如果寫,表示在卷積操作時,對應位置相乘相加后再加一個偏置,這個偏置就是delta。
- borderType: 邊界處理方式,一般用默認值即可。
import cv2
import numpy as np
from numpy import unicode
if __name__ == '__main__':
img1 = cv2.imread("D:/Jupyter_Notebooks/0.jpg") # 讀取彩色圖像(BGR)
kernel = np.ones((9, 9), np.float32) / 81 # 在實際中我們可以定義更復雜的卷積核,以實現(xiàn)自定義濾波操作
img_kernel1 = cv2.filter2D(img1, -1, kernel) # 這個濾波器就相當于均值濾波
kernel = np.ones((18, 18), np.float32) / 81 # 在實際中我們可以定義更復雜的卷積核,以實現(xiàn)自定義濾波操作
img_kernel2 = cv2.filter2D(img1, -1, kernel) # 這個濾波器就相當于均值濾波
cv2.imshow("kernel1", img_kernel1) # 顯示疊加圖像 dst
cv2.imshow("kernel2", img_kernel2) # 顯示疊加圖像 dst
cv2.imshow("image", img1) # 顯示疊加圖像 dst
cv2.waitKey(0)
cv2.destroyAllWindows()

以上就是OpenCV實現(xiàn)圖像平滑處理的方法匯總的詳細內(nèi)容,更多關(guān)于OpenCV圖像平滑處理的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python二分法查找算法實現(xiàn)方法【遞歸與非遞歸】
這篇文章主要介紹了python二分法查找算法實現(xiàn)方法,結(jié)合實例形式分析了Python使用遞歸與非遞歸算法實現(xiàn)二分查找的相關(guān)操作技巧,需要的朋友可以參考下2019-12-12
利用Pandas 創(chuàng)建空的DataFrame方法
下面小編就為大家分享一篇利用Pandas 創(chuàng)建空的DataFrame方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04
用Python從0開始實現(xiàn)一個中文拼音輸入法的思路詳解
中文輸入法是一個歷史悠久的問題,但也實在是個繁瑣的活,不知道這是不是網(wǎng)上很少有人分享中文拼音輸入法的原因,接下來通過本文給大家分享使用Python從0開始實現(xiàn)一個中文拼音輸入法,需要的朋友可以參考下2019-07-07
python實現(xiàn)從本地攝像頭和網(wǎng)絡攝像頭截取圖片功能
這篇文章主要介紹了python實現(xiàn)從本地攝像頭和網(wǎng)絡攝像頭截取圖片功能 ,文中給大家提到了python , opencv 打開網(wǎng)絡攝像頭讀取圖像的實現(xiàn)代碼,需要的朋友可以參考下2019-07-07

