第4章 Python 数字图像处理(DIP) - 频率域滤波8 - 二维DFT和IDFT的一些性质 - 二维离散卷积定理

目录

    • 二维DFT和IDFT的一些性质
      • 二维离散卷积定理
      • 二维离散傅里叶变换性质的小结

二维DFT和IDFT的一些性质

二维离散卷积定理

二维循环卷积表达式:
(f⋆h)(x,y)=∑m=0M−1∑n=0N−1f(m,n)h(x−m,y−n)(4.94)(f \star h)(x, y) = \sum_{m=0}^{M-1} \sum_{n=0}^{N-1} f(m,n)h(x-m, y-n) \tag{4.94}(fh)(x,y)=m=0M1n=0N1f(m,n)h(xm,yn)(4.94)

二维卷积定理为:
(f⋆h)(x,y)⇔(F∙H)(u,v)(4.95)(f \star h)(x, y) \Leftrightarrow (F\bullet H)(u, v) \tag{4.95}(fh)(x,y)(FH)(u,v)(4.95)

(f∙h)(x,y)⇔1MN(F⋆H)(u,v)(4.96)(f \bullet h)(x, y) \Leftrightarrow \frac{1}{MN}(F\star H)(u, v) \tag{4.96}(fh)(x,y)MN1(FH)(u,v)(4.96)

fffhhh的空间卷积的傅里叶变换,是它们的变换的乘积。

空间卷积是空间域滤波的基础,式(4.95)是在空间域和频率域滤波之间建立等价关系的纽带。

# 一维卷积与一维傅里叶变换
f = np.zeros([400])
f[:300] = 3h = np.zeros([f.shape[0]])
h[:200] = 2# 卷积
F_con = np.convolve(f, h)# 傅里叶变换,未填充零的结果
f_fft = np.fft.fft(f)
f_fft = np.fft.fftshift(f_fft)
h_fft = np.fft.fft(h)
h_fft = np.fft.fftshift(h_fft)fh_fft = f_fft * h_fft# 傅里叶反变换
fh_ifft = np.abs(np.fft.ifft(fh_fft))fig = plt.figure(figsize=(12, 6))
plt.subplot(2, 2, 1), plt.plot(f), plt.ylim([0, 5]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400]), plt.title('f')
plt.subplot(2, 2, 2), plt.plot(h), plt.ylim([0, 5]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400]), plt.title('h')
plt.subplot(2, 2, 3), plt.plot(F_con), plt.ylim([0, 2000]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400, 600, 800]), 
plt.title('Convolution')
plt.subplot(2, 2, 4), plt.plot(fh_ifft), plt.ylim([0, 2000]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400, 600, 800]), 
plt.title('IFFT')
plt.tight_layout()
plt.show()

在这里插入图片描述
从上图可以看出,卷积与傅里叶变换的结果不一样,这种错误可以通过对原函数填充零来纠正。要使得它们的长度PPP相同,则有
P≥A+B−1(4.97)P \ge A + B - 1 \tag{4.97}PA+B1(4.97)

从下面的结果可以看出,直接的零填充得到的结果跟卷积是一样的。镜像和复制的填充结果不太一样。

