前景检测算法_4(opencv自带GMM)

2024-01-25 15:48

本文主要是介绍前景检测算法_4(opencv自带GMM),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

  前面已经有3篇博文介绍了背景减图方面相关知识(见下面的链接),在第3篇博文中自己也实现了gmm简单算法,但效果不是很好,下面来体验下opencv自带2个gmm算法。

  opencv实现背景减图法1(codebook和平均背景法)

  http://www.cnblogs.com/tornadomeet/archive/2012/04/08/2438158.html

  opencv实现背景减图法2(帧差法)

  http://www.cnblogs.com/tornadomeet/archive/2012/05/01/2477629.html

  opencv实现背景减图法3(GMM)

  http://www.cnblogs.com/tornadomeet/archive/2012/06/02/2531565.html

  工程环境opencv2.3.1+vs2010

  实现功能:与上面第三篇博文一样,完成动态背景的训练,来检测前景。

  数据来源和前面的一样: http://research.microsoft.com/en-us/um/people/jckrumm/WallFlower/TestImages.htm 由于该数据是286张bmp格式的图片,所以用的前200张图片来作为GMM参数训练,后186张作为测试。训练的过程中树枝被很大幅度的摆动,测试过程中有行人走动,该行人是需要迁就检测的部分。

  Opencv自带的gmm算法1的实验结果如下:

  

  

  

  其工程代码如下:

 

  1 // gmm_wavetrees.cpp : 定义控制台应用程序的入口点。2 //3 4 #include "stdafx.h"5 6 #include "opencv2/core/core.hpp"7 #include "opencv2/video/background_segm.hpp"8 #include "opencv2/highgui/highgui.hpp"9 #include "opencv2/imgproc/imgproc.hpp"10 #include <stdio.h>11 12 using namespace std;13 using namespace cv;14 15 //this is a sample for foreground detection functions16 string src_img_name="WavingTrees/b00";17 const char *src_img_name1;18 Mat img, fgmask, fgimg;19 int i=-1;20 char chari[500];21 bool update_bg_model = true;22 bool pause=false;23 24 //第一种gmm,用的是KaewTraKulPong, P. and R. Bowden (2001).25 //An improved adaptive background mixture model for real-time tracking with shadow detection.26 BackgroundSubtractorMOG bg_model;27 28 void refineSegments(const Mat& img, Mat& mask, Mat& dst)29 {30     int niters = 3;31 32     vector<vector<Point> > contours;33     vector<Vec4i> hierarchy;34 35     Mat temp;36 37     dilate(mask, temp, Mat(), Point(-1,-1), niters);//膨胀,3*3的element,迭代次数为niters38     erode(temp, temp, Mat(), Point(-1,-1), niters*2);//腐蚀39     dilate(temp, temp, Mat(), Point(-1,-1), niters);40 41     findContours( temp, contours, hierarchy, CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE );//找轮廓42 43     dst = Mat::zeros(img.size(), CV_8UC3);44 45     if( contours.size() == 0 )46         return;47 48     // iterate through all the top-level contours,49     // draw each connected component with its own random color50     int idx = 0, largestComp = 0;51     double maxArea = 0;52 53     for( ; idx >= 0; idx = hierarchy[idx][0] )//这句没怎么看懂54     {55         const vector<Point>& c = contours[idx];56         double area = fabs(contourArea(Mat(c)));57         if( area > maxArea )58         {59             maxArea = area;60             largestComp = idx;//找出包含面积最大的轮廓61         }62     }63     Scalar color( 0, 255, 0 );64     drawContours( dst, contours, largestComp, color, CV_FILLED, 8, hierarchy );65 }66 67 int main(int argc, const char** argv)68 {69     bg_model.noiseSigma = 10;70     img=imread("WavingTrees/b00000.bmp");71     if(img.empty())72     {73         namedWindow("image",1);//不能更改窗口74         namedWindow("foreground image",1);75         namedWindow("mean background image", 1);76     }77     for(;;)78     {79         if(!pause)80         {81         i++;82         itoa(i,chari,10);83         if(i<10)84         {85             src_img_name+="00";86         }87         else if(i<100)88         {89             src_img_name+="0";90         }91         else if(i>285)92         {93             i=-1;94         }95         if(i>=230)96             update_bg_model=false;97         else update_bg_model=true;98 99         src_img_name+=chari;
