opencv 直方图反向投影

转载至:http://www.cnblogs.com/zsb517/archive/2012/06/20/2556508.html

直方图反向投影式通过给定的直方图信息,在图像找到相应的像素分布区域,opencv提供两种算法,一个是基于像素的,一个是基于块的。

使用方法不写了,可以参考一下几个网站:

直方图反向投影参考1

直方图参考2

 

测试例子1:灰度直方图反向投影


IplImage * image= cvLoadImage("22.jpg");  
IplImage * image2= cvLoadImage("2.jpg");  
int hist_size=256;  
float range[] = {0,255};  
float* ranges[]={range};  IplImage* gray_plane = cvCreateImage(cvGetSize(image),8,1);  
cvCvtColor(image,gray_plane,CV_BGR2GRAY);  
CvHistogram* gray_hist = cvCreateHist(1,&hist_size,CV_HIST_ARRAY,ranges,1);  
cvCalcHist(&gray_plane,gray_hist,0,0);  
//cvNormalizeHist(gray_hist,1.0);  IplImage* gray_plane2 = cvCreateImage(cvGetSize(image2),8,1);  
cvCvtColor(image2,gray_plane2,CV_BGR2GRAY);  
//CvHistogram* gray_hist2 = cvCreateHist(1,&hist_size,CV_HIST_ARRAY,ranges,1);  
//cvCalcHist(&gray_plane2,gray_hist2,0,0);  
//cvNormalizeHist(gray_hist2,1.0);  
IplImage* dst = cvCreateImage(cvGetSize(gray_plane2),IPL_DEPTH_8U,1);  cvCalcBackProject(&gray_plane2, dst ,gray_hist);
cvEqualizeHist(dst,dst);
//产生的图像太暗,做了一些直方图均衡cvNamedWindow( "dst");  
cvShowImage("dst",dst);  
cvNamedWindow( "src");  
cvShowImage( "src", image2 );  
cvNamedWindow( "templ");  
cvShowImage( "templ", image );  
cvWaitKey();

效果图:

 2
第一个图为源图像,中间的那个小图像是产生用于反向投影的直方图的图像,最后的用直方图均衡化后的结果图像,可以看到,苹果的像素位置几被找到了。

 

测试例子2:彩色直方图反向投影测试


IplImage*src= cvLoadImage("myhand2.jpg", 1);  
IplImage*templ=cvLoadImage("myhand3.jpg",1);cvNamedWindow( "Source" );  
cvShowImage( "Source", src );  IplImage* h_plane2 = cvCreateImage( cvGetSize(src), 8, 1 );      
IplImage* s_plane2 = cvCreateImage( cvGetSize(src), 8, 1 );    
IplImage* v_plane2 = cvCreateImage( cvGetSize(src), 8, 1); 
IplImage* planes2[] = { h_plane2, s_plane2,v_plane2 };IplImage* hsv2 = cvCreateImage( cvGetSize(src), 8, 3 );
cvCvtColor( src, hsv2, CV_BGR2HSV );    
cvSplit( hsv2, h_plane2, s_plane2, v_plane2, 0 );
printf("h%d",h_plane2->widthStep);
printf("s%d",h_plane2->widthStep);
printf("v%d",h_plane2->widthStep);IplImage* h_plane = cvCreateImage( cvGetSize(templ), 8, 1 );      
IplImage* s_plane = cvCreateImage( cvGetSize(templ), 8, 1 );    
IplImage* v_plane = cvCreateImage( cvGetSize(templ), 8, 1);    
IplImage* planes[] = { h_plane, s_plane,v_plane };
IplImage* hsv = cvCreateImage( cvGetSize(templ), 8, 3 );  
cvCvtColor( templ, hsv, CV_BGR2HSV );    
cvSplit( hsv, h_plane, s_plane, v_plane, 0 );
printf("h%d\n",h_plane->widthStep);
printf("s%d\n",s_plane->widthStep);
printf("v%d\n",v_plane->widthStep);int h_bins = 16, s_bins = 16,v_bins=16;
int hist_size[] = {h_bins, s_bins,v_bins};
float h_ranges[] = {0,255};
float s_ranges[] = {0,255};
float v_ranges[] = {0,255};
float* ranges[] = { h_ranges, s_ranges,v_ranges};
CvHistogram* hist;
hist = cvCreateHist( 3, hist_size, CV_HIST_ARRAY, ranges, 1 ); 
cvCalcHist( planes, hist, 0, 0 );
//1.double a=1.f;
//2.cvNormalizeHist(hist,a);
//templ's hist is just calculateIplImage*back_project=cvCreateImage(cvGetSize(src),8,1);//!!归一,把改成,就弹出对话框,说planes的steps不是一致的!cvZero(back_project);                                  //但是我去掉归一,改成就可以显示//NOW we begin calculate back projectcvCalcBackProject(planes2,back_project,hist);cvNamedWindow( "back_project" );  
cvShowImage( "back_project", back_project );  cvWaitKey(0);

