123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- // This file is part of OpenCV project.
- // It is subject to the license terms in the LICENSE file found in the top-level directory
- // of this distribution and at http://opencv.org/license.html.
- //
- // Copyright (C) 2018 Intel Corporation
- #ifndef OPENCV_GAPI_RENDER_TESTS_HPP
- #define OPENCV_GAPI_RENDER_TESTS_HPP
- #include "gapi_tests_common.hpp"
- namespace opencv_test
- {
- template<typename ...SpecificParams>
- struct RenderParams : public Params<SpecificParams...>
- {
- using common_params_t = std::tuple<cv::Size>;
- using specific_params_t = std::tuple<SpecificParams...>;
- using params_t = std::tuple<cv::Size, SpecificParams...>;
- static constexpr const size_t common_params_size = std::tuple_size<common_params_t>::value;
- static constexpr const size_t specific_params_size = std::tuple_size<specific_params_t>::value;
- template<size_t I>
- static const typename std::tuple_element<I, common_params_t>::type&
- getCommon(const params_t& t)
- {
- static_assert(I < common_params_size, "Index out of range");
- return std::get<I>(t);
- }
- template<size_t I>
- static const typename std::tuple_element<I, specific_params_t>::type&
- getSpecific(const params_t& t)
- {
- static_assert(specific_params_size > 0,
- "Impossible to call this function: no specific parameters specified");
- static_assert(I < specific_params_size, "Index out of range");
- return std::get<common_params_size + I>(t);
- }
- };
- template<typename ...SpecificParams>
- struct RenderTestBase : public TestWithParam<typename RenderParams<SpecificParams...>::params_t>
- {
- using AllParams = RenderParams<SpecificParams...>;
- // Get common (pre-defined) parameter value by index
- template<size_t I>
- inline auto getCommonParam() const
- -> decltype(AllParams::template getCommon<I>(this->GetParam()))
- {
- return AllParams::template getCommon<I>(this->GetParam());
- }
- // Get specific (user-defined) parameter value by index
- template<size_t I>
- inline auto getSpecificParam() const
- -> decltype(AllParams::template getSpecific<I>(this->GetParam()))
- {
- return AllParams::template getSpecific<I>(this->GetParam());
- }
- cv::Size sz_ = getCommonParam<0>();
- };
- template <typename ...Args>
- class RenderBGRTestBase : public RenderTestBase<Args...>
- {
- protected:
- void Init(const cv::Size& sz)
- {
- MatType type = CV_8UC3;
- ref_mat.create(sz, type);
- gapi_mat.create(sz, type);
- cv::randu(ref_mat, cv::Scalar::all(0), cv::Scalar::all(255));
- ref_mat.copyTo(gapi_mat);
- }
- cv::Mat gapi_mat, ref_mat;
- };
- template <typename ...Args>
- class RenderNV12TestBase : public RenderTestBase<Args...>
- {
- protected:
- void Init(const cv::Size& sz)
- {
- auto create_rand_mats = [](const cv::Size& size, MatType type, cv::Mat& ref_mat, cv::Mat& gapi_mat) {
- ref_mat.create(size, type);
- cv::randu(ref_mat, cv::Scalar::all(0), cv::Scalar::all(255));
- ref_mat.copyTo(gapi_mat);
- };
- create_rand_mats(sz, CV_8UC1, y_ref_mat , y_gapi_mat);
- create_rand_mats(sz / 2, CV_8UC2, uv_ref_mat , uv_gapi_mat);
- }
- cv::Mat y_ref_mat, uv_ref_mat, y_gapi_mat, uv_gapi_mat;
- };
- cv::Scalar cvtBGRToYUVC(const cv::Scalar& bgr);
- void drawMosaicRef(const cv::Mat& mat, const cv::Rect &rect, int cellSz);
- void blendImageRef(cv::Mat& mat,
- const cv::Point& org,
- const cv::Mat& img,
- const cv::Mat& alpha);
- #define GAPI_RENDER_TEST_FIXTURE_NV12(Fixture, API, Number, ...) \
- struct Fixture : public RenderNV12TestBase API { \
- __WRAP_VAARGS(DEFINE_SPECIFIC_PARAMS_##Number(__VA_ARGS__)) \
- Fixture() { \
- Init(sz_); \
- }; \
- };
- #define GAPI_RENDER_TEST_FIXTURE_BGR(Fixture, API, Number, ...) \
- struct Fixture : public RenderBGRTestBase API { \
- __WRAP_VAARGS(DEFINE_SPECIFIC_PARAMS_##Number(__VA_ARGS__)) \
- Fixture() { \
- Init(sz_); \
- }; \
- };
- #define GET_VA_ARGS(...) __VA_ARGS__
- #define GAPI_RENDER_TEST_FIXTURES(Fixture, API, Number, ...) \
- GAPI_RENDER_TEST_FIXTURE_BGR(RenderBGR##Fixture, GET_VA_ARGS(API), Number, __VA_ARGS__) \
- GAPI_RENDER_TEST_FIXTURE_NV12(RenderNV12##Fixture, GET_VA_ARGS(API), Number, __VA_ARGS__) \
- GAPI_RENDER_TEST_FIXTURE_NV12(RenderMFrame##Fixture, GET_VA_ARGS(API), Number, __VA_ARGS__) \
- using Points = std::vector<cv::Point>;
- GAPI_RENDER_TEST_FIXTURES(TestTexts, FIXTURE_API(std::string, cv::Point, double, cv::Scalar), 4, text, org, fs, color)
- GAPI_RENDER_TEST_FIXTURES(TestRects, FIXTURE_API(cv::Rect, cv::Scalar, int), 3, rect, color, thick)
- GAPI_RENDER_TEST_FIXTURES(TestCircles, FIXTURE_API(cv::Point, int, cv::Scalar, int), 4, center, radius, color, thick)
- GAPI_RENDER_TEST_FIXTURES(TestLines, FIXTURE_API(cv::Point, cv::Point, cv::Scalar, int), 4, pt1, pt2, color, thick)
- GAPI_RENDER_TEST_FIXTURES(TestMosaics, FIXTURE_API(cv::Rect, int, int), 3, mos, cellsz, decim)
- GAPI_RENDER_TEST_FIXTURES(TestImages, FIXTURE_API(cv::Rect, cv::Scalar, double), 3, rect, color, transparency)
- GAPI_RENDER_TEST_FIXTURES(TestPolylines, FIXTURE_API(Points, cv::Scalar, int), 3, points, color, thick)
- } // opencv_test
- #endif //OPENCV_GAPI_RENDER_TESTS_HPP
|