二维填充的公式:
fP(x,y)={f(x,y),0≤x≤A−1和0≤y≤B−10,A≤x≤P或B≤y≤Q(4.98)f_P(x, y) = \begin{cases} f(x, y), & 0 \leq x \leq A -1和 0 \leq y \leq B-1 \\ 0, & A \leq x \leq P 或 B \leq y \leq Q \end{cases} \tag{4.98}fP(x,y)={f(x,y),0,0xA10yB1AxPByQ(4.98)

hP(x,y)={h(x,y),0≤x≤C−1和0≤y≤D−10,C≤x≤P或D≤y≤Q(4.99)h_P(x, y) = \begin{cases} h(x, y), & 0 \leq x \leq C -1和 0 \leq y \leq D-1 \\ 0, & C \leq x \leq P 或 D \leq y \leq Q \end{cases} \tag{4.99}hP(x,y)={h(x,y),0,0xC10yD1CxPDyQ(4.99)

P≥A+C−1(4.100)P \ge A + C - 1 \tag{4.100}PA+C1(4.100)
Q≥B+D−1(4.101)Q \ge B + D - 1 \tag{4.101}QB+D1(4.101)

DFT算法通过偶数大小的阵列时速度通常更快,因此经常选择PPPQQQ的最小偶数整数。

如果两个阵列大小相同,则意味着
P=2M(4.102)P = 2M \tag{4.102}P=2M(4.102)

Q=2N(4.103)Q = 2N \tag{4.103}Q=2N(4.103)

在两个函数中,如果有一个或两个函数的值在取样区间的末尾不是0,那么把0添加到函数中来消除交叠错误时,会导致函数不连续。这类似于用一个盒式函数来乘以一下函数,在频率域是这一相乘意味着原变换与一个sinc\text{sinc}sinc函数的卷积,进行导致由sinc\text{sinc}sinc函数的高频分量产生所谓的频率泄露
频率泄露会使得图像块效应。

开窗或切趾法

  • 降低工频率泄漏的方法,就是让取样后的函数乘以另一个两端平滑地过渡到0的函数(窗函数)
# 傅里叶变换,填充堆的结果
f_pad = np.zeros([800])
f_pad[:400] = f
h_pad = np.zeros([800])
h_pad[:400] = h
f_fft = np.fft.fft(f_pad)
f_fft = np.fft.fftshift(f_fft)
h_fft = np.fft.fft(h_pad)
h_fft = np.fft.fftshift(h_fft)fh_fft = f_fft * h_fft# 傅里叶反变换
fh_ifft = np.abs(np.fft.ifft(fh_fft))fig = plt.figure(figsize=(12, 6))
plt.subplot(2, 2, 1), plt.plot(f_pad), plt.ylim([0, 5]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400]), plt.title('f pad 0')
plt.subplot(2, 2, 2), plt.plot(h_pad), plt.ylim([0, 5]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400]), plt.title('h pad 0')
plt.subplot(2, 2, 3), plt.plot(F_con), plt.ylim([0, 2000]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400, 600, 800]), 
plt.title('Convolution')
plt.subplot(2, 2, 4), plt.plot(fh_ifft), plt.ylim([0, 2000]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400, 600, 800]), 
plt.title('IFFT')
plt.tight_layout()
plt.show()

在这里插入图片描述

# 傅里叶变换,镜像
f_pad = np.zeros([800])
f_pad = np.pad(f, (400, 0), mode='reflect')
# f_pad = np.
h_pad = np.zeros([800])
h_pad = np.pad(h, (400, 0), mode='reflect')f_fft = np.fft.fft(f_pad)
f_fft = np.fft.fftshift(f_fft)
h_fft = np.fft.fft(h_pad)
h_fft = np.fft.fftshift(h_fft)fh_fft = f_fft * h_fft# 傅里叶反变换
fh_ifft = np.abs(np.fft.ifft(fh_fft))
fh_ifft = 2394 - fh_ifft
fig = plt.figure(figsize=(12, 6))
plt.subplot(2, 2, 1), plt.plot(f_pad), plt.ylim([0, 5]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400]), plt.title('f pad 0')
plt.subplot(2, 2, 2), plt.plot(h_pad), plt.ylim([0, 5]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400]), plt.title('h pad 0')
plt.subplot(2, 2, 3), plt.plot(F_con), plt.ylim([0, 2000]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400, 600, 800]), 
plt.title('Convolution')
plt.subplot(2, 2, 4), plt.plot(fh_ifft), plt.ylim([0, 2000]), plt.xlim([0, 1000]), plt.xticks([0, 200, 400, 600, 800]), 
plt.title('IFFT')
plt.tight_layout()
plt.show()

在这里插入图片描述

二维离散傅里叶变换性质的小结