测试结果:

 QQ截图20120620142552

手的肤色位置基本找到了,但是有一个问题,在做直方图反向的时候,直方图分级是16等分,并不是256等分,下图是32等分和8等分的图像效果:

4      32等分 5 8等分

程序里面使用了SHV分量,也算是肤色检测的一个实例,里面的颜色区分很明显,所有采用大一点的区域统计,能更好的找到肤色的位置,如果采用很细的颜色区分,光照的影响也会考虑进去了。

测试例子3:基于块的直方图投影

这种方法速度很慢,模版图像别弄的太大了。


IplImage*src= cvLoadImage("2.jpg", 1);  
IplImage*templ=cvLoadImage("22.jpg",1);cvNamedWindow( "Source" );  
cvShowImage( "Source", src );  IplImage* h_plane2 = cvCreateImage( cvGetSize(src), 8, 1 );      
IplImage* s_plane2 = cvCreateImage( cvGetSize(src), 8, 1 );    
IplImage* v_plane2 = cvCreateImage( cvGetSize(src), 8, 1); 
IplImage* planes2[] = { h_plane2, s_plane2,v_plane2 };IplImage* hsv2 = cvCreateImage( cvGetSize(src), 8, 3 );
cvCvtColor( src, hsv2, CV_BGR2HSV );    
cvSplit( hsv2, h_plane2, s_plane2, v_plane2, 0 );
printf("h%d",h_plane2->widthStep);
printf("s%d",h_plane2->widthStep);
printf("v%d",h_plane2->widthStep);IplImage* h_plane = cvCreateImage( cvGetSize(templ), 8, 1 );      
IplImage* s_plane = cvCreateImage( cvGetSize(templ), 8, 1 );    
IplImage* v_plane = cvCreateImage( cvGetSize(templ), 8, 1);    
IplImage* planes[] = { h_plane, s_plane,v_plane };
IplImage* hsv = cvCreateImage( cvGetSize(templ), 8, 3 );  
cvCvtColor( templ, hsv, CV_BGR2HSV );    
cvSplit( hsv, h_plane, s_plane, v_plane, 0 );
printf("h%d\n",h_plane->widthStep);
printf("s%d\n",s_plane->widthStep);
printf("v%d\n",v_plane->widthStep);int h_bins = 16, s_bins = 16,v_bins=16;
int hist_size[] = {h_bins, s_bins,v_bins};
float h_ranges[] = {0,255};
float s_ranges[] = {0,255};
float v_ranges[] = {0,255};
float* ranges[] = { h_ranges, s_ranges,v_ranges};
CvHistogram* hist;
hist = cvCreateHist( 3, hist_size, CV_HIST_ARRAY, ranges, 1 ); 
cvCalcHist( planes, hist, 0, 0 );CvSize temp ;
temp.height = src->height - templ->height + 1;
temp.width  = src->width - templ->width + 1;
IplImage*back_project=cvCreateImage(temp,IPL_DEPTH_32F,1);//!!归一,把改成,就弹出对话框,说planes的steps不是一致的!cvZero(back_project);                                     //但是我去掉归一,改成就可以显示
cvCalcBackProjectPatch(planes2, back_project, cvGetSize(templ), hist,CV_COMP_INTERSECT ,1);cvNamedWindow( "back_project" );  
cvShowImage( "back_project", back_project );  cvWaitKey(0);


测试图像:

当模版图像小雨目标的时候,作为区域检测器,测试如下:可以找到手区域

6

当模版等于目标的时候,测试如下:输出图像,较亮的部分就是人的头部大致位置

7

基于块的反向,速度太慢了。



转载于:https://www.cnblogs.com/zfluo/p/5131870.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257186.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

request请求在Struts2中的处理步骤

