大作业毕设系列基于matlab的直方图优化的图像去雾系统


前言

雾霾天气往往会给人类的生产和生活带来极大不便,也大大增加了交通事故的发生概率。一般而言,在恶劣天气(如雾天、雨天等)条件下,户外景物图像的对比度和颜色会被改变或退化,图像中蕴含的许多特征也会被覆盖或模糊,这会导致某些视觉系统(如电子卡口、门禁监控等)无法正常工作。因此,从在雾霾天气下采集的退化图像中复原和增强景物的细节信息具有重要的现实意义。数字图像处理技术已被广泛应用于科学和工程领域,如地形分类系统、户外监控系统、自动导航系统等。为了保证视觉系统全天候正常工作,就必须使视觉系统适应各种天气状况。


一、理论基础

图像增强是指按特定的需要突出一幅图像中的某些信息,并同时削弱或去除某些不需要的信息的处理技术。图像增强的主要作用是相对于原来的图像,处理后的图像能更加有效地满足某些特定应用的要求。根据图像处理空间的不同,图像增强方法基本上可分为两大类:频域处理法、空域处理法。频域处理法的基础是卷积定理,它通过进行某种图像变换(如傅里叶变换、小波变换等)得到频域结果并修改的方法来实现对图像的增强处理。空域处理法是直接对图像中的像素进行处理,一般以图像灰度的映射变换为基础并且根据图像增强的目标来采用所需的映射变换,常见的图像对比度增强、图像灰度层次优化等均属于空域处理法。接下来主要介绍
空域的直方图增强算法。

直方图是图像的一种统计表达形式。对于一幅灰度图像来说,其灰度统计直方图可以反映该图像中不同灰度级出现的统计情况。一般而言,图像的视觉效果和其直方图有对应关系,通过调整或变换其直方图的形状会对图像的显示效果有很大影响。
直方图均衡化主要用于增强灰度值动态范围偏小的图像的对比度,它的基本思想是把原始图像的灰度统计直方图变换为均匀分布形式,这样就增加了像素灰度值的动态范围,从而达到增强图像整体对比度的效果。

数字图像是离散化的数值矩阵,其直方图可以被视为一个离散函数,表示数字图像中每个灰度级与其出现概率间的统计关系。假设一幅数字图像 f (x, y)的像素总数为 N,rk表示第 k 个灰度级对应的灰度,nk表示灰度为 rk的像素个数即频数,若用横坐标表示灰度级,用纵坐标表示频数,p(rk)=n/k,,表示p灰度 rk出现的相对频数即概率。直方图在一定程度上能够反映数字图像的概貌性描述,包括图像的灰度范围、灰度分布、整幅图像的亮度均值和阴暗对比度等,并可以此为基础进行分析来得出对图像进一步处理的重要依据。直方图均衡化也叫作直方图均匀化,就是把给定图像的直方图变换成均匀分布的直方图,是一种较为常用的灰度增强算法。直方图均衡化通常包括以下三个主要步骤。
(1)预处理。输入图像,计算该图像的直方图。
(2)灰度变换表。根据输入图像的直方图计算灰度值变换表。
(3)查表变换。执行变换 x’=H(x),表示对在步骤 1 中得到的直方图使用步骤 2 得到的灰
度值变换表进行查表变换操作,通过遍历整幅图像的每一个像元,将原始图像灰度值x放入变换表 H(x)中,可得到变换后的新灰度值 x’。根据信息论的相关理论,我们可以知道图像在经直方图均衡化后,将会包含更多的信息量,进而能突出某些图像特征。假设图像具有 n 级灰度,其第 i 级灰度出现的概率为 pi,则该级灰度所含的信息量为:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
从图 1-1、图 1-3 可以看出,原图的像素分布大多集中在 0~25 区间,在直观上偏黑色区域占比较多,难以区分轮胎区域的细节;从图 1-2、图 1-4 可以看出,原图在均衡化后,图像的像素均匀分布在 0~255 区间,在直观上呈现亮度均匀的效果,能较好地看出轮胎区域的细节。因此,直方图均衡化在一定程度上可以提升亮度分布不均、曝光过度等情况的图像可视化效果,是一种较为通用的图像增强方法。

二、程序实现

在这里插入图片描述

1.全局直方图处理

MATLAB 通过函数 imread 读取 RGB 图像,并通过维数为
m *n * 3的矩阵来表示。其中,维数m *n 表示图像的行数、列数信息,维数 3 表示图像的 R、G、B 三层通道数据。因此,全局直方图处理通过对 RGB 图像的 R、G、B 三层通道分别进行直方图均衡化,再整合到新的图像的方式进行。核心代码如下:

