171 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			171 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <iostream>
 | |
| #include <string>
 | |
| 
 | |
| #include "opencv2/core/core.hpp"
 | |
| #include "opencv2/gpu/gpu.hpp"
 | |
| #include "opencv2/highgui/highgui.hpp"
 | |
| 
 | |
| using namespace std;
 | |
| using namespace cv;
 | |
| using namespace cv::gpu;
 | |
| 
 | |
| enum Method
 | |
| {
 | |
|     FGD_STAT,
 | |
|     MOG,
 | |
|     MOG2,
 | |
|     GMG
 | |
| };
 | |
| 
 | |
| int main(int argc, const char** argv)
 | |
| {
 | |
|     cv::CommandLineParser cmd(argc, argv,
 | |
|         "{ c | camera | false       | use camera }"
 | |
|         "{ f | file   | 768x576.avi | input video file }"
 | |
|         "{ m | method | mog         | method (fgd, mog, mog2, gmg) }"
 | |
|         "{ h | help   | false       | print help message }");
 | |
| 
 | |
|     if (cmd.get<bool>("help"))
 | |
|     {
 | |
|         cout << "Usage : bgfg_segm [options]" << endl;
 | |
|         cout << "Avaible options:" << endl;
 | |
|         cmd.printParams();
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     bool useCamera = cmd.get<bool>("camera");
 | |
|     string file = cmd.get<string>("file");
 | |
|     string method = cmd.get<string>("method");
 | |
| 
 | |
|     if (method != "fgd"
 | |
|         && method != "mog"
 | |
|         && method != "mog2"
 | |
|         && method != "gmg")
 | |
|     {
 | |
|         cerr << "Incorrect method" << endl;
 | |
|         return -1;
 | |
|     }
 | |
| 
 | |
|     Method m = method == "fgd" ? FGD_STAT :
 | |
|                method == "mog" ? MOG :
 | |
|                method == "mog2" ? MOG2 :
 | |
|                                   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);
 | |
| 
 | |
|     FGDStatModel fgd_stat;
 | |
|     MOG_GPU mog;
 | |
|     MOG2_GPU mog2;
 | |
|     GMG_GPU gmg;
 | |
|     gmg.numInitializationFrames = 40;
 | |
| 
 | |
|     GpuMat d_fgmask;
 | |
|     GpuMat d_fgimg;
 | |
|     GpuMat d_bgimg;
 | |
| 
 | |
|     Mat fgmask;
 | |
|     Mat fgimg;
 | |
|     Mat bgimg;
 | |
| 
 | |
|     switch (m)
 | |
|     {
 | |
|     case FGD_STAT:
 | |
|         fgd_stat.create(d_frame);
 | |
|         break;
 | |
| 
 | |
|     case MOG:
 | |
|         mog(d_frame, d_fgmask, 0.01f);
 | |
|         break;
 | |
| 
 | |
|     case MOG2:
 | |
|         mog2(d_frame, d_fgmask);
 | |
|         break;
 | |
| 
 | |
|     case GMG:
 | |
|         gmg.initialize(d_frame.size());
 | |
|         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 FGD_STAT:
 | |
|             fgd_stat.update(d_frame);
 | |
|             d_fgmask = fgd_stat.foreground;
 | |
|             d_bgimg = fgd_stat.background;
 | |
|             break;
 | |
| 
 | |
|         case MOG:
 | |
|             mog(d_frame, d_fgmask, 0.01f);
 | |
|             mog.getBackgroundImage(d_bgimg);
 | |
|             break;
 | |
| 
 | |
|         case MOG2:
 | |
|             mog2(d_frame, d_fgmask);
 | |
|             mog2.getBackgroundImage(d_bgimg);
 | |
|             break;
 | |
| 
 | |
|         case GMG:
 | |
|             gmg(d_frame, d_fgmask);
 | |
|             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;
 | |
| }
 | 
