亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python+OpenCV 實(shí)現(xiàn)簡(jiǎn)單的高斯濾波(推薦)

 更新時(shí)間:2021年09月18日 15:31:16   作者:林林zonzon  
這篇文章主要介紹了Python+OpenCV 實(shí)現(xiàn)簡(jiǎn)單的高斯濾波,在文中需要注意的是,這里我沒有特判當(dāng)sigma = 0的時(shí)候的情況,具體實(shí)現(xiàn)過(guò)程跟隨小編一起看看吧

基本原理講解:高斯模糊的算法

高斯核函數(shù)的編寫:構(gòu)建權(quán)重矩陣,采用高斯二維分布函數(shù)的形式進(jìn)行處理。需要注意的是,這里我沒有特判當(dāng)sigma = 0的時(shí)候的情況。

即是實(shí)現(xiàn):

1)權(quán)重矩陣的構(gòu)建

        根據(jù)公式:

 計(jì)算矩陣內(nèi)部結(jié)構(gòu),其中因?yàn)橐M(jìn)行歸一化處理,e前方的系數(shù)會(huì)被約去,因此代碼中不體現(xiàn)。

2)矩陣元素歸一化處理

        計(jì)算矩陣內(nèi)部元素總和sum,最后做矩陣除法得到歸一化處理后的權(quán)重矩陣。

# 高斯核生成函數(shù) kernel_size:濾波核大小  sigma:高斯核函數(shù)的局部影響范圍
def gauss(kernel_size, sigma):
    #定型0填充
    kernel = np.zeros((kernel_size, kernel_size))
    #確定正態(tài)分布中間值
    center = kernel_size // 2
    # s:方差 sum:記錄總和
    s = sigma ** 2
    sum = 0
    for i in range(kernel_size):
        for j in range(kernel_size):
            #由于最后要進(jìn)行歸一化處理,此處根號(hào)下2Π計(jì)算可以省略
            x, y = i - center, j - center
            kernel[i, j] = np.exp(-(x ** 2 + y ** 2) / (2 * s))
            sum += kernel[i, j]
    #歸一化處理后輸出
    kernel = kernel / sum
    return kernel

濾波函數(shù)的編寫:將圖片中的每個(gè)像素點(diǎn)(邊緣除外)及其周圍像素乘以權(quán)重矩陣,實(shí)現(xiàn)高斯濾波

 需要注意的是此函數(shù)僅能處理彩色圖片,因?yàn)橹挥胁噬珗D片擁有img.shape[2]元素,灰度圖片沒有img.shape[2]元素不能用這個(gè)方法處理。

# 高斯濾波實(shí)現(xiàn),img:輸入圖像 kermel:輸入高斯核函數(shù)
def myfilter(img,kernel):
    # 讀取img行數(shù)核列數(shù)
    h = img.shape[0]
    w = img.shape[1]
    # 直接拷貝父對(duì)象
    img1 = copy.copy(img)
    # 去掉邊緣
    for i in range(1,h-1):
        for j in range(1,w-1):
            # 三通道處理
            for c in range(0,2):
                sum = 0
                # 加權(quán)
                for k in range(-1,2):
                    for l in range(-1,2):
                        sum += img[i+k,j+l,c]*kernel[k+1,l+1]
                img1[i,j,c] = sum
    return img1

同時(shí)在處理高斯濾波的時(shí)候,函數(shù)采取的是針對(duì)3*3的kernel_size進(jìn)行編寫的,要更改kernel_size的大小,需要更改此處的range范圍。 

 下面是灰度圖像的處理方式:

def myfilter2(img,kernel):
    # 讀取img行數(shù)核列數(shù)
    h = img.shape[0]
    w = img.shape[1]
    # 直接拷貝父對(duì)象
    img1 = copy.copy(img)
    # 去掉邊緣
    for i in range(1,h-1):
        for j in range(1,w-1):
            sum = 0
            for k in range(-1,2):
                for l in range(-1,2):
                    sum += img[i+k,j+l]*kernel[k+1,l+1]
            img1[i,j] = sum
    return img1

 最后整個(gè)運(yùn)行代碼:

