opencv 反向投影 cvCalcBackProject的示例 ,用图像中某中颜色的区域

在学习 《学习opencv》的cvCalcBackProject时自己写的例子

#include 
#include 
#include 
#include 
#include 

using namespace std;
int main()
{
	IplImage *src = cvLoadImage("f:\\images\\hand00.jpg");
	IplImage *hsv_src = cvCloneImage(src);
	cvCvtColor(src,hsv_src,CV_BGR2HSV);

	IplImage *h_plane_src = cvCreateImage(cvGetSize(src),8,1);
	cvSplit(hsv_src,h_plane_src,NULL,NULL,NULL);
	cvSave("h.xml",h_plane_src);
	int dims = 1;
	int size[] = {180};
	float ranges_h[] ={0,181};
	float *ranges[] = {ranges_h};
	CvHistogram *hist_src = cvCreateHist(1,size,CV_HIST_ARRAY,ranges);
	cvCalcHist(&h_plane_src,hist_src);

	
	IplImage *dst = cvLoadImage("f:\\images\\hand1.jpg");
	IplImage *hsv_dst = cvCreateImage(cvGetSize(dst),8,3);
	cvCvtColor(dst,hsv_dst,CV_BGR2HSV);
	IplImage *h_plane_dst = cvCreateImage(cvGetSize(dst),8,1);
	cvSplit(hsv_dst,h_plane_dst,NULL,NULL,NULL);
	

	IplImage *dst_probability = cvCreateImage(cvGetSize(h_plane_dst),IPL_DEPTH_8U,1);
	cvZero(dst_probability);
	cvCalcBackProject(&h_plane_dst,dst_probability,hist_src);
	cout<

其中hand00.jpg图片为:



第二次读入的图片可为:


输出的结果:



这就是《学习opencv》上的示例图(但没给出源码)

opencv文档中介绍的该算法可以用来搜索物体(英文,查查字典,读起来也简单) :

1. Calculate a hue histogram for the red object assuming the image contains only this object.
The histogram is likely to have a strong maximum, corresponding to red color.
2. Calculate back projection of a hue plane of input image where the object is searched, using
the histogram. Threshold the image.
3. Find connected components in the resulting picture and choose the right component using
some additional criteria, for example, the largest connected component.



按我的理解的话,就是:对于后来的输入图像,backproject未得的图像只是个概率图

比如在原来未hist直方图时,有个像素值BGR(100,200,102)的像素点很多 ,  那么在求得的hist直方图中对应位置的值就越大(概率越大)。

所以呢,如果对目标图使用backproject时,目标图中像素值等于BGR(100,200,102)的像素点的概率越大,表现为cvCalcBackProject得出结果中对应像素位置的灰度值大。


表现在此例中的意思就是: 由于我们只计算了原始图像的HSV色彩空间中的H色度分量。 原始图中,手的肤色对应的色度和黑色对应的色度的像素点是最多的。

那么反向投影到目标图像时, 目标图像像素色度为 手的肤色和黑色对应的色度 的概率越大, 输出的对应位置的灰度图就越大。



下一篇讲使用块搜索由单个物体 在一个大图像中寻找 物体的位置  cvCalcBackProjectPatch 函数

你可能感兴趣的:(opencv)