2011-09-13 19:19:40 +08:00
|
|
|
#include "perf_precomp.hpp"
|
|
|
|
|
|
|
|
#include "opencv2/highgui/highgui.hpp"
|
2012-06-08 01:21:29 +08:00
|
|
|
#include "opencv2/core/internal.hpp"
|
2011-10-27 22:06:06 +08:00
|
|
|
#include "opencv2/flann/flann.hpp"
|
2012-04-30 22:33:52 +08:00
|
|
|
#include "opencv2/opencv_modules.hpp"
|
2011-09-13 19:19:40 +08:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace cv;
|
|
|
|
using namespace perf;
|
2011-12-30 00:46:16 +08:00
|
|
|
using std::tr1::make_tuple;
|
|
|
|
using std::tr1::get;
|
2011-09-13 19:19:40 +08:00
|
|
|
|
2011-10-27 22:06:06 +08:00
|
|
|
#define SURF_MATCH_CONFIDENCE 0.65f
|
|
|
|
#define ORB_MATCH_CONFIDENCE 0.3f
|
|
|
|
#define WORK_MEGAPIX 0.6
|
|
|
|
|
2011-10-19 18:48:45 +08:00
|
|
|
typedef TestBaseWithParam<String> stitch;
|
2011-10-27 22:06:06 +08:00
|
|
|
typedef TestBaseWithParam<String> match;
|
2011-09-13 19:19:40 +08:00
|
|
|
|
2012-06-08 16:11:17 +08:00
|
|
|
#ifdef HAVE_OPENCV_NONFREE
|
2012-04-30 22:33:52 +08:00
|
|
|
#define TEST_DETECTORS testing::Values("surf", "orb")
|
|
|
|
#else
|
|
|
|
#define TEST_DETECTORS testing::Values<String>("orb")
|
|
|
|
#endif
|
|
|
|
|
|
|
|
PERF_TEST_P(stitch, a123, TEST_DETECTORS)
|
2011-09-13 19:19:40 +08:00
|
|
|
{
|
|
|
|
Mat pano;
|
2012-06-08 01:21:29 +08:00
|
|
|
|
2011-09-13 19:19:40 +08:00
|
|
|
vector<Mat> imgs;
|
|
|
|
imgs.push_back( imread( getDataPath("stitching/a1.jpg") ) );
|
|
|
|
imgs.push_back( imread( getDataPath("stitching/a2.jpg") ) );
|
|
|
|
imgs.push_back( imread( getDataPath("stitching/a3.jpg") ) );
|
|
|
|
|
2011-10-19 18:48:45 +08:00
|
|
|
Ptr<detail::FeaturesFinder> featuresFinder = GetParam() == "orb"
|
|
|
|
? (detail::FeaturesFinder*)new detail::OrbFeaturesFinder()
|
|
|
|
: (detail::FeaturesFinder*)new detail::SurfFeaturesFinder();
|
2011-09-13 19:19:40 +08:00
|
|
|
|
2011-10-19 18:48:45 +08:00
|
|
|
Ptr<detail::FeaturesMatcher> featuresMatcher = GetParam() == "orb"
|
2011-10-27 22:06:06 +08:00
|
|
|
? new detail::BestOf2NearestMatcher(false, ORB_MATCH_CONFIDENCE)
|
|
|
|
: new detail::BestOf2NearestMatcher(false, SURF_MATCH_CONFIDENCE);
|
2011-10-19 18:48:45 +08:00
|
|
|
|
2011-12-16 12:42:34 +08:00
|
|
|
declare.time(30 * 20).iterations(20);
|
2011-09-13 19:19:40 +08:00
|
|
|
|
2011-09-29 20:11:18 +08:00
|
|
|
while(next())
|
|
|
|
{
|
|
|
|
Stitcher stitcher = Stitcher::createDefault();
|
2011-10-19 18:48:45 +08:00
|
|
|
stitcher.setFeaturesFinder(featuresFinder);
|
|
|
|
stitcher.setFeaturesMatcher(featuresMatcher);
|
2011-12-30 00:46:16 +08:00
|
|
|
stitcher.setWarper(new SphericalWarper());
|
2011-10-27 22:06:06 +08:00
|
|
|
stitcher.setRegistrationResol(WORK_MEGAPIX);
|
2011-09-29 20:11:18 +08:00
|
|
|
|
|
|
|
startTimer();
|
2012-06-08 11:15:08 +08:00
|
|
|
stitcher.stitch(imgs, pano);
|
2011-09-29 20:11:18 +08:00
|
|
|
stopTimer();
|
|
|
|
}
|
2011-09-13 19:19:40 +08:00
|
|
|
}
|
|
|
|
|
2012-04-30 22:33:52 +08:00
|
|
|
PERF_TEST_P(stitch, b12, TEST_DETECTORS)
|
2011-09-13 19:19:40 +08:00
|
|
|
{
|
|
|
|
Mat pano;
|
2012-06-08 01:21:29 +08:00
|
|
|
|
2011-09-13 19:19:40 +08:00
|
|
|
vector<Mat> imgs;
|
|
|
|
imgs.push_back( imread( getDataPath("stitching/b1.jpg") ) );
|
|
|
|
imgs.push_back( imread( getDataPath("stitching/b2.jpg") ) );
|
|
|
|
|
2011-10-19 18:48:45 +08:00
|
|
|
Ptr<detail::FeaturesFinder> featuresFinder = GetParam() == "orb"
|
|
|
|
? (detail::FeaturesFinder*)new detail::OrbFeaturesFinder()
|
|
|
|
: (detail::FeaturesFinder*)new detail::SurfFeaturesFinder();
|
|
|
|
|
|
|
|
Ptr<detail::FeaturesMatcher> featuresMatcher = GetParam() == "orb"
|
2011-10-27 22:06:06 +08:00
|
|
|
? new detail::BestOf2NearestMatcher(false, ORB_MATCH_CONFIDENCE)
|
|
|
|
: new detail::BestOf2NearestMatcher(false, SURF_MATCH_CONFIDENCE);
|
2011-09-13 19:19:40 +08:00
|
|
|
|
2011-12-16 12:42:34 +08:00
|
|
|
declare.time(30 * 20).iterations(20);
|
2011-09-13 19:19:40 +08:00
|
|
|
|
2011-09-29 20:11:18 +08:00
|
|
|
while(next())
|
|
|
|
{
|
|
|
|
Stitcher stitcher = Stitcher::createDefault();
|
2011-10-19 18:48:45 +08:00
|
|
|
stitcher.setFeaturesFinder(featuresFinder);
|
|
|
|
stitcher.setFeaturesMatcher(featuresMatcher);
|
2011-12-30 00:46:16 +08:00
|
|
|
stitcher.setWarper(new SphericalWarper());
|
2011-10-27 22:06:06 +08:00
|
|
|
stitcher.setRegistrationResol(WORK_MEGAPIX);
|
2011-09-29 20:11:18 +08:00
|
|
|
|
|
|
|
startTimer();
|
2012-06-08 11:15:08 +08:00
|
|
|
stitcher.stitch(imgs, pano);
|
2011-09-29 20:11:18 +08:00
|
|
|
stopTimer();
|
|
|
|
}
|
2011-09-13 19:19:40 +08:00
|
|
|
}
|
2011-10-27 22:06:06 +08:00
|
|
|
|
2012-04-30 22:33:52 +08:00
|
|
|
PERF_TEST_P( match, bestOf2Nearest, TEST_DETECTORS)
|
2011-10-27 22:06:06 +08:00
|
|
|
{
|
|
|
|
Mat img1, img1_full = imread( getDataPath("stitching/b1.jpg") );
|
|
|
|
Mat img2, img2_full = imread( getDataPath("stitching/b2.jpg") );
|
2012-02-14 18:22:34 +08:00
|
|
|
float scale1 = (float)std::min(1.0, sqrt(WORK_MEGAPIX * 1e6 / img1_full.total()));
|
|
|
|
float scale2 = (float)std::min(1.0, sqrt(WORK_MEGAPIX * 1e6 / img2_full.total()));
|
2011-10-27 22:06:06 +08:00
|
|
|
resize(img1_full, img1, Size(), scale1, scale1);
|
|
|
|
resize(img2_full, img2, Size(), scale2, scale2);
|
|
|
|
|
|
|
|
Ptr<detail::FeaturesFinder> finder;
|
|
|
|
Ptr<detail::FeaturesMatcher> matcher;
|
|
|
|
if (GetParam() == "surf")
|
|
|
|
{
|
|
|
|
finder = new detail::SurfFeaturesFinder();
|
|
|
|
matcher = new detail::BestOf2NearestMatcher(false, SURF_MATCH_CONFIDENCE);
|
|
|
|
}
|
|
|
|
else if (GetParam() == "orb")
|
|
|
|
{
|
|
|
|
finder = new detail::OrbFeaturesFinder();
|
|
|
|
matcher = new detail::BestOf2NearestMatcher(false, ORB_MATCH_CONFIDENCE);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
FAIL() << "Unknown 2D features type: " << GetParam();
|
|
|
|
}
|
|
|
|
|
|
|
|
detail::ImageFeatures features1, features2;
|
|
|
|
(*finder)(img1, features1);
|
|
|
|
(*finder)(img2, features2);
|
|
|
|
|
|
|
|
detail::MatchesInfo pairwise_matches;
|
|
|
|
|
|
|
|
declare.in(features1.descriptors, features2.descriptors)
|
2011-12-30 00:46:16 +08:00
|
|
|
.iterations(100);
|
2011-10-27 22:06:06 +08:00
|
|
|
|
|
|
|
while(next())
|
|
|
|
{
|
|
|
|
cvflann::seed_random(42);//for predictive FlannBasedMatcher
|
|
|
|
startTimer();
|
|
|
|
(*matcher)(features1, features2, pairwise_matches);
|
|
|
|
stopTimer();
|
|
|
|
matcher->collectGarbage();
|
|
|
|
}
|
|
|
|
}
|