100         src_img_name+=".bmp";
101     
102         img=imread(src_img_name);
103         if( img.empty() )
104             break;
105     
106         //update the model
107         bg_model(img, fgmask, update_bg_model ? 0.005 : 0);//计算前景mask图像,其中输出fgmask为8-bit二进制图像,第3个参数为学习速率
108         refineSegments(img, fgmask, fgimg);
109 
110         imshow("image", img);
111         imshow("foreground image", fgimg);
112 
113         src_img_name="WavingTrees/b00";
114 
115         }
116         char k = (char)waitKey(80);
117         if( k == 27 ) break;
118 
119         if( k == ' ' )
120         {
121             pause=!pause;
122         }        
123     }
124 
125     return 0;
126 }

 

 

  Opencv自带的gmm算法2的实验结果如下:

  

  

  

 

  其工程代码如下:

 

  1 // gmm2_wavetrees.cpp : 定义控制台应用程序的入口点。2 //3 4 #include "stdafx.h"5 6 #include "opencv2/core/core.hpp"7 #include "opencv2/video/background_segm.hpp"8 #include "opencv2/highgui/highgui.hpp"9 #include "opencv2/imgproc/imgproc.hpp"10 #include <stdio.h>11 12 using namespace std;13 using namespace cv;14 15 //this is a sample for foreground detection functions16 string src_img_name="WavingTrees/b00";17 const char *src_img_name1;18 Mat img, fgmask, fgimg;19 int i=-1;20 char chari[500];21 bool update_bg_model = true;22 bool pause=false;23 24 //第一种gmm,用的是KaewTraKulPong, P. and R. Bowden (2001).25 //An improved adaptive background mixture model for real-time tracking with shadow detection.26 BackgroundSubtractorMOG2 bg_model;27 28 void refineSegments(const Mat& img, Mat& mask, Mat& dst)29 {30     int niters = 3;31 32     vector<vector<Point> > contours;33     vector<Vec4i> hierarchy;34 35     Mat temp;36 37     dilate(mask, temp, Mat(), Point(-1,-1), niters);38     erode(temp, temp, Mat(), Point(-1,-1), niters*2);39     dilate(temp, temp, Mat(), Point(-1,-1), niters);40 41     findContours( temp, contours, hierarchy, CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE );42 43     dst = Mat::zeros(img.size(), CV_8UC3);44 45     if( contours.size() == 0 )46         return;47 48     // iterate through all the top-level contours,49     // draw each connected component with its own random color50     int idx = 0, largestComp = 0;51     double maxArea = 0;52 53     for( ; idx >= 0; idx = hierarchy[idx][0] )54     {55         const vector<Point>& c = contours[idx];56         double area = fabs(contourArea(Mat(c)));57         if( area > maxArea )58         {59             maxArea = area;60             largestComp = idx;61         }62     }63     Scalar color( 255, 0, 0 );64     drawContours( dst, contours, largestComp, color, CV_FILLED, 8, hierarchy );65 }66 67 int main(int argc, const char** argv)68 {69     img=imread("WvingTrees/b00000.bmp");70     if(img.empty())71     {72         namedWindow("image",1);//不能更改窗口73         //cvNamedWindow("image",0);74         namedWindow("foreground image",1);75     //    namedWindow("mean background image", 1);76     }77     for(;;)78     {79         if(!pause)80         {81             i++;82             itoa(i,chari,10);83             if(i<10)84             {85                 src_img_name+="00";86             }87             else if(i<100)88             {89                 src_img_name+="0";90             }91             else if(i>285)92             {93                 i=-1;94             }95         //    if(i>=230)96         //        update_bg_model=false;97         //    else update_bg_model=true;98 99             src_img_name+=chari;
100             src_img_name+=".bmp";
101 
102             img=imread(src_img_name);
103             if( img.empty() )
104                 break;
105 
106             //update the model
107             bg_model(img, fgmask, update_bg_model ? 0.005 : 0);//计算前景mask图像,其中输出fgmask为8-bit二进制图像,第3个参数为学习速率
108             refineSegments(img, fgmask, fgimg);
109 
110             imshow("foreground image", fgimg);
111             imshow("image", img);
112         
113             src_img_name="WavingTrees/b00";
114 
115         }
116         char k = (char)waitKey(100);
117         if( k == 27 ) break;
118 
119         if( k == ' ' )
120         {
121             pause=!pause;
122         }
123     }
124 
125     return 0;
126 }

 

 

  可以看出gmm1效果比gmm2的好,但是研究发现,gmm2是在gmm1上改进的,不会越该越差吧,除非2个函数的使用方法不同(虽然函数形式一样),也就是说相同的参数值对函数功能的影响不同。以后有时间在研究了。

这篇关于前景检测算法_4(opencv自带GMM)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/643760

相关文章

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形