python实现图像的理想滤波器、butterworth滤波器、指数滤波器

python实现图像的理想滤波器、butterworth滤波器、指数滤波器1.傅里叶变换图像的频率滤波是基于傅里叶变换的,通过二维傅里叶变换把图像从空域转换到频域,对频域的图像的频率进行操作,比如限制某个频率范围的像素通过。(1)傅里叶变换其中离散傅里叶变换为:(2)傅里叶逆变换其中离散傅里叶逆变换为:(3)傅里叶变换性质上述傅里叶变换均为一维傅里叶变换,然而图像中为二维的傅里叶变换,因此我们可以分别在行方向和列方向分别做傅里叶变换,:2.频域滤波频域滤波的基本流程如下傅…

大家好,欢迎来到IT知识分享网。

1.傅里叶变换

图像的频率滤波是基于傅里叶变换的,通过二维傅里叶变换把图像从空域转换到频域,对频域的图像的频率进行操作,比如限制某个频率范围的像素通过。

(1)傅里叶变换

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

其中离散傅里叶变换为:

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 

(2)傅里叶逆变换

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

其中离散傅里叶逆变换为:

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 

        (3)傅里叶变换性质

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 上述傅里叶变换均为一维傅里叶变换,然而图像中为二维的傅里叶变换,因此我们可以分别在行方向和列方向分别做傅里叶变换,

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 2.频域滤波

频域滤波的基本流程如下

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 傅里叶变换一般要中心化,根据二维傅里叶的平移性质:

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 我们只需要对变换后的图像像素乘以\left ( -1 \right )^{x+y}就可以进行中心化和去中心化:

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

3.常用滤波器

  (1)理想滤波器

理想低通滤波器

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 


理想高通滤波器

 

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 

 (2)butterwoth滤波器

butterwoth低通滤波器:

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

 


butterwoth高通滤波器:

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

(3)指数滤波器

指数低通滤波 :

 

python实现图像的理想滤波器、butterworth滤波器、指数滤波器


指数高通滤波: 

 

python实现图像的理想滤波器、butterworth滤波器、指数滤波器

4.python实现

import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt

def filter(img, D0, W=None, N=2, type='lp', filter='butterworth'):
    '''
    频域滤波器
    Args:
        img: 灰度图片
        D0: 截止频率
        W: 带宽
        N: butterworth和指数滤波器的阶数
        type: lp, hp, bp, bs即低通、高通、带通、带阻
        filter:butterworth、ideal、exponential即巴特沃斯、理想、指数滤波器

    Returns:
        imgback:滤波后的图像

    '''

    #离散傅里叶变换
    dft=cv.dft(np.float32(img),flags=cv.DFT_COMPLEX_OUTPUT)
    #中心化
    dtf_shift=np.fft.fftshift(dft) 

    rows,cols=img.shape 
    crow,ccol=int(rows/2),int(cols/2) #计算频谱中心
    mask=np.ones((rows,cols,2)) #生成rows行cols列的2纬矩阵
    for i in range(rows):
        for j in range(cols):
            D = np.sqrt((i-crow)**2+(j-ccol)**2)
            if(filter.lower() == 'butterworth'):
                if(type == 'lp'):
                    mask[i, j] = 1/(1+(D/D0)**(2*N))
                elif(type == 'hp'):
                    mask[i, j] = 1/(1+(D0/D)**(2*N))
                elif(type == 'bs'):
                    mask[i, j] = 1/(1+(D*W/(D**2-D0**2))**(2*N))
                elif(type == 'bp'):
                    mask[i, j] = 1/(1+((D**2-D0**2)/D*W)**(2*N))
                else:
                    assert('type error')
            elif(filter.lower() == 'ideal'): #理想滤波器
                if(type == 'lp'):
                    if(D > D0):
                        mask[i, j] = 0
                elif(type == 'hp'):
                    if(D < D0):
                        mask[i, j] = 0
                elif(type == 'bs'):
                    if(D > D0 and D < D0+W):
                        mask[i, j] = 0
                elif(type == 'bp'):
                    if(D < D0 and D > D0+W):
                        mask[i, j] = 0
                else:
                    assert('type error')
            elif(filter.lower() == 'exponential'): #指数滤波器
                if(type == 'lp'):
                    mask[i, j] = np.exp(-(D/D0)**(2*N))
                elif(type == 'hp'):
                    mask[i, j] = np.exp(-(D0/D)**(2*N))
                elif(type == 'bs'):
                    mask[i, j] = np.exp(-(D*W/(D**2 - D0**2))**(2*N))
                elif(type == 'bp'):
                    mask[i, j] = np.exp(-((D**2 - D0**2)/D*W)**(2*N))
                else:
                    assert('type error')
            
    fshift = dtf_shift*mask

    f_ishift=np.fft.ifftshift(fshift) 
    img_back=cv.idft(f_ishift) 
    img_back=cv.magnitude(img_back[:,:,0],img_back[:,:,1]) #计算像素梯度的绝对值
    img_back=np.abs(img_back)
    img_back=(img_back-np.amin(img_back))/(np.amax(img_back)-np.amin(img_back))

    return img_back

img=cv.imread('lena.jpg',0)
plt.subplot(121),plt.imshow(img,cmap='gray'),plt.title('origin image')
img_back = filter(img, 30, type='hp')
plt.subplot(122),plt.imshow(img_back,cmap='gray'),plt.title('after butterworth highpass filter image')
plt.show()

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/12338.html

(0)
上一篇 2024-03-14 19:00
下一篇 2024-03-16 07:00

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信