名称 表达式
f(x,y)f(x, y)f(x,y)的DFTF(u,v)=∑x=0M−1∑y=0N−1f(x,y)e−j2π(ux/M+vy/N)F(u, v) = \sum_{x = 0}^{M - 1} \sum_{y = 0}^{N - 1} f(x, y) e^{-j2\pi(u x/M + v y /N)}F(u,v)=x=0M1y=0N1f(x,y)ej2π(ux/M+vy/N)
F(u,v)F(u, v)F(u,v)的IDFTf(x,y)=1MN∑u=0M−1∑v=0N−1F(u,v)ej2π(ux/M+vy/N)f(x, y) = \frac{1}{MN}\sum_{u = 0}^{M - 1} \sum_{v = 0}^{N - 1} F(u, v) e^{j2\pi(u x /M + vy /N)}f(x,y)=MN1u=0M1v=0N1F(u,v)ej2π(ux/M+vy/N)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/260709.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jmeter中重定向多个正则表达式_2020年jmeter技术实战续集,最新技术全栈,值得收藏

在上一篇:主要介绍线程组、HTTP请求默认值、用户定义的变量、固定定时器的应用场景及实战。以下主要介绍正则表达式提取器、调式取样器(Debug Sampler)、响应断言、HTTP信息头管理器的应用场景及实战。一、正则表达式提取器1、使用场景从请求的响应结果中取到需要的…

[置顶] 均衡音效

[置顶] 均衡音效 1均衡的作用 均衡器是一种可以分别调节各种频率成分电信号放大量的电子设备,通过对各种不同频率的电信号的调节来补偿扬声器和声场的缺陷,补偿和修饰各种声源及其它特殊作用。具体来说,它的作用如下: &#xff08…

html5之web worker

Web Worker 在本文中 与 Web Worker 进行双向通信WindowTimers在 IE10 Platform Preview 4 中对 Web Worker 的更新API 参考示例和教程有关 Internet Explorer 的 Test Drive 演示IEBlog 文章规范相关主题Internet Explorer 10 和使用 JavaScript 的 Windows 应用商店应用引入了…

第4章 Python 数字图像处理(DIP) - 频率域滤波9 - 频率域滤波基础、频率域的滤波过程、低通、高通

目录频率域滤波基础频率域的其他特性频率域滤波基础知识频率域滤波步骤小结空间域和频率域滤波之间的对应关系频率域滤波基础 频率域的其他特性 频率域中的滤波过程如下: 首先修改傅里叶变换以在到特定目的然后计算IDFT,返回到空间域 # 频率域中的其…

C# :试玩EventLog

1. 专门创建Source的Log   创建了Source,log显示在 Event viewer/Applications and Services logs/ 自定义Source 中,待遇比较高,专门显示的。 创建Source需要管理员身份,否则Crash。 如果已经打开了 Computer Management,请关闭…

css 宋体_Java前端基础(一)之html/css

1.1 htmlHTML:超文本标记语言(Hyper Text Markup Language),标准通用标记语言下的一个应用。HTML 不是一种编程语言,而是一种标记语言 (markup language),是网页制作所必备的WEB开发工具:hbuilder/webstorm/vs code/eclpise最简单…

View Controller Programming Guide for iOS---(七)---Resizing the View Controller’s Views

Resizing the View Controller’s Views A view controller owns its own view and manages the view’s contents. In the process, the view controller also manages the view’s subviews. But in most cases, the view’s frame is not set directly by the view controll…

基于百度地图js进行地理定位

http://www.mengxiangchaoren.com/jquery.select.position.min.js 使用方法 $("#myCity").renderSelect({posByGps:true,bdAk:BD_AK});转载于:https://www.cnblogs.com/Brose/p/jquery_select_position.html

C#接口-接口作用

C#接口是一个让很多初学C#者容易迷糊的东西,用起来好像很简单,定义接口,里面包含方法,但没有方法具体实现的代码,然后在继承该接口的类里面要实现接口的所有方法的代码,但没有真正认识到接口的作用的时候就…

gpio的8种工作模式_Stm32之GPIO工作模式简介

