频率域滤波图像复原之逆滤波的python实现——数字图像处理

逆滤波原理

逆滤波是一种在频率域进行的图像复原技术,常用于修复由运动模糊等因素引起的图像退化。具体步骤如下:

**频率域表示:**首先,将退化的图像通过傅里叶变换从空间域转换到频率域。这使得图像的频率成分变得明显,便于分析和处理。

**退化模型识别:**在频率域中,图像退化通常可以表示为原始图像与某个退化函数(比如运动模糊)的卷积。逆滤波需要识别这个退化函数,这通常需要一定的先验知识或假设。

**设计逆滤波器:**逆滤波器的设计基于退化函数的逆。如果已知或假设了退化函数的形式,那么可以计算其在频率域的逆。这个逆滤波器理论上可以完全抵消退化效果。

应用逆滤波器:将设计好的逆滤波器应用于退化图像。在频率域中,这通常表示为对退化图像的频率响应和逆滤波器的频率响应进行乘法操作。

逆傅里叶变换:处理完毕后,通过逆傅里叶变换将图像从频率域转换回空间域,得到复原后的图像。

然而,逆滤波也有其局限性。例如,当退化函数不是很精确时,或者图像包含噪声时,直接应用逆滤波可能会放大这些错误或噪声,导致复原效果不理想。因此,在实际应用中,逆滤波通常与其他技术(如威纳滤波)结合使用,以改善复原质量。

公式表示

设 H(u,v) 是已知的退化函数在频率域的表示,G(u,v) 是退化图像在频率域的表示,那么根据线性系统理论,退化过程可以表示为:
在这里插入图片描述
其中 ,F(u,v) 是原始图像在频率域的表示,N(u,v) 是加性噪声。
在理想情况下(忽略噪声),退化过程可以简化为:
G(u,v)=H(u,v)⋅F(u,v)

逆滤波的目的是通过逆转 H(u,v) 的影响来恢复 F(u,v)。如果 H(u,v) 是已知且没有零点,那么逆滤波器 H^-1 (u,v) 可以表示为:
在这里插入图片描述
因此,复原图像 F^ (u,v) 可以通过逆滤波器处理退化图像 G(u,v) 来获得:
在这里插入图片描述
最后,通过对 F^(u,v) 进行逆傅里叶变换,可以得到空间域中的复原图像。
需要注意的是,当 H(u,v) 接近或等于零的时候,上述逆滤波器会放大噪声,这是逆滤波的主要局限性之一。在实际应用中,为了避免这种情况,通常会对逆滤波器进行一定的修改或者使用其他更加稳健的复原方法。

python实现下图

在这里插入图片描述

提示

这是一幅经过参数k=0.0025的大气湍流模型退化后的图像,。结果依次显示用不同截止半径限制频率后逆滤波得到的结果。,限制滤波频率是通过对比值G(u,v)/H(u,v)应用一个阶数为10的巴特沃斯低通函数来实现的,4幅结果图的截止频率分别为float(“inf”)(对应着全滤波)、40、60、70。

python代码

 import cv2
import numpy as np
from matplotlib import pyplot as pltimg = cv2.imread('Fig0525.tif', 0)
rows = img.shape[0]
cols = img.shape[1]Cx = rows//2
Cy = cols//2dft = np.fft.fft2(img)
dft_shift = np.fft.fftshift(dft)img_list = []
img_name_list = []# 大气湍流模型的参数
k = 0.0025# 构造退化函数
H = np.zeros((rows, cols))
for x in range(rows):for y in range(cols):D = ((x - Cx) ** 2 + (y - Cy) ** 2) ** (5/6)H[x, y] = np.exp(-k * D)# 构造巴特沃斯低通滤波器
radius = [float("inf"), 40, 60, 70]
n = 10
for D0 in radius:HB = np.zeros((rows, cols))for x in range(rows):for y in range(cols):D = np.sqrt((x-Cx)**2 + (y-Cy)**2)HB[x, y] = 1 / (1 + (D/D0)**(2*n))dft_filtered = np.multiply(np.multiply(dft_shift, 1/H), HB)img_result = np.abs(np.fft.ifft2(np.fft.fftshift(dft_filtered)))img_list.append(img_result)img_name_list.append('r=' + str(D0))_, axs = plt.subplots(2, 2)for i in range(2):for j in range(2):axs[i, j].imshow(img_list[i * 2 + j], cmap='gray')axs[i, j].set_title(img_name_list[i * 2 + j])axs[i, j].axis('off')#plt.savefig('inverse_filter.jpg')
plt.show()

结果展示

在这里插入图片描述

总结

