opencv一维直方图

原创 2013年12月03日 15:55:12

//一维 灰度 直方图 


#include <iostream>
#include <cv.h>
#include <highgui.h>
#include <cxcore.h>


using namespace std;




int main( )
{
//一维 灰度 直方图 
IplImage * src= cvLoadImage("1.jpg");
IplImage* gray_plane = cvCreateImage(cvGetSize(src),8,1);
cvCvtColor(src,gray_plane,CV_BGR2GRAY);


int hist_size = 256;    //直方图尺寸
int hist_height = 256;
float range[] = {0,255};  //灰度级的范围
float* ranges[]={range};
//创建一维直方图,统计图像在[0 255]像素的均匀分布
CvHistogram* gray_hist = cvCreateHist(1,&hist_size,CV_HIST_ARRAY,ranges,1);
//计算灰度图像的一维直方图
cvCalcHist(&gray_plane,gray_hist,0,0);
//归一化直方图
cvNormalizeHist(gray_hist,1.0);


int scale = 2;
//创建一张一维直方图的“图”,横坐标为灰度级,纵坐标为像素个数(*scale)
IplImage* hist_image = cvCreateImage(cvSize(hist_size*scale,hist_height),8,3);
cvZero(hist_image);
//统计直方图中的最大直方块
float max_value = 0;
cvGetMinMaxHistValue(gray_hist, 0,&max_value,0,0);


//分别将每个直方块的值绘制到图中
//OPENCV坐标系采用  顶——左结构,即坐标系原点在左上方
for(int i=0;i<hist_size;i++)
{
float bin_val = cvQueryHistValue_1D(gray_hist,i); //像素i的概率
int intensity = cvRound(bin_val*hist_height/max_value);  //要绘制的高度
cvRectangle(hist_image,
cvPoint(i*scale,hist_height-1),
cvPoint((i+1)*scale - 1, hist_height - intensity),
CV_RGB(255,255,255));  
}
cvNamedWindow( "GraySource", 1 );
cvShowImage("GraySource",gray_plane);
cvNamedWindow( "Histogram", 1 );
cvShowImage( "Histogram", hist_image );


cvWaitKey(0);
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

直方图 一维 opencv vs2010

  • 2013-04-19 19:08
  • 8.95MB
  • 下载

【OpenCV】直方图——一维

关于直方图的基本概念坛子里介绍的很多,能用代码表示尽量不多话!

opencv3 绘制一维直方图-灰度直方图的绘制

#include #include #include using namespace cv; using namespace std; int main() { Mat srcImage = i...

opencv3 计算一维直方图-灰度直方图的计算

#include #include #include using namespace cv; using namespace std; int main() { Mat srcImage = i...

opencv3 绘制一维直方图-灰度直方图的绘制-柱状图

#include #include #include using namespace cv; using namespace std; int main() { Mat srcImage = i...

opencv 灰度直方图 一维直方图

typedef struct CvHistogram { int type; CvArr* bins; float thresh[CV_MAX_DIM][2]; ...

图像检索:一维直方图+欧几里得距离+flann+KNN

图像检索--一维颜色直方图

在灰度图像上进行Mean Shift迭代搜索目标 ,一维加权直方图 + 巴氏系数 + Mean Shift迭代

今天要给大家分享的是: 在灰度图像上进行Mean Shift迭代搜索目标 ,一维加权直方图+巴氏系数+Mean Shift迭代

图像检索:一维直方图+EMD距离

图像检索

opencv一维码识别

  • 2016-05-04 16:33
  • 23.68MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)