156 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <iostream>
 | |
| #include <iomanip>
 | |
| #include <string>
 | |
| #include "opencv2/core.hpp"
 | |
| #include "opencv2/core/utility.hpp"
 | |
| #include "opencv2/highgui.hpp"
 | |
| #include "opencv2/imgproc.hpp"
 | |
| #include "opencv2/contrib.hpp"
 | |
| #include "opencv2/superres.hpp"
 | |
| #include "opencv2/superres/optical_flow.hpp"
 | |
| 
 | |
| using namespace std;
 | |
| using namespace cv;
 | |
| using namespace cv::superres;
 | |
| 
 | |
| #define MEASURE_TIME(op) \
 | |
|     { \
 | |
|         TickMeter tm; \
 | |
|         tm.start(); \
 | |
|         op; \
 | |
|         tm.stop(); \
 | |
|         cout << tm.getTimeSec() << " sec" << endl; \
 | |
|     }
 | |
| 
 | |
| static Ptr<DenseOpticalFlowExt> createOptFlow(const string& name, bool useGpu)
 | |
| {
 | |
|     if (name == "farneback")
 | |
|     {
 | |
|         if (useGpu)
 | |
|             return createOptFlow_Farneback_GPU();
 | |
|         else
 | |
|             return createOptFlow_Farneback();
 | |
|     }
 | |
|     else if (name == "simple")
 | |
|         return createOptFlow_Simple();
 | |
|     else if (name == "tvl1")
 | |
|     {
 | |
|         if (useGpu)
 | |
|             return createOptFlow_DualTVL1_GPU();
 | |
|         else
 | |
|             return createOptFlow_DualTVL1();
 | |
|     }
 | |
|     else if (name == "brox")
 | |
|         return createOptFlow_Brox_GPU();
 | |
|     else if (name == "pyrlk")
 | |
|         return createOptFlow_PyrLK_GPU();
 | |
|     else
 | |
|     {
 | |
|         cerr << "Incorrect Optical Flow algorithm - " << name << endl;
 | |
|     }
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| int main(int argc, const char* argv[])
 | |
| {
 | |
|     CommandLineParser cmd(argc, argv,
 | |
|         "{ v video      |           | Input video }"
 | |
|         "{ o output     |           | Output video }"
 | |
|         "{ s scale      | 4         | Scale factor }"
 | |
|         "{ i iterations | 180       | Iteration count }"
 | |
|         "{ t temporal   | 4         | Radius of the temporal search area }"
 | |
|         "{ f flow       | farneback | Optical flow algorithm (farneback, simple, tvl1, brox, pyrlk) }"
 | |
|         "{ gpu          | false     | Use GPU }"
 | |
|         "{ h help       | false     | Print help message }"
 | |
|     );
 | |
| 
 | |
|     if (cmd.get<bool>("help"))
 | |
|     {
 | |
|         cout << "This sample demonstrates Super Resolution algorithms for video sequence" << endl;
 | |
|         cmd.printMessage();
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     const string inputVideoName = cmd.get<string>("video");
 | |
|     const string outputVideoName = cmd.get<string>("output");
 | |
|     const int scale = cmd.get<int>("scale");
 | |
|     const int iterations = cmd.get<int>("iterations");
 | |
|     const int temporalAreaRadius = cmd.get<int>("temporal");
 | |
|     const string optFlow = cmd.get<string>("flow");
 | |
|     const bool useGpu = cmd.get<bool>("gpu");
 | |
| 
 | |
|     Ptr<SuperResolution> superRes;
 | |
|     if (useGpu)
 | |
|         superRes = createSuperResolution_BTVL1_GPU();
 | |
|     else
 | |
|         superRes = createSuperResolution_BTVL1();
 | |
| 
 | |
|     superRes->set("scale", scale);
 | |
|     superRes->set("iterations", iterations);
 | |
|     superRes->set("temporalAreaRadius", temporalAreaRadius);
 | |
| 
 | |
|     Ptr<DenseOpticalFlowExt> of = createOptFlow(optFlow, useGpu);
 | |
|     if (of.empty())
 | |
|         exit(-1);
 | |
|     superRes->set("opticalFlow", of);
 | |
| 
 | |
|     Ptr<FrameSource> frameSource;
 | |
|     if (useGpu)
 | |
|     {
 | |
|         // Try to use gpu Video Decoding
 | |
|         try
 | |
|         {
 | |
|             frameSource = createFrameSource_Video_GPU(inputVideoName);
 | |
|             Mat frame;
 | |
|             frameSource->nextFrame(frame);
 | |
|         }
 | |
|         catch (const cv::Exception&)
 | |
|         {
 | |
|             frameSource.release();
 | |
|         }
 | |
|     }
 | |
|     if (frameSource.empty())
 | |
|         frameSource = createFrameSource_Video(inputVideoName);
 | |
| 
 | |
|     // skip first frame, it is usually corrupted
 | |
|     {
 | |
|         Mat frame;
 | |
|         frameSource->nextFrame(frame);
 | |
|         cout << "Input           : " << inputVideoName << " " << frame.size() << endl;
 | |
|         cout << "Scale factor    : " << scale << endl;
 | |
|         cout << "Iterations      : " << iterations << endl;
 | |
|         cout << "Temporal radius : " << temporalAreaRadius << endl;
 | |
|         cout << "Optical Flow    : " << optFlow << endl;
 | |
|         cout << "Mode            : " << (useGpu ? "GPU" : "CPU") << endl;
 | |
|     }
 | |
| 
 | |
|     superRes->setInput(frameSource);
 | |
| 
 | |
|     VideoWriter writer;
 | |
| 
 | |
|     for (int i = 0;; ++i)
 | |
|     {
 | |
|         cout << '[' << setw(3) << i << "] : ";
 | |
| 
 | |
|         Mat result;
 | |
|         MEASURE_TIME(superRes->nextFrame(result));
 | |
| 
 | |
|         if (result.empty())
 | |
|             break;
 | |
| 
 | |
|         imshow("Super Resolution", result);
 | |
| 
 | |
|         if (waitKey(1000) > 0)
 | |
|             break;
 | |
| 
 | |
|         if (!outputVideoName.empty())
 | |
|         {
 | |
|             if (!writer.isOpened())
 | |
|                 writer.open(outputVideoName, VideoWriter::fourcc('X', 'V', 'I', 'D'), 25.0, result.size());
 | |
|             writer << result;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 | 