2019独角兽企业重金招聘Python工程师标准>>> 一个请求在Struts2框架中的处理大概分为以下几个步骤 1 客户端初始化一个指向Servlet容器(例如Tomcat)的请求 2 这个请求经过一系列的过滤器(Filter)(这些过滤…

vs联合torch,ZED相机api,opencv建立C++项目

ZED相机api下载及cmake教程 generate产生工程文件后打开,配置如下: 将ZED项目作为启动项 然后在main.cpp中写入自己的工程代码即可,运行也在release X64下进行 注:cmake之前源文件下main.cpp,也就是tutorial 1 - h…

使用DataGridView数据窗口控件,构建用户快速输入体验

使用DataGridView数据窗口控件,构建用户快速输入体验 在“随风飘散” 博客里面,介绍了一个不错的DataGridView数据窗口控件《DataGridView数据窗口控件开发方法及其源码提供下载》,这种控件在有些场合下,还是非常直观的。因为&…

pip安装

下载pip安装包,解压。复制到C:\Users\administrator\下,用cmd打开当前文件夹,用Python安装, Python setup.py install 安装完之后记得把Python根目录下的scripts也放在环境变量里。 以上是我pip安装的成功例子,可能不…

手把手教你用1行代码实现人脸识别 -- Python Face_recognition

2019独角兽企业重金招聘Python工程师标准>>> 环境要求: Ubuntu17.10Python 2.7.14环境搭建: 1. 安装 Ubuntu17.10 > 安装步骤在这里 2. 安装 Python2.7.14 (Ubuntu17.10 默认Python版本为2.7.14) 3. 安装 git 、cmake 、 python-pip # 安装…

pip安装的库导入pycharm中

用pip安装了一些库,但pycharm中却没有,解决方法是

一个关于解决序列化问题的编程技巧

在前一篇文章中我曾经说过,现在正在做一个小小的框架以实现采用统一的API实现对上下文(Context)信息的统一管理。这个框架同时支持Web和GUI应用,并支持跨线程传递和跨域传递(这里指在WCF服务调用中实现客户端到服务端隐…

踩坑之路anaconda创建虚拟环境

浑浑噩噩的过了三年渣硕生涯,虽然说自己是搞图像的,但基本是一些机器视觉的东西,最近突然想好好搞搞深度学习这方面,想着那就先搭搭环境跑个demo吧,经历了好多莫名其妙的踩坑操作,demo跑的终于没bug了&…

dns服务器未响应

昨天还好好的,今天打开电脑显示DNS服务器为响应。 解决办法:右击电脑下方图标栏——打开Windows任务管理器——服务——服务(s)——找到DNS client和DHCP client——右击重启

ubuntu安装pytorch镜像修改及下载

ubuntu安装pytorch镜像修改及下载 下载pytorch下载太慢,搞了很长时间,终于改好镜像能快速下载了,记录以下。 1.在/home/用户名/ 下找到/.condarc 文件,可能需要你右击鼠标显示隐藏文件才能显示, 2.把内容修改为清华等镜…

R--线性回归诊断(一)

线性回归诊断--R 【转载时请注明来源】:http://www.cnblogs.com/runner-ljt/ Ljt 勿忘初心 无畏未来 作为一个初学者,水平有限,欢迎交流指正。 在R中线性回归,一般使用lm函数就可以得到线性回归模型,但是得到的模型…

妙趣横生的算法--栈和队列

栈 栈的特点是先进后出,一张图简单介绍一下。 #include "stdio.h" #include "math.h" #include "stdlib.h" #define STACK_INIT_SIZE 20 #define STACKINCRE…

resure挽救笔记本系统和一些相关的操作记录

使用fedora23很久了, 但是感觉不是很流畅, 出现了一些不太稳定的体验, 所以想改到centos7. 因为centos7的很多东西 跟 fedora23 很相近了. 所以应该是无缝过渡是选择32位的系统还是选择64位的系统?还是要使用 32位的 它是90%的人的选择使用, 是普通人的通用选择, 几乎支持linu…

2021-06-08

opencv无法读取mp4文件opencv读取mp4文件时,总是VideoCapture.isopen()返回0,即无法打开cap。解决方法,将opencv安装包的opencv_videoio_ffmpeg451_64文件复制进工程中。

Cocos2d-3.x版的HelloWorld工程分析 (二)

我们HelloWorld 从applicationDidFinishLaunching()后, 大部分人都会从这部分代码开始研究,如果想要研究main函数 如何调用applicationDidFinishLaunching() 传送门 http://blog.csdn.net/hiwoshixiaoyu/article/details/51472707 #include "App…

NO.1 python_人工智能_学习路线

***##学习路线:* 1.python基础 计算机组成原理、python开发环境、python变量、流程控制语句、文件操作、异常处理、模块与包、飞机大战游戏制作等 2.python高级应用 网络编程、并发编程、数据库编程、正则表达式、Linux系统应用、函数的高级应用、python的语法进阶…

iOS开发网络篇—数据缓存

iOS开发网络篇—数据缓存 一、关于同一个URL的多次请求 有时候,对同一个URL请求多次,返回的数据可能都是一样的,比如服务器上的某张图片,无论下载多少次,返回的数据都是一样的。 上面的情况会造成以下问题 &#xff08…

[WinError 10061] 由于目标计算机积极拒绝,无法连接错误解决办法

爬虫的时候会经常出现"[WinError 10061] 由于目标计算机积极拒绝,无法连接"错误这种情况,有可能是LAN口设置不正确 我是在爬取全国天气情况的时候出现的这种错误,后面调了以后可以了1.控制面板——网络和 Internet—— Internet选项…

这门课有什么用?

每个老师都苦恼于学生常问的问题:“某某课学了有什么用?”老师费劲巴拉解释一通,结果还是:然并卵。 一门课有什么用,很难解释得令人信服,因为这和人的认知水平有关。认知水平达不到,解释的多深入…

NO.1_python_scrapy组成爬取多页数据连接数据库配置文件书写

scrapy框架组成及各部分作用 item pipelines: 用于存放需要存储数据的数据模型,一般格式为: #需要存储多少中类型的数据就写多少行,一般是key_value组合 数据名称,即key scrapy.Field()spiders 用于解析返回来的response im…