most of the performance tests was rewritten in google-test manner
This commit is contained in:
@@ -45,48 +45,49 @@
|
||||
//M*/
|
||||
|
||||
#include "perf_precomp.hpp"
|
||||
|
||||
///////////// StereoMatchBM ////////////////////////
|
||||
PERFTEST(StereoMatchBM)
|
||||
|
||||
PERF_TEST(StereoMatchBMFixture, DISABLED_StereoMatchBM)
|
||||
{
|
||||
Mat left_image = imread(abspath("aloeL.jpg"), cv::IMREAD_GRAYSCALE);
|
||||
Mat right_image = imread(abspath("aloeR.jpg"), cv::IMREAD_GRAYSCALE);
|
||||
Mat disp,dst;
|
||||
ocl::oclMat d_left, d_right,d_disp;
|
||||
int n_disp= 128;
|
||||
int winSize =19;
|
||||
Mat left_image = imread(getDataPath("gpu/stereobm/aloe-L.png"), cv::IMREAD_GRAYSCALE);
|
||||
Mat right_image = imread(getDataPath("gpu/stereobm/aloe-R.png"), cv::IMREAD_GRAYSCALE);
|
||||
|
||||
SUBTEST << left_image.cols << 'x' << left_image.rows << "; aloeL.jpg ;"<< right_image.cols << 'x' << right_image.rows << "; aloeR.jpg ";
|
||||
ASSERT_TRUE(!left_image.empty()) << "no input image";
|
||||
ASSERT_TRUE(!right_image.empty()) << "no input image";
|
||||
ASSERT_TRUE(right_image.size() == left_image.size());
|
||||
ASSERT_TRUE(right_image.size() == left_image.size());
|
||||
|
||||
StereoBM bm(0, n_disp, winSize);
|
||||
bm(left_image, right_image, dst);
|
||||
const std::string impl = getSelectedImpl();
|
||||
const int n_disp = 128, winSize = 19;
|
||||
Mat disp(left_image.size(), CV_16SC1);
|
||||
|
||||
CPU_ON;
|
||||
bm(left_image, right_image, dst);
|
||||
CPU_OFF;
|
||||
declare.in(left_image, right_image).out(disp);
|
||||
|
||||
d_left.upload(left_image);
|
||||
d_right.upload(right_image);
|
||||
if (impl == "ocl")
|
||||
{
|
||||
ocl::oclMat oclLeft(left_image), oclRight(right_image),
|
||||
oclDisp(left_image.size(), CV_16SC1);
|
||||
ocl::StereoBM_OCL oclBM(0, n_disp, winSize);
|
||||
|
||||
ocl::StereoBM_OCL d_bm(0, n_disp, winSize);
|
||||
TEST_CYCLE() oclBM(oclLeft, oclRight, oclDisp);
|
||||
|
||||
WARMUP_ON;
|
||||
d_bm(d_left, d_right, d_disp);
|
||||
WARMUP_OFF;
|
||||
oclDisp.download(disp);
|
||||
|
||||
cv::Mat ocl_mat;
|
||||
d_disp.download(ocl_mat);
|
||||
ocl_mat.convertTo(ocl_mat, dst.type());
|
||||
SANITY_CHECK(disp);
|
||||
}
|
||||
else if (impl == "plain")
|
||||
{
|
||||
StereoBM bm(0, n_disp, winSize);
|
||||
|
||||
GPU_ON;
|
||||
d_bm(d_left, d_right, d_disp);
|
||||
GPU_OFF;
|
||||
TEST_CYCLE() bm(left_image, right_image, disp);
|
||||
|
||||
GPU_FULL_ON;
|
||||
d_left.upload(left_image);
|
||||
d_right.upload(right_image);
|
||||
d_bm(d_left, d_right, d_disp);
|
||||
d_disp.download(disp);
|
||||
GPU_FULL_OFF;
|
||||
|
||||
TestSystem::instance().setAccurate(-1, 0.);
|
||||
SANITY_CHECK(disp);
|
||||
}
|
||||
#ifdef HAVE_OPENCV_GPU
|
||||
else if (impl == "gpu")
|
||||
CV_TEST_FAIL_NO_IMPL();
|
||||
#endif
|
||||
else
|
||||
CV_TEST_FAIL_NO_IMPL();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user