直方图可以用来描述各种不同的事物,如物体的色彩分布、物体边缘梯度模板,以及表示目标位置的当前假设。

简单的说,直方图就是对数据进行统计,将统计值组织到一系列事先定义好的bin中。bin中的数值是从数据中计算出特征的统计量,这些数据可以是诸如梯度、方向、色彩或者任何其他特征。无论如何,直方图获得的是数据分布的统计图。通常直方图的维数要低于原始数据。

具体可参见:

http://docs.opencv.org/doc/tutorials/imgproc/histograms/histogram_calculation/histogram_calculation.html#histogram-calculation

下面参考《Learning OpenCV》一个例子。根据输入的图像计算出一个色相饱和度的2维直方图。

/**
* file:参考《learning OpenCV》P227
* author: Jacky_Liu
* date: 2013-12-06
*/ #include <QtCore/QCoreApplication>
#include <cv.h>
#include <highgui.h> int main(int argc, char *argv[])
{
// QCoreApplication a(argc, argv);
// return a.exec(); IplImage *src = NULL; if(argc != || (src = cvLoadImage(argv[], )) == )
{
printf("The number of the arguments is wrong, or the fail to load image.");
return ;
} //转换颜色空间
IplImage *hsv = cvCreateImage(cvGetSize(src), , );
cvCvtColor(src, hsv, CV_BGR2HSV); //分割到3个独立通道的图像
IplImage *h_plane = cvCreateImage( cvGetSize(src), , );
IplImage *s_plane = cvCreateImage( cvGetSize(src), , );
IplImage *v_plane = cvCreateImage( cvGetSize(src), , ); IplImage *planes[] = {h_plane, s_plane};
cvCvtPixToPlane(hsv, h_plane, s_plane, v_plane, ); //建立直方图结构,并计算
int h_bins = , s_bins = ;
CvHistogram *hist = NULL; //数组每一个元素对应直方图对应维数的bin的个数
int hist_size[] = {h_bins, s_bins};
//hue范围[0,180]
float h_ranges[] = {, };
float s_ranges[] = {, };
float *ranges[] = {h_ranges, s_ranges}; hist = cvCreateHist(, //直方图维数为2维
hist_size, //直方图每一维对应的bin数
CV_HIST_ARRAY, //稠密矩阵存储
ranges, //直方图每一维的维数
); //均匀直方图
//计算直方图
cvCalcHist(planes, hist, , ); //显示2维直方图
int scale = ;
IplImage *hist_img = cvCreateImage(cvSize(h_bins * scale, s_bins * scale),
, );
cvZero( hist_img ); float max_value = ;
cvGetMinMaxHistValue(hist, , &max_value, , ); for(int h = ; h < h_bins; h++)
{
for(int s = ; s < s_bins; s++)
{
//获取bin对应的最大值
float bin_val = cvQueryHistValue_2D(hist, h, s);
//颜色归一化到[0,255]显示
int intensity = cvRound( bin_val * / max_value);
//显示
cvRectangle(
hist_img,
cvPoint( h*scale, s*scale),
cvPoint( (h+)*scale - , (s+)*scale - ),
CV_RGB(intensity,intensity, intensity),
CV_FILLED
);
}
}
cvNamedWindow("Source", );
cvShowImage("Source", src); cvNamedWindow("H-S Histogram", );
cvShowImage("H-S Histogram", hist_img);
cvWaitKey(); return ;
}

