perf_feature2d.cpp 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #include "perf_feature2d.hpp"
  2. namespace opencv_test
  3. {
  4. using namespace perf;
  5. PERF_TEST_P(feature2d, detect, testing::Combine(Feature2DType::all(), TEST_IMAGES))
  6. {
  7. Ptr<Feature2D> detector = getFeature2D(get<0>(GetParam()));
  8. std::string filename = getDataPath(get<1>(GetParam()));
  9. Mat img = imread(filename, IMREAD_GRAYSCALE);
  10. ASSERT_FALSE(img.empty());
  11. ASSERT_TRUE(detector);
  12. declare.in(img);
  13. Mat mask;
  14. vector<KeyPoint> points;
  15. TEST_CYCLE() detector->detect(img, points, mask);
  16. EXPECT_GT(points.size(), 20u);
  17. SANITY_CHECK_NOTHING();
  18. }
  19. PERF_TEST_P(feature2d, extract, testing::Combine(testing::Values(DETECTORS_EXTRACTORS), TEST_IMAGES))
  20. {
  21. Ptr<Feature2D> detector = AKAZE::create();
  22. Ptr<Feature2D> extractor = getFeature2D(get<0>(GetParam()));
  23. std::string filename = getDataPath(get<1>(GetParam()));
  24. Mat img = imread(filename, IMREAD_GRAYSCALE);
  25. ASSERT_FALSE(img.empty());
  26. ASSERT_TRUE(extractor);
  27. declare.in(img);
  28. Mat mask;
  29. vector<KeyPoint> points;
  30. detector->detect(img, points, mask);
  31. EXPECT_GT(points.size(), 20u);
  32. Mat descriptors;
  33. TEST_CYCLE() extractor->compute(img, points, descriptors);
  34. EXPECT_EQ((size_t)descriptors.rows, points.size());
  35. SANITY_CHECK_NOTHING();
  36. }
  37. PERF_TEST_P(feature2d, detectAndExtract, testing::Combine(testing::Values(DETECTORS_EXTRACTORS), TEST_IMAGES))
  38. {
  39. Ptr<Feature2D> detector = getFeature2D(get<0>(GetParam()));
  40. std::string filename = getDataPath(get<1>(GetParam()));
  41. Mat img = imread(filename, IMREAD_GRAYSCALE);
  42. ASSERT_FALSE(img.empty());
  43. ASSERT_TRUE(detector);
  44. declare.in(img);
  45. Mat mask;
  46. vector<KeyPoint> points;
  47. Mat descriptors;
  48. TEST_CYCLE() detector->detectAndCompute(img, mask, points, descriptors, false);
  49. EXPECT_GT(points.size(), 20u);
  50. EXPECT_EQ((size_t)descriptors.rows, points.size());
  51. SANITY_CHECK_NOTHING();
  52. }
  53. } // namespace