图像复原是一种客观的操作,通过使用退化现象的先验知识重建或恢复一副退化的图像;图像在形成、传输和记录的过程中,由于受多种原因的影响,图像的质量会有下降,典型表现为图像模糊、失真、有噪声等,这一降质的过程称为图像的退化。而图像复原试图利用退化现象的某种先验知识(即退化模型),把已经退化了的图像加以重建和复原。其目的就是尽可能地减少或去除在获取图像过程中发的图像质量的下降(退化),恢复被退化图像的本来面目。
逆滤波复原过程:对退化的图像进行二位傅里叶变换;计算系统点扩散函数的二位傅里叶变换;引入H(fx,fy)计算并且对结果进行逆傅里叶变换。
逆滤波:简单的就是将退化函数去除,直接的逆滤波没有什么意义,只处理了靠近直流分量的部分,其他不做处理。如果加入巴特沃斯低通滤波器,效果会好点,可是在运动模糊的图片中就不好使了。

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

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

相关文章

直流稳压电源电路

一、稳压电源的技术指标及对稳压电源的要求 稳压电源的技术指标可以分为两大类:一类是特性指标,如输出电压、输出电滤及电压调节范围;另一类是质量指标,反映一个稳压电源的优劣,包括稳定度、等效内阻(输出电阻&#x…

dyld: Library not loaded: /usr/lib/swift/libswiftCoreGraphics.dylib

更新Xcode14后低版本iPhone调试报错 dyld: Library not loaded: /usr/lib/swift/libswiftCoreGraphics.dylib Referenced from: /var/containers/Bundle/Application/…/….app/… Reason: image not found 这是缺少libswiftCoreGraphics库 直接导入libswiftCoreGraphics库即…

软件测试作业‖pytest+po+csv+html报告+cookie+selenium

软件测试作业‖pytestpocsvhtml报告cookieselenium 先用本地部署的系统试了下 或者UFT自动化测试里诺图书管理系统软件测试 # ,#测试报告# #性能测试#,#测试用例#, #自动化测试# Selenium 的 Web自动化测试基本要求和注意事项 1.请使用ch…

软件测试之单元测试、系统测试、集成测试知识总结

一、单元测试的概念 单元测试是对软件基本组成单元进行的测试,如函数或一个类的方法。当然这里的基本单元不仅仅指的是一个函数或者方法,有可能对应多个程序文件中的一组函数。 单元也具有一些基本的属性。比如:明确的功能、规格定义&#…

phpstudy面板Table ‘mysql.proc‘ doesn‘t exist解决办法

原因分析:误删了mysql数据库 解决办法如下: 1、停止服务 2、先把mysql文件夹下的data文件夹备份,因为data文件里存有数据库文件。然后再删除data文件。 3、cmd管理员命令进入到mysql中的bin目录下 ,执行mysqld --initialize-…

2024--Django平台开发-基础信息(一)

一、前置知识点 - Python环境搭建 (Python解释器、Pycharm、环境变量等) - 基础语法(条件、循环、输入输出、编码等) - 数据类型(整型、布尔型、字符串、列表、字典、元组、集合等) - 函数(文件操作、返回值、参数、作用域等) - 面向对象 (类、对象、封装、继承、多态等)包和模…

Vue3-39-路由-导航异常的检测 afterEatch 与 编程式导航之后的订阅动作

说明 本文主要是介绍一下 路由的后置守卫 afterEatch 的一个重要的作用 : 就是检测路由异常信息。 它的实现方式是 通过第三个参数来返回的。 而且,它的异常检测是全局的。导航的异常有以下三种类型: aborted : 在导航守卫中 被拦截并返回了…

certbot https 证书配置

服务器上敲这个命令 certbot certonly --manual --preferred-challenges dns -d 51dbapi.com,*.51dbapi.com会弹出这个。点击回车 然后去域名页面配置新的解析记录 就可以了,3个月搞一次,自动的没配成功过,就手动吧

HarmonyOS4.0系统性深入开发15Want概述

Want概述 Want的定义与用途 Want是对象间信息传递的载体,可以用于应用组件间的信息传递。其使用场景之一是作为startAbility()的参数,包含了指定的启动目标以及启动时需携带的相关数据,如bundleName和abilityName字段分别指明目标Ability所…

故障诊断 | 基于FFT频谱与小波时频图的双流CNN轴承故障诊断模型(matlab +python)

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 故障诊断 | 基于FFT频谱与小波时频图的双流CNN轴承故障诊断模型(matlab python) 基于FFT频谱与小波时频图的双流CNN轴承故障诊断模型 特征拼接 python(pytorch) 基于2D-…

Vagrant安装虚拟机

Vagrant安装虚拟机 优点:操作简单方便 vagrant仓库提供已配置完成镜像系统,只需简单命令可迅速初始化运行虚拟机 一、安装virtualBox 官方网站:Oracle VM VirtualBox 如果虚拟机安装失败,可能计算机未开启CPU虚拟化 二、安装V…

【书生·浦语大模型实战营02】《轻松玩转书生·浦语大模型趣味Demo》学习笔记

《轻松玩转书生浦语大模型趣味Demo》 1、InternLM-Chat-7B 智能对话:生成 300 字的小故事 本节中我们将使用InternLM-Chat-7B 模型部署一个智能对话 Demo。 1.1 环境准备 在InternStudio平台中选择 A100(1/4) 的配置,镜像选择 Cuda11.7-conda&#x…