巴特沃斯滤波原理及代码实现(matlab详细过程版)

目录

  • 一、算法原理
    • 1、原理概述
    • 2、参考文献
  • 二、代码实现
  • 三、结果展示

在这里插入图片描述

本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫与GPT。

一、算法原理

1、原理概述

  巴特沃斯滤波器(Butterworth filter)是一种连续衰减的滤波器,所以也被称为最大平坦滤波器,在该滤波器不会出现太大陡峭的变化。其特点是在通频带内呈现出最大限度的平坦的频率响应曲线,没有纹波,同时在阻频带内则逐渐下降为0。其主要原理是先通过离散傅里叶变换把图像转换到频域,再进行巴特沃斯低通滤波,然后用傅里叶逆变换转换回空域,最终实现图像增强效果。其中离散傅里叶变换就是傅里叶变换在时间和频率域上均以离散的形式存在。其一维离散傅里叶变换定义为:
在这里插入图片描述
  其中 f ( x ) f(x) f(x) 为离散序列,长度为 N N N u = 0 , 1 , … , N − 1 u =0,1,…, N -1 u=0,1,,N1,则 F ( u ) F(u) F(u)的一维离散傅里叶反变换可以定义为:

在这里插入图片描述
  根据公式(3)和(4)可以推广出二维离散傅里叶变换,设离散函数 f ( x , y ) f (x,y) f(x,y) ,其中 x = 0 , 1 , … , M − 1 , y = 0 , 1 , … , N − 1 x =0,1,…, M -1, y =0,1,…, N -1 x=0,1,,M1,y=0,1,,N1
其定义为:
在这里插入图片描述
  在公式(5)中, u = 0 , 1 , … , M − 1 , v = 0 , 1 , … , N − 1 u =0,1,…, M -1,v =0,1,…, N -1 u=0,1,,M1v=0,1,,N1 F ( u , v ) F(u,v) F(u,v)二维离散傅里叶反变换可以定义为:
在这里插入图片描述
  通过傅里叶变换将图像从时域转换到频域之后,就可以对其进行下一步操作,巴特沃斯低通滤波的定义如公式(7)所示:

在这里插入图片描述
  其中 D ( u , v ) D(u,v) D(u,v)为该点到中心点的距离, D 0 D_0 D0为截止频率,也就是振幅下降为-3 分贝时的频率, D 0 D_0 D0选取的值不同其对图像的处理效果也不同。滤波器阶数 n n n越大滤波器的形状越陡峭。通常取 n = 2 n = 2 n=2,此时没有明显的振铃效应,数值更大时会有模糊效应。
  巴特沃斯高通滤波的定义如公式(8)所示:
在这里插入图片描述
  为了在高频率域来降噪时较好的保存边缘信息,首要工作就是要找到图像结构特征的频率带,在这些频率带上不能做过多的缩减,而在离这些频率带比较远的区域,可以增加缩减的程度。巴特沃斯响应函数在频率中心区域的半径小于 D ( u , v ) D(u,v) D(u,v) 时,函数值很接近1,变化不大;而随着距离中心点越来越远,函数值迅速减少。这一特性可以被用来进行图像降噪。

2、参考文献

[1]贾亮,邢轶博,徐善博. 基于改进巴特沃斯滤波的红外图像增强算法 [J]. 电脑与电信, 2022, (07): 58-62+76. DOI:10.15966/j.cnki.dnydx.2022.07.017.

二、代码实现

clc;
clear;
close all;

%% ------------------------------读取图像----------------------------------
Img = imread('Y.png');
%% ---------------------------可视化原始图像-------------------------------
subplot(121),imshow(Img);
title('原始图像');
%% --------------------------巴特沃斯高通滤波------------------------------
% 图像的数据类型由uint8转化为double类型
Imgd = im2double(Img);
% 二维傅立叶变换
fuv = fft2(Imgd);
% 对傅里叶变换后得到的频谱进行平移,将变换后的图像频谱中心从矩阵的原点移到矩阵的中心
trans = fftshift(fuv);
[row,col] = size(trans); % 求二维傅里叶变换后图像大小
n = 2;                   % 巴特沃斯高通滤波器的阶数n
d0 = 30;                 % 巴特沃斯高通滤波器的截止频率D0
n1 = round(row/2);
n2 = round(col/2);
% 计算频率点(i,j)与频域中心的距离
for i = 1:row      
    for j = 1:col 
        distance = sqrt((i-n1)^2+(j-n2)^2);
        if distance==0 
            h = 0; 
        else
            h = 1/(1+(d0/distance)^(2*n));% 巴特沃斯高通滤波
        end
        trans(i,j) = h*trans(i,j);% 频域图像乘以滤波器的系数
    end
