test_motempl.cpp 1.92 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
// 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 cvtest {
namespace ocl {

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 < 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 cvtest::ocl

#endif // HAVE_OPENCL