 4036f6a3d0
			
		
	
	4036f6a3d0
	
	
	
		
			
			Conflicts: apps/CMakeLists.txt modules/contrib/CMakeLists.txt modules/core/include/opencv2/core/version.hpp modules/imgproc/include/opencv2/imgproc/imgproc.hpp modules/java/generator/gen_java.py modules/ocl/include/opencv2/ocl/ocl.hpp modules/ocl/src/cl_runtime/cl_runtime.cpp modules/ocl/src/columnsum.cpp modules/ocl/src/filtering.cpp modules/ocl/src/imgproc.cpp modules/ocl/test/main.cpp modules/ocl/test/test_color.cpp modules/ocl/test/test_imgproc.cpp samples/gpu/CMakeLists.txt
		
			
				
	
	
		
			170 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			170 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <iostream>
 | |
| #include <string>
 | |
| 
 | |
| #include "opencv2/core.hpp"
 | |
| #include "opencv2/core/utility.hpp"
 | |
| #include "opencv2/cudabgsegm.hpp"
 | |
| #include "opencv2/video.hpp"
 | |
| #include "opencv2/highgui.hpp"
 | |
| 
 | |
| using namespace std;
 | |
| using namespace cv;
 | |
| using namespace cv::cuda;
 | |
| 
 | |
| enum Method
 | |
| {
 | |
|     MOG,
 | |
|     MOG2,
 | |
|     GMG,
 | |
|     FGD_STAT
 | |
| };
 | |
| 
 | |
| int main(int argc, const char** argv)
 | |
| {
 | |
|     cv::CommandLineParser cmd(argc, argv,
 | |
|         "{ c camera |             | use camera }"
 | |
|         "{ f file   | 768x576.avi | input video file }"
 | |
|         "{ m method | mog         | method (mog, mog2, gmg, fgd) }"
 | |
|         "{ h help   |             | print help message }");
 | |
| 
 | |
|     if (cmd.has("help") || !cmd.check())
 | |
|     {
 | |
|         cmd.printMessage();
 | |
|         cmd.printErrors();
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     bool useCamera = cmd.has("camera");
 | |
|     string file = cmd.get<string>("file");
 | |
|     string method = cmd.get<string>("method");
 | |
| 
 | |
|     if (method != "mog"
 | |
|         && method != "mog2"
 | |
|         && method != "gmg"
 | |
|         && method != "fgd")
 | |
|     {
 | |
|         cerr << "Incorrect method" << endl;
 | |
|         return -1;
 | |
|     }
 | |
| 
 | |
|     Method m = method == "mog" ? MOG :
 | |
|                method == "mog2" ? MOG2 :
 | |
|                method == "fgd" ? FGD_STAT :
 | |
|                                   GMG;
 | |
| 
 | |
|     VideoCapture cap;
 | |
| 
 | |
|     if (useCamera)
 | |
|         cap.open(0);
 | |
|     else
 | |
|         cap.open(file);
 | |
| 
 | |
|     if (!cap.isOpened())
 | |
|     {
 | |
|         cerr << "can not open camera or video file" << endl;
 | |
|         return -1;
 | |
|     }
 | |
| 
 | |
|     Mat frame;
 | |
|     cap >> frame;
 | |
| 
 | |
|     GpuMat d_frame(frame);
 | |
| 
 | |
|     Ptr<BackgroundSubtractor> mog = cuda::createBackgroundSubtractorMOG();
 | |
|     Ptr<BackgroundSubtractor> mog2 = cuda::createBackgroundSubtractorMOG2();
 | |
|     Ptr<BackgroundSubtractor> gmg = cuda::createBackgroundSubtractorGMG(40);
 | |
|     Ptr<BackgroundSubtractor> fgd = cuda::createBackgroundSubtractorFGD();
 | |
| 
 | |
|     GpuMat d_fgmask;
 | |
|     GpuMat d_fgimg;
 | |
|     GpuMat d_bgimg;
 | |
| 
 | |
|     Mat fgmask;
 | |
|     Mat fgimg;
 | |
|     Mat bgimg;
 | |
| 
 | |
|     switch (m)
 | |
|     {
 | |
|     case MOG:
 | |
|         mog->apply(d_frame, d_fgmask, 0.01);
 | |
|         break;
 | |
| 
 | |
|     case MOG2:
 | |
|         mog2->apply(d_frame, d_fgmask);
 | |
|         break;
 | |
| 
 | |
|     case GMG:
 | |
|         gmg->apply(d_frame, d_fgmask);
 | |
|         break;
 | |
| 
 | |
|     case FGD_STAT:
 | |
|         fgd->apply(d_frame, d_fgmask);
 | |
|         break;
 | |
|     }
 | |
| 
 | |
|     namedWindow("image", WINDOW_NORMAL);
 | |
|     namedWindow("foreground mask", WINDOW_NORMAL);
 | |
|     namedWindow("foreground image", WINDOW_NORMAL);
 | |
|     if (m != GMG)
 | |
|     {
 | |
|         namedWindow("mean background image", WINDOW_NORMAL);
 | |
|     }
 | |
| 
 | |
|     for(;;)
 | |
|     {
 | |
|         cap >> frame;
 | |
|         if (frame.empty())
 | |
|             break;
 | |
|         d_frame.upload(frame);
 | |
| 
 | |
|         int64 start = cv::getTickCount();
 | |
| 
 | |
|         //update the model
 | |
|         switch (m)
 | |
|         {
 | |
|         case MOG:
 | |
|             mog->apply(d_frame, d_fgmask, 0.01);
 | |
|             mog->getBackgroundImage(d_bgimg);
 | |
|             break;
 | |
| 
 | |
|         case MOG2:
 | |
|             mog2->apply(d_frame, d_fgmask);
 | |
|             mog2->getBackgroundImage(d_bgimg);
 | |
|             break;
 | |
| 
 | |
|         case GMG:
 | |
|             gmg->apply(d_frame, d_fgmask);
 | |
|             break;
 | |
| 
 | |
|         case FGD_STAT:
 | |
|             fgd->apply(d_frame, d_fgmask);
 | |
|             fgd->getBackgroundImage(d_bgimg);
 | |
|             break;
 | |
|         }
 | |
| 
 | |
|         double fps = cv::getTickFrequency() / (cv::getTickCount() - start);
 | |
|         std::cout << "FPS : " << fps << std::endl;
 | |
| 
 | |
|         d_fgimg.create(d_frame.size(), d_frame.type());
 | |
|         d_fgimg.setTo(Scalar::all(0));
 | |
|         d_frame.copyTo(d_fgimg, d_fgmask);
 | |
| 
 | |
|         d_fgmask.download(fgmask);
 | |
|         d_fgimg.download(fgimg);
 | |
|         if (!d_bgimg.empty())
 | |
|             d_bgimg.download(bgimg);
 | |
| 
 | |
|         imshow("image", frame);
 | |
|         imshow("foreground mask", fgmask);
 | |
|         imshow("foreground image", fgimg);
 | |
|         if (!bgimg.empty())
 | |
|             imshow("mean background image", bgimg);
 | |
| 
 | |
|         int key = waitKey(30);
 | |
|         if (key == 27)
 | |
|             break;
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 |