OpenCV处理直方图的更多相关文章

  1. 【计算机视觉】OpenCV中直方图处理函数简述

    计算直方图calcHist 直方图是对数据集合的统计 ,并将统计结果分布于一系列提前定义的bins中.这里的数据不只指的是灰度值 ,统计数据可能是不论什么能有效描写叙述图像的特征. 如果有一个矩阵包括 ...

  2. opencv——图像直方图与反向投影

    引言 在图像处理中,对于直方图这个概念,肯定不会陌生.但是其原理真的可以信手拈来吗? 本文篇幅有点长,在此列个目录,大家可以跳着看: 分析图像直方图的概念,以及opencv函数calcHist()对于 ...

  3. opencv 比较直方图方式 进行人脸检测对比

    完整opencv(emgucv)人脸.检测.采集.识别.匹配.对比 //成对几何直方图匹配               public static string MatchHist()         ...

  4. 【OpenCV】直方图

    今天写直方图,学了几个相关函数 1. mixChannels void mixChannels(const Mat* src, int nsrc, Mat* dst, int ndst, const ...

  5. Opencv——灰度直方图

    灰度直方图是灰度级的函数,它表示图像中具有某种灰度级的像素的个数,反映了图像中某种灰度出现的频率. 如果将图像总像素亮度(灰度级别)看成是一个随机变量,则其分布情况就反映了图像的统计特性,这可用pro ...

  6. OpenCV 之 直方图处理

    1  图像直方图 1.1  定义 统计各个像素值,在整幅图像中出现次数的一个分布函数.        1.2  标准化 $\quad p_r(r_k) = \frac{n_k}{MN} \qquad ...

  7. 【Opencv】直方图函数 calchist()

    calchist函数需要包含头文件 #include <opencv2/imgproc/imgproc.hpp> 函数声明(三个重载 calchist函数): //! computes t ...

  8. opencv图像直方图均衡化及其原理

    直方图均衡化是什么有什么用 先说什么是直方图均衡化,通俗的说,以灰度图为例,原图的某一个像素为x,经过某个函数变为y.形成新的图.新的图的灰度值的分布是均匀的,这个过程就叫直方图均衡化. 图像直方图均 ...

  9. opencv 7 直方图与匹配

    图像直方图概述 直方图的计算与绘制 计算直方图:calcHist()函数 找寻最值:minMaxLoc()函数 示例程序:绘制H-S直方图 #include "opencv2/highgui ...

随机推荐

  1. pycharm 取消自动保存

    pycharm默认是自动保存的,习惯自己按 ctrl + s 的可以进行如下设置: 菜单File -> Settings... -> Appearance & Behavior - ...

  2. unity脚本封装成dll

    先申明一下这样做是有需要的.当我们需要把脚本提供给第三方使用,而又不希望对方看到具体的实现过程,这时候就需要将代码封装编译成dll文件,供第三方调用.或是多个项目都要用到同一个模块或同样的功能,则可以 ...

  3. ElasticStack系列之六 & 版本冲突处理之乐观锁

    悲观并发控制(PCC) 这一点在关系数据库中被广泛使用.假设这种情况很容易发生,我们就可以阻止对这一资源的访问.典型的例子就是当我们在读取一个数据前先锁定这一行,然后确保只有读取到数据的这个线程可以修 ...

  4. ROI POOLING 介绍

    转自 https://blog.csdn.net/gbyy42299/article/details/80352418 Faster rcnn的整体构架: 训练的大致过程: 1.图片先缩放到MxN的尺 ...

  5. Redis学习四:解析配置文件 redis.conf

    一.它在哪 地址: 思考:为什么要将它拷贝出来单独执行? 二.Units单位 1 配置大小单位,开头定义了一些基本的度量单位,只支持bytes,不支持bit 2 对大小写不敏感 三.INCLUDES包 ...

  6. css文字超出显示省略号

    单号: white-space:nowrap; overflow:hidden; text-overflow:ellipsis; 多行: word-break: break-all; text-ove ...

  7. javascript 千分

    var str = '123456789'; function division(str){ var arr = str.split(''), len = arr.length, i = 3; whi ...

  8. BFS 两个重要性质

    对于进行广度优先搜索的队列中,应该始终满足两个性质:   性质1:若队首为第i层拓展到的节点,则队列中最多只能存在第i层和第i+1层的节点,不可能出现3层节点.   性质2:队列中的元素会严格按照层数 ...

  9. summernote 文本编辑器使用时,选择上传图片、链接、录像时,弹出的对话框被遮挡住

    更多内容推荐微信公众号,欢迎关注: 即问题如下链接内的情况: http://bbs.csdn.net/topics/392004332 这个一般属于CSS中样式出现了问题,可以在点开的时候,F12查看 ...

  10. c# 超长字符串截取固定长度后显示...(超长后面显示点点点) 通用方法

    通用方法: 此方法是采用unicode编码方式,一个汉字为2个字节,一个数字or字母是1个字节,此方法传入的第二个长度参数是unicode长度. 所以不用考虑截取的字符串是汉字还是英文字母的问题,参数 ...