function In = RemoveFogByGlobalHisteq(I, flag)
% 对于 RGB 图像,分别对 R、G、B 进行均衡,再得到新的 RGB 图像
% 输入参数:
% I——图像矩阵
% flag——显示标记
% 输出参数:
% In——结果图像
if nargin < 2
 flag = 1;
end
% 提取图像的 R、G、B 分量
R = I(:,:,1);
G = I(:,:,2);
B = I(:,:,3);
% 分别对图像的 R、G、B 分量进行全局直方图均衡化
M = histeq(R);
N = histeq(G);
L = histeq(B);
% 通过集成全局直方图均衡化后的分量来得到结果图像
In = cat(3, M, N, L);
% 结果显示
if flag
 figure;
 subplot(2, 2, 1); imshow(I); title('原图像', 'FontWeight', 'Bold');
 subplot(2, 2, 2); imshow(In); title('处理后的图像', 'FontWeight', 'Bold');
% 灰度化,用于计算直方图
 Q = rgb2gray(I);
 W = rgb2gray(In);
 subplot(2, 2, 3); imhist(Q, 64); title('原灰度直方图', 'FontWeight', 'Bold');
 subplot(2, 2, 4); imhist(W, 64); title('处理后的灰度直方图', 'FontWeight', 
'Bold');
end

在这里插入图片描述

在这里插入图片描述

2.局部直方图处理

全局直方图均衡化增强只是将原图像的直方图进行了均衡化,未能有效保持原始图像的局部特征,容易出现色彩失真问题。通过选择固定大小的滑动窗口作用于原始图像进行局部直方图处理,可以在一定程度上保持原始图像的局部特征,提高图像增强的效果。因此,局部直方图处理通过对 RGB 图像的 R、G、B 三层通道分别进行局部直方图均衡化,再整合到新的图像的方式进行。核心代码如下:

function In = RemoveFogByLocalHisteq(I, flag)
% 对 RGB 图像,分别对 R、G、B 进行均衡,再得到新 RGB 图像
% 输入参数:
% I——图像矩阵
% flag——显示标记
% 输出参数:
% In——结果图像
% 分别对 R、G、B 三层分量进行局部直方图均衡化处理
g1 = GetLocalHisteq(I(:, :, 1));
g2 = GetLocalHisteq(I(:, :, 2));
g3 = GetLocalHisteq(I(:, :, 3));
% 通过集成局部直方图均衡化后的分量得到结果图像
In = cat(3, g1, g2, g3);
% 结果显示
if flag
 figure
  subplot(2, 2, 1); imshow(I); title('原图像', 'FontWeight', 'Bold');
 subplot(2, 2, 2); imshow(In); title('处理后的图像', 'FontWeight', 'Bold');
% 灰度化,用于计算直方图
 Q = rgb2gray(I);
 W = rgb2gray(In);
 subplot(2, 2, 3); imhist(Q, 64); title('原灰度直方图', 'FontWeight', 'Bold');
 subplot(2, 2, 4); imhist(W, 64); title('处理后的灰度直方图', 'FontWeight', 
'Bold');
end
function g = GetLocalHisteq(I)
% 对灰度图像进行局部直方图均衡化
% 输入参数:
% I——图像矩阵
% 输出参数:
% g——结果图像
% 调用库函数 adapthisteq,执行局部均衡化增强
g = adapthisteq(I,'clipLimit',0.02,'Distribution','rayleigh');

在这里插入图片描述
在这里插入图片描述

3.Retinex 增强处理

基于全局直方图、局部直方图的图像去雾算法在理论及实现上比较简单,能起到一定的去雾处理效果。为了进行对比,本次实验采用了 Retinex 图像增强算法进行对比,该算法可以平衡图像灰度动态范围压缩、图像增强和图像颜色恒常三个指标,能够实现对含雾图像的自适应性增强。因此,Retinex 增强处理通过对 RGB 图像的 R、G、B 三层通道分别应用 Retinex 算法进行处理,再整合到新的图像的方式进行。为了提高程序的普适性,我们对部分参数的赋值方式进行了改进,采用随机数取值的方式来生成参数。核心代码如下:

function In = RemoveFogByRetinex(f, flag)
% Retinex 实现图像去雾
% 输入参数:
% f——图像矩阵
% flag——显示标记
% 输出参数:
% In——结果图像
if nargin < 2
 flag = 1;