GPIO的8种工作模式GPIO初始化结构体的时候,必须要配置合适的工作模式,这样才能使得IO口发挥应有的作用。工作模式大体上共分为输入输出两类,共8种,下面将介绍这8种工作模式。GPIO工作模式输入模式GPIO_Mode_AIN 模拟输入 GPIO_Mod…

vagrant,流浪汉,我又来啦。

最近学个DEVOPS2.0,讲微服务,容器华,持续部署,很到位,就一个一个工具撸一撸。。。 vagrant,以前接触过,所以上手快,,哈哈,,用时再具体配置。 virt…

dedecms最新版本修改任意管理员漏洞

此漏洞无视gpc转义,过80sec注入防御。 补充下,不用担心后台找不到。这只是一个demo,都能修改任意数据库了,还怕拿不到SHELL? 起因是全局变量$GLOBALS可以被任意修改,随便看了下,漏洞一堆&#x…

第4章 Python 数字图像处理(DIP) - 频率域滤波10 - 使用低通频率域滤波器平滑图像 - 理想、高斯、巴特沃斯低通滤波器

目录使用低通频率域滤波器平滑图像理想低通滤波器(ILPF)高斯低通滤波器(GLPF)巴特沃斯低通滤波器低通滤波的例子使用低通频率域滤波器平滑图像 理想低通滤波器(ILPF) 在以原点为中心的一个圆内无衰减地通过所有频率,而在这个圆外“截止”所有的频率的二维低通滤波…

vs2008中combox用法总结

1、判断是否为空 m_CheckPoint.GetCurSel()-1; 2、清空 m_CheckPoint.ResetContent(); 3、添加 m_CheckPoint.AddString(str); 4、获取某一索引的值 m_CheckPoint.GetLBText(j,str1);//j为索引,str1为存储变量 5、删除某一索引的值 m_CheckPoint.DeleteString(j);//…

bluecam连接步骤说明_厂家详解旋片式真空泵使用说明

旋片式真空泵是有区分单双极高速直联结构的真空泵,是用来对密封容器抽除气体的基本设备之一。旋片式真空泵的泵与电机连轴,有着高转速、外型小、结构紧凑、流动性工作方便的优点。本文所使用旋片式真空泵使用说明资料,是台冠真空泵技术团队工…

python函数中可变参数的传递方式是_Python函数可变参数定义及其参数传递方式实例详解...

本文实例讲述了Python函数可变参数定义及其参数传递方式。分享给大家供大家参考。具体分析如下: python中 函数不定参数的定义形式如下: 1、func(*args) 传入的参数为以元组形式存在args中,如: def func(*args): print args >&…

加载中做法

一个网页在加载时,可给静态部分加个加载中,而动态部分也即是真正内容用jq来改,这样就有那个效果了转载于:https://www.cnblogs.com/yedeying/p/3618815.html

Junit4常用注解

Junit4注解 JUnit4的测试类不用再继承TestCase类了。使用注解会方便很多。 Before:初始化方法After:释放资源Test:测试方法,在这里可以测试期望异常和超时时间Ignore:忽略的测试方法BeforeClass:针对所有测…

第4章 Python 数字图像处理(DIP) - 频率域滤波11 - 使用高通滤波器锐化图像

目录使用高通滤波器锐化图像由低通滤波器得到理想、高斯和巴特沃斯高通滤波器指纹增强频域中的拉普拉斯钝化掩蔽、高提升滤波和高频强调滤波同态滤波使用高通滤波器锐化图像 由低通滤波器得到理想、高斯和巴特沃斯高通滤波器 HHP(u,v)1−HLP(u,v)(4.118)H_{HP}(u, v) 1 - H_{…

值类型 引用类型 堆栈 堆 之 异想

看了很多值类型 和 引用类型的文章(谷歌能搜索出来的)看了越多疑问越大,而这些资料中没有具体的说明。问题:1、堆栈 和 堆 分别存于计算机的哪个硬件(CPU缓存,内存,硬盘)&#xff1f…