end
invTrans = ifftshift(trans);
% 二维傅里叶反变换转换为时域图像
fxy = ifft2(invTrans);
% real函数取元素的实部
trans = real(fxy);
%% ----------------------可视化滤波后的图像--------------------------------
subplot(122),imshow(trans,[]);
title('巴特沃斯高通滤波图像');



三、结果展示

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

主成分分析(PCA)在 Java 中的简单应用

在数据科学的众多工具中,主成分分析(PCA)是一种非常重要的统计技术,用于数据降维和模式识别。它通过提取数据中的关键特征来简化数据结构,从而帮助我们更好地理解数据集的主要变化因素。本文将介绍如何在 Java 编程环境…

CARLA (I)--Ubuntu20.04 服务器安装 CARLA_0.9.13服务端和客户端详细步骤

目录 0. 说明0.1 应用场景:0.2 本文动机: 1. 准备工作2. 安装 CARLA 服务端软件【远程服务器】3. 安装 CARLA 客户端【远程服务器】3.1 .egg 文件安装:3.2 .whl 文件安装:3.3 从Pypi下载Python package 4. 运行服务端程序5. 运行客…

arcgis js 4.x加载SceneLayer并实现基于属性查询定位及高亮

一、代码 <!DOCTYPE html> <html> <head><meta charset"utf-8" /><meta name"viewport" content"widthdevice-width, initial-scale1,maximum-scale1,user-scalableno"><title></title><link rel…

北京车展创新纷呈,移远通信网联赋能

时隔四年&#xff0c;备受瞩目的2024&#xff08;第十八届&#xff09;北京国际汽车展览会于4月25日盛大开幕。在这场汽车行业盛会上&#xff0c;各大主流车企竞相炫技&#xff0c;众多全球首发车、概念车、新能源车在这里汇聚&#xff0c;深刻揭示了汽车产业的最新成果和发展潮…

神经网络的激活函数

目录 神经网络 激活函数 sigmoid 激活函数 tanh 激活函数 backward方法 relu 激活函数 softmax 激活函数 神经网络 人工神经网络&#xff08; Artificial Neural Network&#xff0c; 简写为ANN&#xff09;也简称为神经网络&#xff08;NN&#xff09;&#xff0c…

杰发科技AC7840——CAN通信简介(7)_波形分析

参考&#xff1a; CAN总线协议_stm32_mustfeng-GitCode 开源社区 0. 简介 隐形和显性波形 整帧数据表示 1. 字节描述 CAN数据帧标准格式域段域段名位宽&#xff1a;bit描述帧起始SOF(Start Of Frame)1数据帧起始标志&#xff0c;固定为1bit显性(b0)仲裁段dentify(ID)11本数…

c++图论基础(2)

目录 图的存储方式&#xff1a; 邻接矩阵&#xff1a; 代码实现&#xff1a; 邻接表&#xff1a; 代码实现&#xff1a; 邻接矩阵邻接表对比&#xff1a; 带权图&#xff1a; 邻接矩阵存储&#xff1a; 邻接表存储(代码实现)&#xff1a; 图的存储方式&#xff1a; 邻…

Unreal Engine添加UGameInstanceSubsystem子类

点击C类文件夹&#xff0c;在右边的区域点击鼠标右键&#xff0c;在弹出的菜单中选择“新建C类”在弹出的菜单中选中“显示所有类”&#xff0c;选择GameInstanceSubsystem作为父类, 点击“下一步”按钮输入子类名称“UVRVIUOnlineGameSubsystem”&#xff0c;选择插件作为新类…

Qt 创建控件的两种方式

目录 Qt 创建控件的两种方式 通过ui界面创建控件 通过代码方式创建控件 Qt 创建控件的两种方式 通过ui界面创建控件 这里当然我们是需要先有一个项目的&#xff0c;按照我们之前创建项目的步骤&#xff0c;我们可以先创建一个 Widget 的项目&#xff0c;但是 MainWindow 也…

