152 lines
4.0 KiB
C++
152 lines
4.0 KiB
C++
// 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 "../perf_precomp.hpp"
|
|
#include "opencv2/ts/ocl_perf.hpp"
|
|
|
|
#ifdef HAVE_OPENCL
|
|
|
|
namespace cvtest {
|
|
namespace ocl {
|
|
|
|
///////////// SetTo ////////////////////////
|
|
|
|
typedef Size_MatType SetToFixture;
|
|
|
|
OCL_PERF_TEST_P(SetToFixture, SetTo,
|
|
::testing::Combine(OCL_TEST_SIZES, OCL_TEST_TYPES))
|
|
{
|
|
const Size_MatType_t params = GetParam();
|
|
const Size srcSize = get<0>(params);
|
|
const int type = get<1>(params);
|
|
const Scalar s = Scalar::all(17);
|
|
|
|
checkDeviceMaxMemoryAllocSize(srcSize, type);
|
|
|
|
UMat src(srcSize, type);
|
|
declare.in(src, WARMUP_RNG).out(src);
|
|
|
|
OCL_TEST_CYCLE() src.setTo(s);
|
|
|
|
SANITY_CHECK(src);
|
|
}
|
|
|
|
///////////// SetTo with mask ////////////////////////
|
|
|
|
typedef Size_MatType SetToFixture;
|
|
|
|
OCL_PERF_TEST_P(SetToFixture, SetToWithMask,
|
|
::testing::Combine(OCL_TEST_SIZES, OCL_TEST_TYPES))
|
|
{
|
|
const Size_MatType_t params = GetParam();
|
|
const Size srcSize = get<0>(params);
|
|
const int type = get<1>(params);
|
|
const Scalar s = Scalar::all(17);
|
|
|
|
checkDeviceMaxMemoryAllocSize(srcSize, type);
|
|
|
|
UMat src(srcSize, type), mask(srcSize, CV_8UC1);
|
|
declare.in(src, mask, WARMUP_RNG).out(src);
|
|
|
|
OCL_TEST_CYCLE() src.setTo(s, mask);
|
|
|
|
SANITY_CHECK(src);
|
|
}
|
|
|
|
///////////// ConvertTo ////////////////////////
|
|
|
|
typedef Size_MatType ConvertToFixture;
|
|
|
|
OCL_PERF_TEST_P(ConvertToFixture, ConvertTo,
|
|
::testing::Combine(OCL_TEST_SIZES, OCL_TEST_TYPES))
|
|
{
|
|
const Size_MatType_t params = GetParam();
|
|
const Size srcSize = get<0>(params);
|
|
const int type = get<1>(params), ddepth = CV_MAT_DEPTH(type) == CV_8U ? CV_32F : CV_8U,
|
|
cn = CV_MAT_CN(type), dtype = CV_MAKE_TYPE(ddepth, cn);
|
|
|
|
checkDeviceMaxMemoryAllocSize(srcSize, type);
|
|
checkDeviceMaxMemoryAllocSize(srcSize, dtype);
|
|
|
|
UMat src(srcSize, type), dst(srcSize, dtype);
|
|
declare.in(src, WARMUP_RNG).out(dst);
|
|
|
|
OCL_TEST_CYCLE() src.convertTo(dst, dtype);
|
|
|
|
SANITY_CHECK(dst);
|
|
}
|
|
|
|
///////////// CopyTo ////////////////////////
|
|
|
|
typedef Size_MatType CopyToFixture;
|
|
|
|
OCL_PERF_TEST_P(CopyToFixture, CopyTo,
|
|
::testing::Combine(OCL_TEST_SIZES, OCL_TEST_TYPES))
|
|
{
|
|
const Size_MatType_t params = GetParam();
|
|
const Size srcSize = get<0>(params);
|
|
const int type = get<1>(params);
|
|
|
|
checkDeviceMaxMemoryAllocSize(srcSize, type);
|
|
|
|
UMat src(srcSize, type), dst(srcSize, type);
|
|
declare.in(src, WARMUP_RNG).out(dst);
|
|
|
|
OCL_TEST_CYCLE() src.copyTo(dst);
|
|
|
|
SANITY_CHECK(dst);
|
|
}
|
|
|
|
///////////// CopyTo with mask ////////////////////////
|
|
|
|
typedef Size_MatType CopyToFixture;
|
|
|
|
OCL_PERF_TEST_P(CopyToFixture, CopyToWithMask,
|
|
::testing::Combine(OCL_TEST_SIZES, OCL_TEST_TYPES))
|
|
{
|
|
const Size_MatType_t params = GetParam();
|
|
const Size srcSize = get<0>(params);
|
|
const int type = get<1>(params);
|
|
|
|
checkDeviceMaxMemoryAllocSize(srcSize, type);
|
|
|
|
UMat src(srcSize, type), dst(srcSize, type), mask(srcSize, CV_8UC1);
|
|
declare.in(src, mask, WARMUP_RNG).out(dst);
|
|
|
|
OCL_TEST_CYCLE() src.copyTo(dst, mask);
|
|
|
|
SANITY_CHECK(dst);
|
|
}
|
|
|
|
OCL_PERF_TEST_P(CopyToFixture, CopyToWithMaskUninit,
|
|
::testing::Combine(OCL_PERF_ENUM(OCL_SIZE_1, OCL_SIZE_2, OCL_SIZE_3), OCL_TEST_TYPES))
|
|
{
|
|
const Size_MatType_t params = GetParam();
|
|
const Size srcSize = get<0>(params);
|
|
const int type = get<1>(params);
|
|
|
|
checkDeviceMaxMemoryAllocSize(srcSize, type);
|
|
|
|
UMat src(srcSize, type), dst, mask(srcSize, CV_8UC1);
|
|
declare.in(src, mask, WARMUP_RNG);
|
|
|
|
for ( ; next(); )
|
|
{
|
|
dst.release();
|
|
startTimer();
|
|
src.copyTo(dst, mask);
|
|
cv::ocl::finish();
|
|
stopTimer();
|
|
}
|
|
|
|
SANITY_CHECK(dst);
|
|
}
|
|
|
|
} } // namespace cvtest::ocl
|
|
|
|
#endif // HAVE_OPENCL
|