mirror of https://github.com/opencv/opencv.git
Open Source Computer Vision Library
https://opencv.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
1.7 KiB
68 lines
1.7 KiB
// 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. |
|
|
|
#include "perf_precomp.hpp" |
|
#include "opencv2/ts/ocl_perf.hpp" |
|
|
|
using namespace std; |
|
using namespace cv; |
|
using namespace ::perf; |
|
using namespace ::cvtest::ocl; |
|
using namespace ::testing; |
|
using std::tr1::tuple; |
|
using std::tr1::get; |
|
|
|
namespace { |
|
|
|
struct OpenCLState |
|
{ |
|
OpenCLState(bool useOpenCL) |
|
{ |
|
isOpenCL_enabled = cv::ocl::useOpenCL(); |
|
cv::ocl::setUseOpenCL(useOpenCL); |
|
} |
|
|
|
~OpenCLState() |
|
{ |
|
cv::ocl::setUseOpenCL(isOpenCL_enabled); |
|
} |
|
|
|
private: |
|
bool isOpenCL_enabled; |
|
}; |
|
|
|
typedef TestBaseWithParam< tuple<Size, bool, int> > UMatTest; |
|
|
|
OCL_PERF_TEST_P(UMatTest, CustomPtr, Combine(Values(sz1080p, sz2160p), Bool(), ::testing::Values(4, 64, 4096))) |
|
{ |
|
OpenCLState s(get<1>(GetParam())); |
|
|
|
int type = CV_8UC1; |
|
cv::Size size = get<0>(GetParam()); |
|
size_t align_base = 4096; |
|
const int align_offset = get<2>(GetParam()); |
|
|
|
void* pData_allocated = new unsigned char [size.area() * CV_ELEM_SIZE(type) + (align_base + align_offset)]; |
|
void* pData = (char*)alignPtr(pData_allocated, (int)align_base) + align_offset; |
|
size_t step = size.width * CV_ELEM_SIZE(type); |
|
|
|
OCL_TEST_CYCLE() |
|
{ |
|
Mat m = Mat(size, type, pData, step); |
|
m.setTo(cv::Scalar::all(2)); |
|
|
|
UMat u = m.getUMat(ACCESS_RW); |
|
cv::add(u, cv::Scalar::all(2), u); |
|
cv::add(u, cv::Scalar::all(3), u); |
|
|
|
Mat d = u.getMat(ACCESS_READ); |
|
ASSERT_EQ(7, d.at<char>(0, 0)); |
|
} |
|
|
|
delete[] (unsigned char*)pData_allocated; |
|
|
|
SANITY_CHECK_NOTHING(); |
|
} |
|
|
|
} // namespace cvtest
|
|
|