disabled gpu::sum, gpu::minMax, gpu:Canny until fix crash.pull/13383/head
parent
7a3b0785d7
commit
66df8ef06c
8 changed files with 1127 additions and 620 deletions
@ -0,0 +1,383 @@ |
|||||||
|
/*M///////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
|
||||||
|
//
|
||||||
|
// By downloading, copying, installing or using the software you agree to this license.
|
||||||
|
// If you do not agree to this license, do not download, install,
|
||||||
|
// copy or use the software.
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// Intel License Agreement
|
||||||
|
// For Open Source Computer Vision Library
|
||||||
|
//
|
||||||
|
// Copyright (C) 2000, Intel Corporation, all rights reserved.
|
||||||
|
// Third party copyrights are property of their respective owners.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
// are permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// * Redistribution's of source code must retain the above copyright notice,
|
||||||
|
// this list of conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// * Redistribution's in binary form must reproduce the above copyright notice,
|
||||||
|
// this list of conditions and the following disclaimer in the documentation
|
||||||
|
// and/or other materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// * The name of Intel Corporation may not be used to endorse or promote products
|
||||||
|
// derived from this software without specific prior written permission.
|
||||||
|
//
|
||||||
|
// This software is provided by the copyright holders and contributors "as is" and
|
||||||
|
// any express or implied warranties, including, but not limited to, the implied
|
||||||
|
// warranties of merchantability and fitness for a particular purpose are disclaimed.
|
||||||
|
// In no event shall the Intel Corporation or contributors be liable for any direct,
|
||||||
|
// indirect, incidental, special, exemplary, or consequential damages
|
||||||
|
// (including, but not limited to, procurement of substitute goods or services;
|
||||||
|
// loss of use, data, or profits; or business interruption) however caused
|
||||||
|
// and on any theory of liability, whether in contract, strict liability,
|
||||||
|
// or tort (including negligence or otherwise) arising in any way out of
|
||||||
|
// the use of this software, even if advised of the possibility of such damage.
|
||||||
|
//
|
||||||
|
//M*/
|
||||||
|
|
||||||
|
#include <iostream> |
||||||
|
#include <cmath> |
||||||
|
#include <limits> |
||||||
|
#include "gputest.hpp" |
||||||
|
#include "opencv2/imgproc/imgproc.hpp" |
||||||
|
#include "opencv2/highgui/highgui.hpp" |
||||||
|
|
||||||
|
using namespace cv; |
||||||
|
using namespace std; |
||||||
|
using namespace gpu; |
||||||
|
|
||||||
|
class CV_GpuNppFilterTest : public CvTest |
||||||
|
{ |
||||||
|
public: |
||||||
|
CV_GpuNppFilterTest(const char* test_name, const char* test_funcs) : CvTest(test_name, test_funcs) {} |
||||||
|
virtual ~CV_GpuNppFilterTest() {} |
||||||
|
|
||||||
|
protected: |
||||||
|
void run(int); |
||||||
|
virtual int test(const Mat& img) = 0; |
||||||
|
|
||||||
|
int test8UC1(const Mat& img) |
||||||
|
{ |
||||||
|
cv::Mat img_C1; |
||||||
|
cvtColor(img, img_C1, CV_BGR2GRAY); |
||||||
|
return test(img_C1); |
||||||
|
} |
||||||
|
|
||||||
|
int test8UC4(const Mat& img) |
||||||
|
{ |
||||||
|
cv::Mat img_C4; |
||||||
|
cvtColor(img, img_C4, CV_BGR2BGRA); |
||||||
|
return test(img_C4); |
||||||
|
} |
||||||
|
|
||||||
|
int CheckNorm(const Mat& m1, const Mat& m2, const Size& ksize) |
||||||
|
{ |
||||||
|
Rect roi = Rect(ksize.width, ksize.height, m1.cols - 2 * ksize.width, m1.rows - 2 * ksize.height); |
||||||
|
Mat m1ROI = m1(roi); |
||||||
|
Mat m2ROI = m2(roi); |
||||||
|
|
||||||
|
double res = norm(m1ROI, m2ROI, NORM_INF); |
||||||
|
|
||||||
|
if (res <= 1) |
||||||
|
return CvTS::OK; |
||||||
|
|
||||||
|
ts->printf(CvTS::LOG, "\nNorm: %f\n", res); |
||||||
|
return CvTS::FAIL_GENERIC; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
void CV_GpuNppFilterTest::run( int ) |
||||||
|
{
|
||||||
|
cv::Mat img = cv::imread(std::string(ts->get_data_path()) + "stereobp/aloe-L.png"); |
||||||
|
|
||||||
|
if (img.empty()) |
||||||
|
{ |
||||||
|
ts->set_failed_test_info(CvTS::FAIL_MISSING_TEST_DATA); |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
try |
||||||
|
{ |
||||||
|
//run tests
|
||||||
|
int testResult = CvTS::OK; |
||||||
|
|
||||||
|
if (test8UC1(img) != CvTS::OK) |
||||||
|
testResult = CvTS::FAIL_GENERIC; |
||||||
|
|
||||||
|
if (test8UC4(img) != CvTS::OK) |
||||||
|
testResult = CvTS::FAIL_GENERIC; |
||||||
|
|
||||||
|
ts->set_failed_test_info(testResult); |
||||||
|
} |
||||||
|
catch(const cv::Exception& e) |
||||||
|
{ |
||||||
|
if (!check_and_treat_gpu_exception(e, ts)) |
||||||
|
throw; |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
ts->set_failed_test_info(CvTS::OK); |
||||||
|
} |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// blur
|
||||||
|
struct CV_GpuNppImageBlurTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
CV_GpuNppImageBlurTest() : CV_GpuNppFilterTest( "GPU-NppImageBlur", "blur" ) {} |
||||||
|
|
||||||
|
int test(const Mat& img) |
||||||
|
{ |
||||||
|
int ksizes[] = {3, 5, 7}; |
||||||
|
int ksizes_num = sizeof(ksizes) / sizeof(int); |
||||||
|
|
||||||
|
int test_res = CvTS::OK; |
||||||
|
|
||||||
|
for (int i = 0; i < ksizes_num; ++i) |
||||||
|
{ |
||||||
|
for (int j = 0; j < ksizes_num; ++j) |
||||||
|
{ |
||||||
|
Size ksize(ksizes[i], ksizes[j]); |
||||||
|
|
||||||
|
ts->printf(CvTS::LOG, "\nksize = (%dx%d)\n", ksizes[i], ksizes[j]); |
||||||
|
|
||||||
|
Mat cpudst; |
||||||
|
cv::blur(img, cpudst, ksize); |
||||||
|
|
||||||
|
GpuMat gpu1(img); |
||||||
|
GpuMat gpudst; |
||||||
|
cv::gpu::blur(gpu1, gpudst, ksize); |
||||||
|
|
||||||
|
if (CheckNorm(cpudst, gpudst, ksize) != CvTS::OK) |
||||||
|
test_res = CvTS::FAIL_GENERIC; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return test_res; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Sobel
|
||||||
|
struct CV_GpuNppImageSobelTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
CV_GpuNppImageSobelTest() : CV_GpuNppFilterTest( "GPU-NppImageSobel", "Sobel" ) {} |
||||||
|
|
||||||
|
int test(const Mat& img) |
||||||
|
{ |
||||||
|
int ksizes[] = {3, 5, 7}; |
||||||
|
int ksizes_num = sizeof(ksizes) / sizeof(int); |
||||||
|
|
||||||
|
int dx = 1, dy = 0; |
||||||
|
|
||||||
|
int test_res = CvTS::OK; |
||||||
|
|
||||||
|
for (int i = 0; i < ksizes_num; ++i) |
||||||
|
{ |
||||||
|
ts->printf(CvTS::LOG, "\nksize = %d\n", ksizes[i]); |
||||||
|
|
||||||
|
Mat cpudst; |
||||||
|
cv::Sobel(img, cpudst, -1, dx, dy, ksizes[i]); |
||||||
|
|
||||||
|
GpuMat gpu1(img); |
||||||
|
GpuMat gpudst; |
||||||
|
cv::gpu::Sobel(gpu1, gpudst, -1, dx, dy, ksizes[i]); |
||||||
|
|
||||||
|
if (CheckNorm(cpudst, gpudst, Size(ksizes[i], ksizes[i])) != CvTS::OK) |
||||||
|
test_res = CvTS::FAIL_GENERIC; |
||||||
|
} |
||||||
|
|
||||||
|
return test_res; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Scharr
|
||||||
|
struct CV_GpuNppImageScharrTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
CV_GpuNppImageScharrTest() : CV_GpuNppFilterTest( "GPU-NppImageScharr", "Scharr" ) {} |
||||||
|
|
||||||
|
int test(const Mat& img) |
||||||
|
{ |
||||||
|
int dx = 1, dy = 0; |
||||||
|
|
||||||
|
Mat cpudst; |
||||||
|
cv::Scharr(img, cpudst, -1, dx, dy); |
||||||
|
|
||||||
|
GpuMat gpu1(img); |
||||||
|
GpuMat gpudst; |
||||||
|
cv::gpu::Scharr(gpu1, gpudst, -1, dx, dy); |
||||||
|
|
||||||
|
return CheckNorm(cpudst, gpudst, Size(3, 3)); |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// GaussianBlur
|
||||||
|
struct CV_GpuNppImageGaussianBlurTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
CV_GpuNppImageGaussianBlurTest() : CV_GpuNppFilterTest( "GPU-NppImageGaussianBlur", "GaussianBlur" ) {} |
||||||
|
|
||||||
|
int test(const Mat& img) |
||||||
|
{ |
||||||
|
int ksizes[] = {3, 5, 7}; |
||||||
|
int ksizes_num = sizeof(ksizes) / sizeof(int); |
||||||
|
|
||||||
|
int test_res = CvTS::OK; |
||||||
|
|
||||||
|
const double sigma1 = 3.0; |
||||||
|
|
||||||
|
for (int i = 0; i < ksizes_num; ++i) |
||||||
|
{ |
||||||
|
for (int j = 0; j < ksizes_num; ++j) |
||||||
|
{ |
||||||
|
cv::Size ksize(ksizes[i], ksizes[j]); |
||||||
|
|
||||||
|
ts->printf(CvTS::LOG, "\nksize = (%dx%d)\n", ksizes[i], ksizes[j]); |
||||||
|
|
||||||
|
Mat cpudst; |
||||||
|
cv::GaussianBlur(img, cpudst, ksize, sigma1); |
||||||
|
|
||||||
|
GpuMat gpu1(img); |
||||||
|
GpuMat gpudst; |
||||||
|
cv::gpu::GaussianBlur(gpu1, gpudst, ksize, sigma1); |
||||||
|
|
||||||
|
if (CheckNorm(cpudst, gpudst, ksize) != CvTS::OK) |
||||||
|
test_res = CvTS::FAIL_GENERIC; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return test_res; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Laplacian
|
||||||
|
struct CV_GpuNppImageLaplacianTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
CV_GpuNppImageLaplacianTest() : CV_GpuNppFilterTest( "GPU-NppImageLaplacian", "Laplacian" ) {} |
||||||
|
|
||||||
|
int test(const Mat& img) |
||||||
|
{ |
||||||
|
int ksizes[] = {1, 3}; |
||||||
|
int ksizes_num = sizeof(ksizes) / sizeof(int); |
||||||
|
|
||||||
|
int test_res = CvTS::OK; |
||||||
|
|
||||||
|
for (int i = 0; i < ksizes_num; ++i) |
||||||
|
{ |
||||||
|
ts->printf(CvTS::LOG, "\nksize = %d\n", ksizes[i]); |
||||||
|
|
||||||
|
Mat cpudst; |
||||||
|
cv::Laplacian(img, cpudst, -1, ksizes[i]); |
||||||
|
|
||||||
|
GpuMat gpu1(img); |
||||||
|
GpuMat gpudst; |
||||||
|
cv::gpu::Laplacian(gpu1, gpudst, -1, ksizes[i]); |
||||||
|
|
||||||
|
if (CheckNorm(cpudst, gpudst, Size(3, 3)) != CvTS::OK) |
||||||
|
test_res = CvTS::FAIL_GENERIC; |
||||||
|
} |
||||||
|
|
||||||
|
return test_res; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Erode
|
||||||
|
class CV_GpuErodeTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
public: |
||||||
|
CV_GpuErodeTest() : CV_GpuNppFilterTest( "GPU-NppErode", "erode" ) {}
|
||||||
|
|
||||||
|
protected: |
||||||
|
virtual int test(const Mat& img) |
||||||
|
{ |
||||||
|
Mat kernel(Mat::ones(3, 3, CV_8U)); |
||||||
|
|
||||||
|
cv::Mat cpuRes; |
||||||
|
cv::erode(img, cpuRes, kernel); |
||||||
|
|
||||||
|
GpuMat gpuRes; |
||||||
|
cv::gpu::erode(GpuMat(img), gpuRes, kernel); |
||||||
|
|
||||||
|
return CheckNorm(cpuRes, gpuRes, Size(3, 3)); |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Dilate
|
||||||
|
class CV_GpuDilateTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
public: |
||||||
|
CV_GpuDilateTest() : CV_GpuNppFilterTest( "GPU-NppDilate", "dilate" ) {}
|
||||||
|
|
||||||
|
protected: |
||||||
|
virtual int test(const Mat& img) |
||||||
|
{ |
||||||
|
Mat kernel(Mat::ones(3, 3, CV_8U)); |
||||||
|
|
||||||
|
cv::Mat cpuRes; |
||||||
|
cv::dilate(img, cpuRes, kernel); |
||||||
|
|
||||||
|
GpuMat gpuRes; |
||||||
|
cv::gpu::dilate(GpuMat(img), gpuRes, kernel); |
||||||
|
|
||||||
|
return CheckNorm(cpuRes, gpuRes, Size(3, 3)); |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// MorphologyEx
|
||||||
|
class CV_GpuMorphExTest : public CV_GpuNppFilterTest |
||||||
|
{ |
||||||
|
public: |
||||||
|
CV_GpuMorphExTest() : CV_GpuNppFilterTest( "GPU-NppMorphologyEx", "morphologyEx" ) {}
|
||||||
|
|
||||||
|
protected: |
||||||
|
virtual int test(const Mat& img) |
||||||
|
{ |
||||||
|
static int ops[] = { MORPH_OPEN, CV_MOP_CLOSE, CV_MOP_GRADIENT, CV_MOP_TOPHAT, CV_MOP_BLACKHAT}; |
||||||
|
const char *names[] = { "MORPH_OPEN", "CV_MOP_CLOSE", "CV_MOP_GRADIENT", "CV_MOP_TOPHAT", "CV_MOP_BLACKHAT"}; |
||||||
|
int num = sizeof(ops)/sizeof(ops[0]); |
||||||
|
|
||||||
|
GpuMat kernel(Mat::ones(3, 3, CV_8U)); |
||||||
|
|
||||||
|
int res = CvTS::OK; |
||||||
|
|
||||||
|
for(int i = 0; i < num; ++i) |
||||||
|
{ |
||||||
|
ts->printf(CvTS::LOG, "Tesing %s\n", names[i]); |
||||||
|
|
||||||
|
cv::Mat cpuRes; |
||||||
|
cv::morphologyEx(img, cpuRes, ops[i], kernel); |
||||||
|
|
||||||
|
GpuMat gpuRes; |
||||||
|
cv::gpu::morphologyEx(GpuMat(img), gpuRes, ops[i], kernel); |
||||||
|
|
||||||
|
if (CvTS::OK != CheckNorm(cpuRes, gpuRes, Size(3, 3))) |
||||||
|
res = CvTS::FAIL_GENERIC; |
||||||
|
} |
||||||
|
return res; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
/////////////////// tests registration /////////////////////////////////////
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
CV_GpuNppImageBlurTest CV_GpuNppImageBlur_test; |
||||||
|
CV_GpuNppImageSobelTest CV_GpuNppImageSobel_test; |
||||||
|
CV_GpuNppImageScharrTest CV_GpuNppImageScharr_test; |
||||||
|
CV_GpuNppImageGaussianBlurTest CV_GpuNppImageGaussianBlur_test; |
||||||
|
CV_GpuNppImageLaplacianTest CV_GpuNppImageLaplacian_test; |
||||||
|
CV_GpuErodeTest CV_GpuErode_test; |
||||||
|
CV_GpuDilateTest CV_GpuDilate_test; |
||||||
|
CV_GpuMorphExTest CV_GpuMorphEx_test; |
@ -1,219 +0,0 @@ |
|||||||
/*M///////////////////////////////////////////////////////////////////////////////////////
|
|
||||||
//
|
|
||||||
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
|
|
||||||
//
|
|
||||||
// By downloading, copying, installing or using the software you agree to this license.
|
|
||||||
// If you do not agree to this license, do not download, install,
|
|
||||||
// copy or use the software.
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// Intel License Agreement
|
|
||||||
// For Open Source Computer Vision Library
|
|
||||||
//
|
|
||||||
// Copyright (C) 2000, Intel Corporation, all rights reserved.
|
|
||||||
// Third party copyrights are property of their respective owners.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without modification,
|
|
||||||
// are permitted provided that the following conditions are met:
|
|
||||||
//
|
|
||||||
// * Redistribution's of source code must retain the above copyright notice,
|
|
||||||
// this list of conditions and the following disclaimer.
|
|
||||||
//
|
|
||||||
// * Redistribution's in binary form must reproduce the above copyright notice,
|
|
||||||
// this list of conditions and the following disclaimer in the documentation
|
|
||||||
// and/or other materials provided with the distribution.
|
|
||||||
//
|
|
||||||
// * The name of Intel Corporation may not be used to endorse or promote products
|
|
||||||
// derived from this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// This software is provided by the copyright holders and contributors "as is" and
|
|
||||||
// any express or implied warranties, including, but not limited to, the implied
|
|
||||||
// warranties of merchantability and fitness for a particular purpose are disclaimed.
|
|
||||||
// In no event shall the Intel Corporation or contributors be liable for any direct,
|
|
||||||
// indirect, incidental, special, exemplary, or consequential damages
|
|
||||||
// (including, but not limited to, procurement of substitute goods or services;
|
|
||||||
// loss of use, data, or profits; or business interruption) however caused
|
|
||||||
// and on any theory of liability, whether in contract, strict liability,
|
|
||||||
// or tort (including negligence or otherwise) arising in any way out of
|
|
||||||
// the use of this software, even if advised of the possibility of such damage.
|
|
||||||
//
|
|
||||||
//M*/
|
|
||||||
|
|
||||||
#include <iostream> |
|
||||||
#include <cmath> |
|
||||||
#include <limits> |
|
||||||
#include "gputest.hpp" |
|
||||||
#include "opencv2/imgproc/imgproc.hpp" |
|
||||||
#include "opencv2/highgui/highgui.hpp" |
|
||||||
|
|
||||||
using namespace cv; |
|
||||||
using namespace std; |
|
||||||
using namespace gpu; |
|
||||||
|
|
||||||
class CV_GpuNppMorphogyTest : public CvTest |
|
||||||
{ |
|
||||||
public: |
|
||||||
CV_GpuNppMorphogyTest(const char* test_name, const char* test_funcs) : CvTest(test_name, test_funcs) {} |
|
||||||
virtual ~CV_GpuNppMorphogyTest() {} |
|
||||||
|
|
||||||
protected: |
|
||||||
void run(int); |
|
||||||
virtual int test(const Mat& img) = 0; |
|
||||||
|
|
||||||
int test8UC1(const Mat& img) |
|
||||||
{ |
|
||||||
cv::Mat img_C1; |
|
||||||
cvtColor(img, img_C1, CV_BGR2GRAY); |
|
||||||
return test(img_C1); |
|
||||||
} |
|
||||||
|
|
||||||
int test8UC4(const Mat& img) |
|
||||||
{ |
|
||||||
cv::Mat img_C4; |
|
||||||
cvtColor(img, img_C4, CV_BGR2BGRA);
|
|
||||||
return test(img_C4); |
|
||||||
} |
|
||||||
|
|
||||||
int CheckNorm(const Mat& m1, const Mat& m2) |
|
||||||
{ |
|
||||||
double res = norm(m1, m2, NORM_INF); |
|
||||||
|
|
||||||
if (res < std::numeric_limits<double>::epsilon()) |
|
||||||
return CvTS::OK; |
|
||||||
|
|
||||||
ts->printf(CvTS::LOG, "\nNorm: %f\n", res); |
|
||||||
return CvTS::FAIL_GENERIC; |
|
||||||
} |
|
||||||
}; |
|
||||||
|
|
||||||
void CV_GpuNppMorphogyTest::run( int ) |
|
||||||
{
|
|
||||||
cv::Mat img = cv::imread(std::string(ts->get_data_path()) + "stereobp/aloe-L.png"); |
|
||||||
|
|
||||||
if (img.empty()) |
|
||||||
{ |
|
||||||
ts->set_failed_test_info(CvTS::FAIL_MISSING_TEST_DATA); |
|
||||||
return; |
|
||||||
} |
|
||||||
|
|
||||||
try |
|
||||||
{ |
|
||||||
//run tests
|
|
||||||
int testResult = test8UC1(img); |
|
||||||
if (testResult != CvTS::OK) |
|
||||||
{ |
|
||||||
ts->set_failed_test_info(testResult); |
|
||||||
return; |
|
||||||
} |
|
||||||
|
|
||||||
testResult = test8UC4(img); |
|
||||||
if (testResult != CvTS::OK) |
|
||||||
{ |
|
||||||
ts->set_failed_test_info(testResult); |
|
||||||
return; |
|
||||||
}
|
|
||||||
} |
|
||||||
catch(const cv::Exception& e) |
|
||||||
{ |
|
||||||
if (!check_and_treat_gpu_exception(e, ts)) |
|
||||||
throw; |
|
||||||
return; |
|
||||||
} |
|
||||||
|
|
||||||
ts->set_failed_test_info(CvTS::OK); |
|
||||||
} |
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Erode
|
|
||||||
class CV_GpuErodeTest : public CV_GpuNppMorphogyTest |
|
||||||
{ |
|
||||||
public: |
|
||||||
CV_GpuErodeTest() : CV_GpuNppMorphogyTest( "GPU-NppErode", "erode" ) {}
|
|
||||||
|
|
||||||
protected: |
|
||||||
virtual int test(const Mat& img) |
|
||||||
{ |
|
||||||
GpuMat kernel(Mat::ones(3, 3, CV_8U)); |
|
||||||
Point anchor(0, 0); |
|
||||||
int iters = 1; |
|
||||||
|
|
||||||
cv::Mat cpuRes, cpuRes1; |
|
||||||
cv::erode(img, cpuRes, kernel, anchor, iters); |
|
||||||
|
|
||||||
GpuMat gpuRes; |
|
||||||
cv::gpu::erode(GpuMat(img), gpuRes, kernel, anchor, iters); |
|
||||||
|
|
||||||
return CheckNorm(cpuRes, gpuRes); |
|
||||||
} |
|
||||||
}; |
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Dilate
|
|
||||||
class CV_GpuDilateTest : public CV_GpuNppMorphogyTest |
|
||||||
{ |
|
||||||
public: |
|
||||||
CV_GpuDilateTest() : CV_GpuNppMorphogyTest( "GPU-NppDilate", "dilate" ) {}
|
|
||||||
|
|
||||||
protected: |
|
||||||
virtual int test(const Mat& img) |
|
||||||
{ |
|
||||||
GpuMat kernel(Mat::ones(3, 3, CV_8U)); |
|
||||||
Point anchor(0, 0); |
|
||||||
int iters = 1; |
|
||||||
|
|
||||||
cv::Mat cpuRes, cpuRes1; |
|
||||||
cv::dilate(img, cpuRes, kernel, anchor, iters); |
|
||||||
|
|
||||||
GpuMat gpuRes, gpuRes1; |
|
||||||
cv::gpu::dilate(GpuMat(img), gpuRes, kernel, anchor, iters); |
|
||||||
|
|
||||||
return CheckNorm(cpuRes, gpuRes); |
|
||||||
} |
|
||||||
}; |
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Dilate
|
|
||||||
class CV_GpuMorphExTest : public CV_GpuNppMorphogyTest |
|
||||||
{ |
|
||||||
public: |
|
||||||
CV_GpuMorphExTest() : CV_GpuNppMorphogyTest( "GPU-NppMorphologyEx", "dmorphologyExilate" ) {}
|
|
||||||
|
|
||||||
protected: |
|
||||||
virtual int test(const Mat& img) |
|
||||||
{ |
|
||||||
static int ops[] = { MORPH_OPEN, CV_MOP_CLOSE, CV_MOP_GRADIENT, CV_MOP_TOPHAT, CV_MOP_BLACKHAT}; |
|
||||||
const char *names[] = { "MORPH_OPEN", "CV_MOP_CLOSE", "CV_MOP_GRADIENT", "CV_MOP_TOPHAT", "CV_MOP_BLACKHAT"}; |
|
||||||
int num = sizeof(ops)/sizeof(ops[0]); |
|
||||||
|
|
||||||
GpuMat kernel(Mat::ones(3, 3, CV_8U)); |
|
||||||
Point anchor(0, 0); |
|
||||||
int iters = 1; |
|
||||||
|
|
||||||
for(int i = 0; i < num; ++i) |
|
||||||
{ |
|
||||||
ts->printf(CvTS::LOG, "Tesing %s\n", names[i]); |
|
||||||
|
|
||||||
cv::Mat cpuRes; |
|
||||||
cv::morphologyEx(img, cpuRes, ops[i], kernel, anchor, iters); |
|
||||||
|
|
||||||
GpuMat gpuRes; |
|
||||||
cv::gpu::morphologyEx(GpuMat(img), gpuRes, ops[i], kernel, anchor, iters); |
|
||||||
|
|
||||||
int res = CheckNorm(cpuRes, gpuRes); |
|
||||||
if (CvTS::OK != res) |
|
||||||
return res; |
|
||||||
} |
|
||||||
return CvTS::OK; |
|
||||||
} |
|
||||||
}; |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
|
||||||
/////////////////// tests registration /////////////////////////////////////
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
CV_GpuErodeTest CV_GpuErode_test; |
|
||||||
CV_GpuDilateTest CV_GpuDilate_test; |
|
||||||
CV_GpuMorphExTest CV_GpuMorphEx_test; |
|
Loading…
Reference in new issue