直方图均衡化及直方图规定化Word下载.docx
《直方图均衡化及直方图规定化Word下载.docx》由会员分享,可在线阅读,更多相关《直方图均衡化及直方图规定化Word下载.docx(11页珍藏版)》请在冰豆网上搜索。
实验2直方图均衡化
一、实验学时:
4学时(本部分占实验成绩的40%)
二、实验目的:
1、理解直方图均衡化的原理及步骤;
2、编程实现图像(灰度或彩色)的直方图均衡化。
三、必须学习和掌握的知识点:
直方图均衡化是一种快速有效且简便的图像空域增强方法,在图像处理中有着非常重要的意义,因此要求掌握。
四、实验题目:
编程实现灰度图像的直方图均衡化处理。
要求给出原始图像的直方图、均衡化图像及其直方图和直方图均衡化时所用的灰度级变换曲线图。
五、思考题:
(选做,有加分)
实现对灰度图像的直方图规定化处理。
六、实验报告:
请按照要求完成下面报告内容并提交源程序、可执行程序文件和实验结果图像。
1、
请详细描述本实验的原理:
1.直方图均衡化概述
图像对比度增强的方法可以分成两类:
一类是直接对比度增强方法;
另一类是间接对比度增强方法。
直方图拉伸和直方图均衡化是两种最常见的间接对比度增强方法。
直方图拉伸是通过对比度拉伸对直方图进行调整,从而“扩大”前景和背景灰度的差别,以达到增强对比度的目的,这种方法可以利用线性或非线性的方法来实现;
直方图均衡化则通过使用累积函数对灰度值进行“调整”以实现对比度的增强。
直方图均衡化的英文名称是HistogramEqualization.
直方图均衡化是图像处理领域中利用图像直方图对对比度进行调整的方法。
这种方法通常用来增加许多图像的局部对比度,尤其是当图像的有用数据的对比度相当接近的时候。
通过这种方法,亮度可以更好地在直方图上分布。
这样就可以用于增强局部的对比度而不影响整体的对比度,直方图均衡化通过有效地扩展常用的亮度来实现这种功能。
2基本思想
直方图均衡化处理的“中心思想”是把原始图像的灰度直方图从比较集中的某个灰度区间变成在全部灰度范围内的均匀分布。
直方图均衡化就是对图像进行非线性拉伸,重新分配图像像素值,使一定灰度范围内的像素数量大致相同。
直方图均衡化就是把给定图像的直方图分布改变成“均匀”分布直方图分布。
直方图均衡化的基本思想是把原始图的直方图变换为均匀分布的形式,这样就增加了象素灰度值的动态范围从而可达到增强图像整体对比度的效果。
设原始图像在(x,y)处的灰度为f,而改变后的图像为g,则对图像增强的方法可表述为将在(x,y)处的灰度f映射为g。
在灰度直方图均衡化处理中对图像的映射函数可定义为:
g=EQ(f),这个映射函数EQ(f)必须满足两个条件(其中L为图像的灰度级数):
(1)EQ(f)在0≤f≤L-1范围内是一个单值单增函数。
这是为了保证增强处理没有打乱原始图像的灰度排列次序,原图各灰度级在变换后仍保持从黑到白(或从白到黑)的排列。
(2)对于0≤f≤L-1有0≤g≤L-1,这个条件保证了变换前后灰度值动态范围的一致性。
累积分布函数(cumulativedistributionfunction,CDF)即可以满足上述两个条件,并且通过该函数可以完成将原图像f的分布转换成g的均匀分布。
此时的直方图均衡化映射函数为:
gk=EQ(fk)=(ni/n)=pf(fi),
(k=0,1,2,……,L-1)
上述求和区间为0到k,根据该方程可以由源图像的各像素灰度值直接得到直方图均衡化后各像素的灰度值。
在实际处理变换时,一般先对原始图像的灰度情况进行统计分析,并计算出原始直方图分布,然后根据计算出的累计直方图分布求出fk到gk的灰度映射关系。
在重复上述步骤得到源图像所有灰度级到目标图像灰度级的映射关系后,按照这个映射关系对源图像各点像素进行灰度转换,即可完成对源图的直方图均衡化。
3.图像直方图变换的基本原理:
设变量r代表图像中像素的灰度级,直方图变换就是假定一个变换式:
(1-1)
也就是,通过上述变换,每个原始图像的像素灰度级r都会产生一个s值。
变换函数T(r)应满足以下条件:
(1)
T(r)在区间
中为单值且单调递增;
(2)
当
时,
,即T(r)的取值范围与r相同。
2.直方图均衡化:
对于离散值,我们处理其概率与求和,而不是概率密度函数与积分。
一幅图像中灰度级rk出现的概率近似为
(1-2)
其中,n是图像中像素的总和,是灰度级的像素个数,L为图像中可能的灰度级总数。
(1-3)
上式中变换函数的离散形式为:
该变换(映射)称为直方图均衡化或直方图线性化。
优缺点
这种方法对于背景和前景都太亮或者太暗的图像非常有用,这种方法尤其是可以带来X光图像中更好的骨骼结构显示以及曝光过度或者曝光不足照片中更好的细节。
这种方法的一个主要优势是它是一个相当直观的技术并且是可逆操作,如果已知均衡化函数,那么就可以恢复原始的直方图,并且计算量也不大。
这种方法的一个缺点是它对处理的数据不加选择,它可能会增加背景杂讯的对比度并且降低有用信号的对比度;
变换后图像的灰度级减少,某些细节消失;
某些图像,如直方图有高峰,经处理后对比度不自然的过分增强。
2、请给出本实验的核心源码(Matlab或C语言):
I=imread('
C:
\Users\wh\Desktop\photo\Rockies.bmp'
);
%读
imshow(I);
figure,imhist(I);
[J,T]=histeq(I,64);
%图像灰度扩展到0~255,但是只有64个灰度级
figure,imshow(J);
figure,imhist(J);
figure,plot((0:
255)/255,T);
%转移函数变换曲线
J=histeq(I,32);
%图像灰度扩展到0~255,但只有32个灰度级
3、实验结果分析(要求附上结果图像):
原图像
图像灰度扩展到0~255,但是只有64个灰度级
直方图显示
转移函数变换曲线
图像灰度扩展到0~255,但只有32个灰度级
(下附显示各像素灰度级的mat文件)
4、实验体会:
1.工欲善其事,必先利其器,matlab简单几行代码就解决了VC中可能上百上千行的程序。
2.正确调用内置子程序是非常便利的。
5、思考题部分:
1.直方图规定化程序代码:
>
f=imread('
imshow(f);
figure,imhist(f);
ylim('
auto'
g=histeq(f,256);
figure,imshow(g);
figure,imhist(g);
2.图像处理