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…

POJ 2186

//在一张有向无环图G,图G会包含很多环(环里面的点是等价的), //当然可以把环缩成一个点(利用tarjan缩点), //形成一棵树,题目要求是求除他以外的点都指向他,也就是只有一…

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

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

pip安装

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

深入剖析授权在WCF中的实现[共14篇]

I、身份(Identity)与安全主体(Security Principal) 从两个重要的概念谈起:Identity与Principal[上篇] 从两个重要的概念谈起:Identity与Principal[下篇] WCF的三种授权模式 II、Windows用户组授权 基于Wind…

sqlserver 查看锁表,解锁

查看被锁表: 代码如下 复制代码 select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName from sys.dm_tran_locks where resource_typeOBJECT spid 锁表进程 tableName 被锁表名 [more] 解锁: 创建一个临时Table 代码如下…

json2.js参考

json2.js使用參考 json2.js提供了json的序列化和反序列化方法&#xff0c;能够将一个json对象转换成json字符串&#xff0c;也能够将一个json字符串转换成一个json对象。<html><head><script type"text/javascript" src"jquery.js"><…

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

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

pip安装的库导入pycharm中

用pip安装了一些库&#xff0c;但pycharm中却没有&#xff0c;解决方法是

javascript数组浅谈1

最近心血来潮要开始玩博客了&#xff0c;刚好也在看数组这块内容&#xff0c;第一篇就只好拿数组开刀了&#xff0c;自己总结的&#xff0c;有什么不对的地方还请批评指正&#xff0c;还有什么没写到的方面也可以提出来我进行完善&#xff0c;谢谢~~ 首先&#xff0c;大概说说数…

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

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

踩坑之路anaconda创建虚拟环境

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

IP多播技术及其应用

随着全球互联网&#xff08;Internet&#xff09;的迅猛发展&#xff0c;上网人数正以几何级数快速增长&#xff0c;以因特网技术为主导的数据通信在通信业务总量中的比列迅速上升&#xff0c;因特网业务已成为多媒体通信业中发展最为迅速、竞争最为激烈的领域。Internet网络传…

【转载】恼人的函数指针(一)

本文转载自: http://www.cnblogs.com/AnnieKim/archive/2011/11/20/2255813.html#undefined> 这篇是为了加深记忆所写。发现&#xff0c;很多知识若不经过反复的琢磨和动手实践&#xff0c;是很难记得住的。 1&#xff09; 函数指针的初始化。 函数如下&#xff1a; int Com…

dns服务器未响应

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

php分页原理

<?php 1.分页原理所需数据&#xff1a; 总记录数&#xff1a; $records mysql_num_rows() 每页显示&#xff1a; $pagesize 人为定义10 总页数&#xff1a; $pages $records/$pagesize 当前页&#xff1a; $page 自己选择2.分页的sql语句&#xff1a; SELECT * F…

从客户端(CourseIssueContent=P财务审计师岗位认证招生简章BR...)中检测到有潜在危险的 Request.Form 值。...

说明: 请求验证过程检测到有潜在危险的客户端输入值&#xff0c;对请求的处理已经中止。该值可能指示危及应用程序安全的尝试&#xff0c;如跨站点的脚本攻击。通过在 Page 指令或 配置节中设置 validateRequestfalse 可以禁用请求验证。但是&#xff0c;在这种情况下&#xff…

ubuntu安装pytorch镜像修改及下载

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

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

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