EasyRecovery数据恢复软件2025激活码及下载使用步骤教程

EasyRecovery数据恢复软件是一款功能强大且用户友好的数据恢复工具&#xff0c;专为帮助用户找回因各种原因丢失的数据而设计。该软件由全球知名的数据恢复技术公司开发&#xff0c;经过多年的技术积累和更新迭代&#xff0c;已经成为行业内备受推崇的数据恢复解决方案。 EasyR…

Spring MVC系列之九大核心组件

概述 Spring MVC是面试必问知识点其一&#xff0c;Spring MVC知识体系庞杂&#xff0c;有以下九大核心组件&#xff1a; HandlerMappingHandlerAdapterHandlerExceptionResolverViewResolverRequestToViewNameTranslatorLocaleResolverThemeResolverMultipartResolverFlashMa…

Andorid复习

组件 TextView 阴影 android:shadowColor"color/red" 阴影颜色android:shadowRadius"3.0" 阴影模糊度&#xff08;大小&#xff09;android:shadowDx"10.0" 横向偏移android:shadowDy"10.0" 跑马灯 这里用自定义控件 public cla…

【Java】HOT100 回溯

目录 理论基础 一、组合问题 LeetCode77&#xff1a;组合 LeetCode17&#xff1a;电话号码的字母组合 LeetCode39&#xff1a;组合总和 LeetCode216&#xff1a;组合总和ii LeetCode216&#xff1a;组合总和iii 二、分割问题 LeetCode131&#xff1a;分割回文串 Leet…

MFC实现ini配置文件的读取

MFC实现 ini 配置文件的读取1 实现的功能&#xff1a;点击导入配置文件按钮可以在旁边编辑框中显示配置文件的路径&#xff0c;以及在下面的编辑框中显示配置文件的内容。 1. 显示配置文件内容的编辑框设置 对于显示配置文件内容的 Edit Contorl 编辑框的属性设置如下&#x…

vue3中所有页面需要手动刷新一下才能显示,控制台没有报错

1.问题 登录进来是进入首页&#xff0c;然后切换任何页面都是空白&#xff0c;但是控制台没有报错。在其他页面刷新后却能显示&#xff0c;然而切换到首页刷新后再切换到其他页面又是空白。 2.解决问题 原因&#xff1a;在于首页给了两个根标签&#xff0c;我把其中一个根标签…

视频输入c++ 调用 libtorch推理

1、支持GPU情况 libtorch 支持GPU情况比较奇怪&#xff0c;目前2.3 版本需要在链接器里面加上以下命令&#xff0c;否则不会支持gpu -INCLUDE:?ignore_this_library_placeholderYAHXZ 2 探测是否支持 加一个函数看你是否支持torch&#xff0c;不然不清楚&#xff0c;看到…

axios——503响应超时重复多次请求——技能提升

今天在写后台管理系统时&#xff0c;遇到一个问题&#xff0c;就是每天早上一启动项目&#xff0c;接口会提示503超时&#xff0c;因此项目运行必须重新刷新请求成功后才可以正常使用。 后端同事说请求超时了&#xff0c;需要前端处理一下&#xff0c;如果是503的状态码&#…

封装 H.264 视频为 FLV 格式然后推流

封装 H.264 视频为 FLV 格式并通过 RTMP 推流 flyfish 协议 RTMP (Real-Time Messaging Protocol) RTSP (Real Time Streaming Protocol) SRT (Secure Reliable Transport) WebRTC RTMP&#xff08;Real Time Messaging Protocol&#xff09;是一种用于实时音视频流传输的协…

西安交通大学 915 备考常见误区

看到助教在 915 全程班群里给同学们解答问题&#xff0c;我也是感触颇深&#xff0c;想起来我当年自身的一个备考情况。接下来结合我自身情况给同学们分析一下&#xff0c;为什么有的同学基础一般&#xff0c;最后分数却很高&#xff0c;有的同学基础很好&#xff0c;分数却一般…

Linux网络编程---多进/线程并发服务器

一、多进程并发服务器 实现一个服务器可以连接多个客户端&#xff0c;每当accept函数等待到客户端进行连接时 就创建一个子进程 思路分析&#xff1a; 核心思路&#xff1a;让accept循环阻塞等待客户端&#xff0c;每当有客户端连接时就fork子进程&#xff0c;让子进程去和客户…