import copy
import cv2
import numpy as np
#圖像讀取
img_y = cv2.imread('p2.jpg')
# 選擇高斯生成函數(shù)3*3,其中sigama = 3
kernel = gauss(3,3)
# 打印這個(gè)生成函數(shù)
print(kernel)
# 高斯濾波處理
img1 = myfilter(img_y, kernel)
cv2.imshow('P1_yuantu',img_y)
cv2.imshow('P1_gaussian', img1)
cv2.waitKey(0)

 輸入輸出圖像結(jié)果展示:

原圖與高斯濾波后

需要注意的是采取的方法很原始,如果輸入的圖像過(guò)大,運(yùn)行時(shí)間會(huì)很久。

這方面東西挺有意思的,只是初略的學(xué)習(xí),寫些基礎(chǔ)的東西,應(yīng)該還有錯(cuò)漏的地方,希望有大佬們多多指點(diǎn)。

到此這篇關(guān)于Python+OpenCV 實(shí)現(xiàn)簡(jiǎn)單的高斯濾波的文章就介紹到這了,更多相關(guān)Python OpenCV 高斯濾波內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python如何讀取base64圖片數(shù)據(jù)

    Python如何讀取base64圖片數(shù)據(jù)

    在Python中,使用base64模塊可以解碼Base64編碼的圖片數(shù)據(jù),首先需要去除Base64字符串的前綴,然后使用base64.b64decode()函數(shù)進(jìn)行解碼,最后將解碼后的數(shù)據(jù)保存為圖片文件,適用于各種MIME類型的Base64編碼
    2024-09-09
  • numpy中np.dstack()、np.hstack()、np.vstack()用法

    numpy中np.dstack()、np.hstack()、np.vstack()用法

    numpy里dstack, hstack, vstack, 都有拼接的作用,本文詳細(xì)的介紹了np.dstack()、np.hstack()、np.vstack()用法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 利用python實(shí)現(xiàn)PSO算法優(yōu)化二元函數(shù)

    利用python實(shí)現(xiàn)PSO算法優(yōu)化二元函數(shù)

    這篇文章主要介紹了python實(shí)現(xiàn)PSO算法優(yōu)化二元函數(shù)的代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Win7 64位下python3.6.5安裝配置圖文教程

    Win7 64位下python3.6.5安裝配置圖文教程

    這篇文章主要為大家詳細(xì)介紹了Win7 64位下python3.6.5安裝配置的圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • 使用Python實(shí)現(xiàn)with結(jié)構(gòu)的@contextmanager方法詳解

    使用Python實(shí)現(xiàn)with結(jié)構(gòu)的@contextmanager方法詳解

    這篇文章主要介紹了使用Python實(shí)現(xiàn)with結(jié)構(gòu)的@contextmanager方法詳解,這個(gè)結(jié)構(gòu)的好處,一個(gè)是簡(jiǎn)潔,一個(gè)是當(dāng)我們對(duì)文件操作的邏輯很長(zhǎng)的時(shí)候,不會(huì)因?yàn)橥岁P(guān)閉文件而造成不必要的錯(cuò)誤,需要的朋友可以參考下
    2023-07-07
  • python?字符串索引取值的實(shí)現(xiàn)示例

    python?字符串索引取值的實(shí)現(xiàn)示例

    本文主要介紹了python?字符串索引取值的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Python編程快速上手——選擇性拷貝操作案例分析

    Python編程快速上手——選擇性拷貝操作案例分析

    這篇文章主要介紹了Python選擇性拷貝操作,結(jié)合具體實(shí)例形式分析了Python文件遍歷、查找、復(fù)制拷貝等相關(guān)操作技巧,需要的朋友可以參考下
    2020-02-02
  • 在python中解決死鎖的問(wèn)題

    在python中解決死鎖的問(wèn)題

    這篇文章主要介紹了在python中解決死鎖的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • Python logging模塊用法示例

    Python logging模塊用法示例

    這篇文章主要介紹了Python logging模塊用法,結(jié)合實(shí)例形式分析了Python logging模塊相關(guān)配置、函數(shù)、組件等操作方法與注意事項(xiàng),需要的朋友可以參考下
    2018-08-08
  • 關(guān)于 Python opencv 使用中的 ValueError: too many values to unpack

    關(guān)于 Python opencv 使用中的 ValueError: too many values to unpack

    這篇文章主要介紹了關(guān)于 Python opencv 使用中的 ValueError: too many values to unpack,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-06-06

最新評(píng)論