`
ihuashao
  • 浏览: 4514269 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

数字图像的直方图均衡化(C/C++源代码)

阅读更多

数字图像的直方图均衡化是常用的图像增强方法,因为均衡化是自动完成的,无需人工干预,而且常常得到比较满意的结果。下面的程序是利用OPENCV提供的函数,实现这个功能。需要OPENCV B4.0的支持,在VC6下编译通过。

//
// perform histgram equalization for single channel image
// AssureDigit Sample code
//


#include "cv.h"
#include "highgui.h"

#define HDIM 256 // bin of HIST, default = 256

int main( int argc, char** argv )
{
IplImage *src = 0, *dst = 0;
CvHistogram *hist = 0;

int n = HDIM;
double nn[HDIM];
uchar T[HDIM];
CvMat *T_mat;

int x;
int sum = 0; // sum of pixels of the source image 图像中象素点的总和
double val = 0;

if( argc != 2 || (src=cvLoadImage(argv[1], 0)) == NULL) // force to gray image
return -1;

cvNamedWindow( "source", 1 );
cvNamedWindow( "result", 1 );

// calculate histgram 计算直方图
hist = cvCreateHist( 1, &n, CV_HIST_ARRAY, 0, 1 );
cvCalcHist( &src, hist, 0, 0 );

// Create Accumulative Distribute Function of histgram
val = 0;
for ( x = 0; x < n; x++)
{
val = val + cvGetReal1D (hist->bins, x);
nn[x] = val;
}

// Compute intensity transformation 计算变换函数的离散形式
sum = src->height * src->width;
for( x = 0; x < n; x++ )
{
T[x] = (uchar) (255 * nn[x] / sum); // range is [0,255]
}

// Do intensity transform for source image
dst = cvCloneImage( src );
T_mat = cvCreateMatHeader( 1, 256, CV_8UC1 );
cvSetData( T_mat, T, 0 );
// directly use look-up-table function 直接调用内部函数完成 look-up-table 的过程
cvLUT( src, dst, T_mat );

cvShowImage( "source", src );
cvShowImage( "result", dst );
cvWaitKey(0);

cvDestroyWindow("source");
cvDestroyWindow("result");
cvReleaseImage( &src );
cvReleaseImage( &dst );
cvReleaseHist ( &hist );

return 0;
}

分享到:
评论

相关推荐

    c++数字图像处理 直方图均衡化 完整代码

    优秀完整的源代码,可以应用到自己的代码中,无论工程应用,交论文都可适用,值得下载。

    直方图均衡化源代码

    可以打开一张BMP格式图片,对其进行均衡化处理,是学习数字图像处理的一个很好示例

    Visual c++数字图像处理典型算法及实例源代码

    Visual c++数字图像处理典型算法及实例源代码,内容包括: 源码目录结构图、256色转灰度图、Hough变换、Walsh变换、二值化变换、亮度增减、傅立叶变换、反色、取对数、取指数、图像平移、图像旋转、图像细化、图像...

    数字图像获取, 处理及实践应用源代码

    很多有用的图像处理的源代码:图像显示(原图、抖动),图像增强(灰度变换、直方图均衡、多种滤波器、伪彩色增强等),图像复原(运动模糊、逆滤波等等),图像变换(傅立叶变换、快速傅立叶变换、离散余弦变换、...

    [毕业分享] MFC实现数字图像处理软件(源代码)

    双显示图片,显示图片信息,灰度图片,采样量化图片,直方图显示图片(手动绘制),几何变换和非几何变换(图像均衡化),几何变换,灰度级差值,图像增强(拉普拉斯等各种算子),图像编码压缩,霍夫变换等功能。...

    Visual c 数字图像处理典型算法及实例随书光盘源码.rar

    Visual c 数字图像处理典型算法及实例随书光盘源码,列举一些源码:用Canny算子提取边缘、梯度锐化、取对数、256色转灰度图、Hough变换、对比度拉伸、Walsh变换、二值化变换、维纳滤波处理、阈值变换、直方图均衡、...

    数字图像获取(用VC++实现)

    数字图像获取, 处理及实践应用源代码——很多有用的图像处理的源代码:图像显示(原图、抖动),图像增强(灰度变换、直方图均衡、多种滤波器、伪彩色增强等),图像复原(运动模糊、逆滤波等等),图像变换(傅立叶...

    《Visual C++数字图像处理开发入门与编程实践》源码

    第1章 Visual C++与数字图像处理 1 1.1 数字图像处理概述 2 1.1.1 图像与数字图像 2 1.1.2 数字图像处理研究的内容 4 1.1.3 数字图像处理的应用 6 1.2 Visual C++概述 8 1.2.1 C++语言简介 8 1.2.2 Visual C++简介 ...

    图像处理基础算法源代码

    数字图像处理的基本算法,其中包括中值滤波、直方图均衡、拉普拉斯锐化(边缘检测)等基本算法

    数字图像处理大作业,用Visual studio2022,C++与qt5写的,可自己导入图片做实验

    以下是大作业说明文档的目录,给出了包含的功能。上传的资源中包含了做实验用的图像,...4.1 直方图均衡化 10 4.2 中值滤波 11 4.3 图像灰度指数变换增强 11 4.4 Laplace锐化处理 12 5. 边缘检测 13 6. 傅里叶描述子 15

    vc++ 应用源码包_6

    C视频源代码 视频教程步骤源码 DDraw DirectX 实例 DES加密算法源代码 Detected memory leaks 检查内存泄漏源码 DigiStatic_src 自绘CStatic实现数字效果。 DirectShow开发指南pdf附属代码 DirectShow开发指南...

    vc++ 开发实例源码包

    C视频源代码 视频教程步骤源码 DDraw DirectX 实例 DES加密算法源代码 如题。 Detected memory leaks 检查内存泄漏源码 DigiStatic_src 自绘CStatic实现数字效果。 DirectShow开发指南pdf附属代码 如题。 ...

    若干源程序资料12.rar

    0 1.txt 2012-06-11 21:42 554,081 13 套ROOTKITS源码—Windows内核的安全防护.rar ...2012-06-11 21:36 142,693 直方图均衡化的c语言实现.rar 2012-06-11 20:58 58,895 矩形排样-源码.rar 2012-06-11 21:28 44,781...

    vc++ 应用源码包_5

    C视频源代码 视频教程步骤源码 DDraw DirectX 实例 DES加密算法源代码 Detected memory leaks 检查内存泄漏源码 DigiStatic_src 自绘CStatic实现数字效果。 DirectShow开发指南pdf附属代码 DirectShow开发指南...

    vc++ 应用源码包_1

    C视频源代码 视频教程步骤源码 DDraw DirectX 实例 DES加密算法源代码 Detected memory leaks 检查内存泄漏源码 DigiStatic_src 自绘CStatic实现数字效果。 DirectShow开发指南pdf附属代码 DirectShow开发指南...

    vc++ 应用源码包_2

    C视频源代码 视频教程步骤源码 DDraw DirectX 实例 DES加密算法源代码 Detected memory leaks 检查内存泄漏源码 DigiStatic_src 自绘CStatic实现数字效果。 DirectShow开发指南pdf附属代码 DirectShow开发指南...

    vc++ 应用源码包_3

    C视频源代码 视频教程步骤源码 DDraw DirectX 实例 DES加密算法源代码 Detected memory leaks 检查内存泄漏源码 DigiStatic_src 自绘CStatic实现数字效果。 DirectShow开发指南pdf附属代码 DirectShow开发指南...

Global site tag (gtag.js) - Google Analytics