数字图像的直方图均衡化(C/C++源代码)
来源:互联网 发布:大学生网络课程怎么上 编辑:程序博客网 时间:2024/06/03 18:06
数字图像的直方图均衡化是常用的图像增强方法,因为均衡化是自动完成的,无需人工干预,而且常常得到比较满意的结果。下面的程序是利用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;
}
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/hunnish/archive/2004/10/14/136003.aspx
- 数字图像的直方图均衡化(C/C++源代码)
- Win8Metro(C#)数字图像处理--2.30直方图均衡化
- 数字图像处理--直方图均衡化
- 数字图像处理-----直方图均衡化
- 数字图像处理之灰度图的直方图均衡化
- 数字图像处理之彩色图像的直方图均衡化
- python数字图像处理(9):直方图与均衡化
- python数字图像处理(9):直方图与均衡化
- python数字图像处理(9):直方图与均衡化
- MATLAB数字图像处理(一)直方图均衡化
- MATLAB数字图像处理(一)局部直方图均衡化
- 用C++(OpenCV)自己实现彩色直方图均衡化
- c语言实现直方图均衡化
- C语言实现直方图均衡化
- C/C++ OpenCV直方图均衡化
- 数字图像处理:1.直方图均衡化
- 数字图像处理之直方图均衡化
- python数字图像处理:直方图与均衡化
- 杯水车薪---ipcclean可能用到的有用命令awk
- DataSink和MediaOutput的关系
- 如何判断变量是否是数字
- android菜鸟测试之Aj_01的Android Launcher抽屉类SlidingDrawer的使用
- chapter7的一个小bug
- 数字图像的直方图均衡化(C/C++源代码)
- 新浪微博API客户端OAuth认证直接获取pin
- [shell编程]svn指定用户的修改文件获取
- scalar in perl
- Android系统详细介绍
- db2 语句
- Seasar2入门(一)
- 在windows下配置svn服务器
- 想下载点儿东西,积分却没有了