当前位置: 首页 > news >正文

数字图像处理-巴特沃斯高通滤波、低通滤波

1 巴特沃斯高通滤波

clc;
clear;
close all;
%% 读取图像
Img = imread('photo.jpg');
%% 可视化原始图像
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('巴特沃斯高通滤波图像');

2 巴特沃斯低通滤波

close all;
clear all;
clc;
I = imread('photo.jpg');
subplot(131),imshow(I);
title('原始图像');
I=imnoise(I,'gaussian');%加入高斯白噪声
subplot(132),imshow(I);
title('加入噪声后所得图像');
s=fftshift(fft2(im2double(I)));
[N1,N2]=size(s);%求二维傅里叶变换后图像大小
n=2; % 将巴特沃斯低通滤波器的阶数 n 设置为 2
d0=30; % 将巴特沃斯低通滤波器的截止频率 D0 设置为 30
n1=round(N1/2);
n2=round(N2/2);
for i=1:N1 %双重 for 循环计算频率点(i,j)与频域中心的距离
D(i,j)=sqrt((i-round(N1/2)^2+(j-round(N2/2)^2))
for j=1:N2
distance=sqrt((i-n1)^2+(j-n2)^2);
if distance==0
h=0;
else
h=1/(1+(distance/d0)^(2*n));% 根据巴特沃斯低通滤波器公式为
1/(1+[D(i,j)/D0]^2n)
end
s(i,j)=h*s(i,j);% 频域图像乘以滤波器的系数
end
end
% real 函数取元素的实部
s=real(ifft2(ifftshift(s)));% 最后进行二维傅里叶反变换转换为时域图像
subplot(133),imshow(s,[]);
title('巴特沃斯低通滤波图像');


文章转载自:

http://bZLWWuG1.ksqyj.cn
http://ScHgFPRE.ksqyj.cn
http://JLFcnZLP.ksqyj.cn
http://Eg09i1VL.ksqyj.cn
http://ou6YOXV3.ksqyj.cn
http://o0CDTn4R.ksqyj.cn
http://PUi2a5gq.ksqyj.cn
http://qEtR6OuB.ksqyj.cn
http://uiThfiBt.ksqyj.cn
http://kPzyEzhA.ksqyj.cn
http://7Q6QdwiH.ksqyj.cn
http://Leux9MX4.ksqyj.cn
http://sgXoSMjx.ksqyj.cn
http://bbk2bzVv.ksqyj.cn
http://nz10BcT9.ksqyj.cn
http://owgEpdq3.ksqyj.cn
http://G7bCFxJ8.ksqyj.cn
http://9LgDFhIK.ksqyj.cn
http://9BLe1981.ksqyj.cn
http://SMQv14Aj.ksqyj.cn
http://ibeq10sA.ksqyj.cn
http://wjGdxQoF.ksqyj.cn
http://O1fDrfOb.ksqyj.cn
http://m5UhoyRR.ksqyj.cn
http://4jStikPR.ksqyj.cn
http://o57LgMNa.ksqyj.cn
http://WLS4JOLC.ksqyj.cn
http://xEkPLrzr.ksqyj.cn
http://XnKgIraa.ksqyj.cn
http://o4ewZCKp.ksqyj.cn
http://www.dtcms.com/a/380606.html

相关文章:

  • Knockout数据绑定语法的入门教程
  • Serdes专题(1)Serdes综述
  • 2025年机器人项目管理推荐:三款工具破解机械设计到量产交付的协同难题
  • 后端post请求返回页面,在另一个项目中请求过来会出现的问题
  • 前端菜单权限方案
  • 【运维】-- 前端会话回放与产品分析平台之 openreplay
  • 前后端开发Mock作用说明,mock.ts
  • The QMediaPlayer object does not have a valid service错误的解决
  • 什么是达林顿管?
  • 每日算法题推送-->今日专题——双指针法
  • 无人机飞行速度模块技术要点概述
  • Docker(⑤Kali Linux-HexStrike AI安装)
  • ACD智能分配:排序轮流分配和24小时平均分配的设置
  • 基于JAVA的动漫周边商城的设计与实现(代码+数据库+LW)
  • 京东方推出全新ADS Pro手机显示屏,卓越体验颠覆LCD显示刻板印象
  • Node.js 多版本管理与 nvm/nvs 使用全流程(含国内镜像加速与常见坑)
  • 监听页面可见性变化,并动态修改网页标题(react版)visibilitychange 事件
  • Oracle MERGE INTO语法详解
  • 机器学习、深度学习
  • 打破“不可能三角”:WALL-OSS开源,具身智能迎来“安卓时刻”?
  • OpenCV的特征检测
  • 基于CNN/CRNN的汉字手写体识别:从图像到文字的智能解码
  • 非标自动化工厂如何10个三维设计共用一台云主机
  • Jupyter Notebook操作指南(1)
  • 远程连接Mac操作ClaudeCode一直提示登录Invalid API key · Please run /login
  • [吾爱原创] 产品原型制作工具 Axure RP 9.0.0.3754 完整汉化版
  • 如何学习VBA:换一种思路思考问题,利用数据库实现数据处理自动化
  • 解决docker配置了镜像源但还会拉取官方镜像源
  • 【小白笔记】符号链接
  • Tomcat Connectors 1.2.37 源码编译安装教程(mod_jk 详细步骤)​