end
%提取图像的 R、G、B 分量
fr = f(:, :, 1);
fg = f(:, :, 2);
fb = f(:, :, 3);
%数据类型归一化
mr = mat2gray(im2double(fr));
mg = mat2gray(im2double(fg));
mb = mat2gray(im2double(fb));
%定义 alpha 参数
alpha = randi([80 100], 1)*20;
%定义模板大小
n = floor(min([size(f, 1) size(f, 2)])*0.5);
%计算中心
n1 = floor((n+1)/2);
for i = 1:n
 for j = 1:n
 %高斯函数
 b(i,j) = exp(-((i-n1)^2+(j-n1)^2)/(4*alpha))/(pi*alpha);
 end
end
%卷积滤波
nr1 = imfilter(mr,b,'conv', 'replicate');
ng1 = imfilter(mg,b,'conv', 'replicate');
nb1 = imfilter(mb,b,'conv', 'replicate');
ur1 = log(nr1);
ug1 = log(ng1);
ub1 = log(nb1);
tr1 = log(mr);
tg1 = log(mg);
tb1 = log(mb);
yr1 = (tr1-ur1)/3;
yg1 = (tg1-ug1)/3;
yb1 = (tb1-ub1)/3;
%定义 beta 参数
beta = randi([80 100], 1)*1;
%定义模板的大小
x = 32;
for i = 1:n
 for j = 1:n
 %高斯函数
 a(i,j) = exp(-((i-n1)^2+(j-n1)^2)/(4*beta))/(6*pi*beta);
 end
end
%卷积滤波
nr2 = imfilter(mr,a,'conv', 'replicate');
ng2 = imfilter(mg,a,'conv', 'replicate');
nb2 = imfilter(mb,a,'conv', 'replicate');
ur2 = log(nr2);
ug2 = log(ng2);
ub2 = log(nb2);
tr2 = log(mr);
tg2 = log(mg);
tb2 = log(mb);
yr2 = (tr2-ur2)/3;
yg2 = (tg2-ug2)/3;
yb2 = (tb2-ub2)/3;
%定义 eta 参数
eta = randi([80 100], 1)*200;
for i = 1:n
 for j = 1:n
 %高斯函数
 e(i,j) = exp(-((i-n1)^2+(j-n1)^2)/(4*eta))/(4*pi*eta);
 end
end
%卷积滤波
nr3 = imfilter(mr,e,'conv', 'replicate');
ng3 = imfilter(mg,e,'conv', 'replicate');
nb3 = imfilter(mb,e,'conv', 'replicate');
ur3 = log(nr3);
ug3 = log(ng3);
ub3 = log(nb3);
tr3 = log(mr);
tg3 = log(mg);
tb3 = log(mb);
yr3 = (tr3-ur3)/3;
yg3 = (tg3-ug3)/3;
yb3 = (tb3-ub3)/3;
dr = yr1+yr2+yr3;
dg = yg1+yg2+yg3;
db = yb1+yb2+yb3;
cr = im2uint8(dr);
cg = im2uint8(dg);
cb = im2uint8(db);
% 通过集成处理后的分量得到结果图像
In = cat(3, cr, cg, cb);
%结果显示
if flag
 figure;
 subplot(2, 2, 1); imshow(f); title('原图像', 'FontWeight', 'Bold');
 subplot(2, 2, 2); imshow(In); title('处理后的图像', 'FontWeight', 'Bold');
 % 灰度化,用于计算直方图
 Q = rgb2gray(f);
 M = rgb2gray(In);
 subplot(2, 2, 3); imhist(Q, 64); title('原灰度直方图', 'FontWeight', 'Bold');
 subplot(2, 2, 4); imhist(M, 64); title('处理后的灰度直方图', 'FontWeight', 
'Bold');
end

在这里插入图片描述

总结

基于图像处理的去雾增强技术可以显著提高对比度,突出图像细节,提升视觉效果,该方法已被广泛应用于项目实践中。基于直方图均衡化模型的去雾方法针对性强,运行效率高,且易于融合于其他图像增强算法,所以该技术必将获得进一步的发展。尽管图像去雾技术在实际应用中已经取得了若干成果,但在不同的场景下依然面临某些局限性,需要引起研究人员的进一步关注。

源码下载

订阅此专栏可以获得:源码+文档+运行视频
链接: link

  • 0
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

挂科边缘(毕业版)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值