123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- // 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) 2014, Advanced Micro Devices, Inc., all rights reserved.
- // Third party copyrights are property of their respective owners.
- #include "../test_precomp.hpp"
- #include "opencv2/ts/ocl_test.hpp"
- #ifdef HAVE_OPENCL
- namespace opencv_test { namespace {
- PARAM_TEST_CASE(UpdateMotionHistory, bool)
- {
- double timestamp, duration;
- bool use_roi;
- TEST_DECLARE_INPUT_PARAMETER(silhouette);
- TEST_DECLARE_OUTPUT_PARAMETER(mhi);
- virtual void SetUp()
- {
- use_roi = GET_PARAM(0);
- }
- virtual void generateTestData()
- {
- Size roiSize = randomSize(1, MAX_VALUE);
- Border silhouetteBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(silhouette, silhouette_roi, roiSize, silhouetteBorder, CV_8UC1, -11, 11);
- Border mhiBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(mhi, mhi_roi, roiSize, mhiBorder, CV_32FC1, 0, 1);
- timestamp = randomDouble(0, 1);
- duration = randomDouble(0, 1);
- if (timestamp < duration)
- std::swap(timestamp, duration);
- UMAT_UPLOAD_INPUT_PARAMETER(silhouette);
- UMAT_UPLOAD_OUTPUT_PARAMETER(mhi);
- }
- };
- OCL_TEST_P(UpdateMotionHistory, Mat)
- {
- for (int j = 0; j < cvtest::ocl::test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::motempl::updateMotionHistory(silhouette_roi, mhi_roi, timestamp, duration));
- OCL_ON(cv::motempl::updateMotionHistory(usilhouette_roi, umhi_roi, timestamp, duration));
- OCL_EXPECT_MATS_NEAR(mhi, 0);
- }
- }
- //////////////////////////////////////// Instantiation /////////////////////////////////////////
- OCL_INSTANTIATE_TEST_CASE_P(Video, UpdateMotionHistory, Values(false, true));
- }} // namespace
- #endif // HAVE_OPENCL
|