mirror of
https://github.com/opencv/opencv.git
synced 2025-01-10 14:19:03 +08:00
f76dd99299
Conflicts: cmake/OpenCVModule.cmake doc/tutorials/calib3d/camera_calibration/camera_calibration.rst doc/tutorials/features2d/feature_detection/feature_detection.rst doc/tutorials/features2d/feature_flann_matcher/feature_flann_matcher.rst doc/tutorials/features2d/feature_homography/feature_homography.rst modules/core/include/opencv2/core/operations.hpp modules/core/src/arithm.cpp modules/gpu/perf/perf_video.cpp modules/imgproc/include/opencv2/imgproc/imgproc.hpp modules/java/generator/gen_java.py modules/java/generator/src/cpp/VideoCapture.cpp modules/nonfree/src/opencl/surf.cl modules/ocl/include/opencv2/ocl/ocl.hpp modules/ocl/perf/perf_haar.cpp modules/ocl/perf/perf_precomp.hpp modules/ocl/src/color.cpp modules/ocl/src/filtering.cpp modules/ocl/test/test_color.cpp modules/ocl/test/test_objdetect.cpp modules/python/src2/cv2.cpp samples/gpu/CMakeLists.txt samples/gpu/super_resolution.cpp
72 lines
1.9 KiB
C++
72 lines
1.9 KiB
C++
#include "test_precomp.hpp"
|
|
#include <iomanip>
|
|
|
|
#ifdef HAVE_OPENCL
|
|
|
|
using namespace cv;
|
|
using namespace cv::ocl;
|
|
using namespace cvtest;
|
|
using namespace testing;
|
|
using namespace std;
|
|
extern string workdir;
|
|
PARAM_TEST_CASE(MomentsTest, MatType, bool)
|
|
{
|
|
int type;
|
|
cv::Mat mat1;
|
|
bool test_contours;
|
|
|
|
virtual void SetUp()
|
|
{
|
|
type = GET_PARAM(0);
|
|
test_contours = GET_PARAM(1);
|
|
cv::RNG &rng = TS::ptr()->get_rng();
|
|
cv::Size size(10*MWIDTH, 10*MHEIGHT);
|
|
mat1 = randomMat(rng, size, type, 5, 16, false);
|
|
}
|
|
|
|
void Compare(Moments& cpu, Moments& gpu)
|
|
{
|
|
Mat gpu_dst, cpu_dst;
|
|
HuMoments(cpu, cpu_dst);
|
|
HuMoments(gpu, gpu_dst);
|
|
EXPECT_MAT_NEAR(gpu_dst,cpu_dst, .5);
|
|
}
|
|
|
|
};
|
|
|
|
|
|
TEST_P(MomentsTest, Mat)
|
|
{
|
|
bool binaryImage = 0;
|
|
SetUp();
|
|
|
|
for(int j = 0; j < LOOP_TIMES; j++)
|
|
{
|
|
if(test_contours)
|
|
{
|
|
Mat src = readImage( "cv/shared/pic3.png", IMREAD_GRAYSCALE );
|
|
ASSERT_FALSE(src.empty());
|
|
Mat canny_output;
|
|
vector<vector<Point> > contours;
|
|
vector<Vec4i> hierarchy;
|
|
Canny( src, canny_output, 100, 200, 3 );
|
|
findContours( canny_output, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0) );
|
|
for( size_t i = 0; i < contours.size(); i++ )
|
|
{
|
|
Moments m = moments( contours[i], false );
|
|
Moments dm = ocl::ocl_moments( contours[i], false );
|
|
Compare(m, dm);
|
|
}
|
|
}
|
|
cv::_InputArray _array(mat1);
|
|
cv::Moments CvMom = cv::moments(_array, binaryImage);
|
|
cv::Moments oclMom = cv::ocl::ocl_moments(_array, binaryImage);
|
|
|
|
Compare(CvMom, oclMom);
|
|
|
|
}
|
|
}
|
|
INSTANTIATE_TEST_CASE_P(OCL_ImgProc, MomentsTest, Combine(
|
|
Values(CV_8UC1, CV_16UC1, CV_16SC1, CV_64FC1), Values(true,false)));
|
|
#endif // HAVE_OPENCL
|