2012-05-22 18:29:58 +08:00
|
|
|
#include "perf_cpu_precomp.hpp"
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
#ifdef HAVE_CUDA
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Transpose
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Transpose, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::transpose(src, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Transpose, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_32SC1, CV_64FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Flip
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Flip, cv::gpu::DeviceInfo, cv::Size, perf::MatType, FlipCode)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
int flipCode = GET_PARAM(3);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::flip(src, dst, flipCode);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Flip, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_8UC4, CV_32FC1, CV_32FC4),
|
|
|
|
testing::Values((int) HORIZONTAL_AXIS, (int) VERTICAL_AXIS, (int) BOTH_AXIS)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// LUT
|
|
|
|
|
|
|
|
GPU_PERF_TEST(LUT, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
cv::Mat lut(1, 256, CV_8UC1);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, lut, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::LUT(src, lut, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, LUT, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_8UC3)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// CartToPolar
|
|
|
|
|
|
|
|
GPU_PERF_TEST(CartToPolar, cv::gpu::DeviceInfo, cv::Size)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat x(size, CV_32FC1);
|
|
|
|
cv::Mat y(size, CV_32FC1);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(x, -100.0, 100.0);
|
|
|
|
fill(y, -100.0, 100.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat magnitude;
|
|
|
|
cv::Mat angle;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::cartToPolar(x, y, magnitude, angle);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, CartToPolar, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
2012-05-22 16:29:08 +08:00
|
|
|
GPU_TYPICAL_MAT_SIZES));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// PolarToCart
|
|
|
|
|
|
|
|
GPU_PERF_TEST(PolarToCart, cv::gpu::DeviceInfo, cv::Size)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat magnitude(size, CV_32FC1);
|
|
|
|
cv::Mat angle(size, CV_32FC1);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(magnitude, 0.0, 100.0);
|
|
|
|
fill(angle, 0.0, 360.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat x;
|
|
|
|
cv::Mat y;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::polarToCart(magnitude, angle, x, y, true);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, PolarToCart, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
2012-05-22 16:29:08 +08:00
|
|
|
GPU_TYPICAL_MAT_SIZES));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// AddMat
|
|
|
|
|
|
|
|
GPU_PERF_TEST(AddMat, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, type);
|
|
|
|
cv::Mat src2(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src1, 0.0, 100.0);
|
|
|
|
fill(src2, 0.0, 100.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::add(src1, src2, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, AddMat, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// AddScalar
|
|
|
|
|
|
|
|
GPU_PERF_TEST(AddScalar, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src, 0.0, 100.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
cv::Scalar s(1,2,3,4);
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::add(src, s, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, AddScalar, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Exp
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Exp, cv::gpu::DeviceInfo, cv::Size)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, CV_32FC1);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src, 0.0, 10.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::exp(src, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Exp, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
2012-05-22 16:29:08 +08:00
|
|
|
GPU_TYPICAL_MAT_SIZES));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Pow
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Pow, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::pow(src, 0.5, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Pow, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
|
|
|
testing::Values(perf::MatType(CV_32FC1))));
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Compare
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Compare, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, type);
|
|
|
|
cv::Mat src2(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src1, src2, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::compare(src1, src2, dst, cv::CMP_EQ);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Compare, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// BitwiseNot
|
|
|
|
|
|
|
|
GPU_PERF_TEST(BitwiseNot, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::bitwise_not(src, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, BitwiseNot, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32SC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// BitwiseAnd
|
|
|
|
|
|
|
|
GPU_PERF_TEST(BitwiseAnd, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, type);
|
|
|
|
cv::Mat src2(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src1, src2, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::bitwise_and(src1, src2, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, BitwiseAnd, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32SC1)));
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// BitwiseScalarAnd
|
|
|
|
|
2012-05-22 16:29:08 +08:00
|
|
|
GPU_PERF_TEST(BitwiseScalarAnd, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
cv::Scalar sc = cv::Scalar(123, 123, 123, 123);
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::bitwise_and(src, sc, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, BitwiseScalarAnd, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_8UC3, CV_8UC4, CV_16UC1, CV_16UC3, CV_16UC4, CV_32SC1, CV_32SC3, CV_32SC4)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Min
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Min, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, type);
|
|
|
|
cv::Mat src2(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src1, src2, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::min(src1, src2, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Min, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32SC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// MeanStdDev
|
|
|
|
|
|
|
|
GPU_PERF_TEST(MeanStdDev, cv::gpu::DeviceInfo, cv::Size)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, CV_8UC1);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
cv::Scalar mean;
|
|
|
|
cv::Scalar stddev;
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::meanStdDev(src, mean, stddev);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, MeanStdDev, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
2012-05-22 16:29:08 +08:00
|
|
|
GPU_TYPICAL_MAT_SIZES));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Norm
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Norm, cv::gpu::DeviceInfo, cv::Size, perf::MatType, NormType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
int normType = GET_PARAM(3);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
double dst;
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
dst = cv::norm(src, normType);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Norm, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32SC1),
|
|
|
|
testing::Values((int) cv::NORM_INF, (int) cv::NORM_L1, (int) cv::NORM_L2)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// NormDiff
|
|
|
|
|
|
|
|
GPU_PERF_TEST(NormDiff, cv::gpu::DeviceInfo, cv::Size, NormType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int normType = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, CV_8UC1);
|
|
|
|
cv::Mat src2(size, CV_8UC1);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src1, src2, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
double dst;
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
dst = cv::norm(src1, src2, normType);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, NormDiff, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values((int) cv::NORM_INF, (int) cv::NORM_L1, (int) cv::NORM_L2)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Sum
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Sum, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
cv::Scalar dst;
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
dst = cv::sum(src);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Sum, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// MinMaxLoc
|
|
|
|
|
|
|
|
GPU_PERF_TEST(MinMaxLoc, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.in(src, WARMUP_RNG);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
double minVal, maxVal;
|
|
|
|
cv::Point minLoc, maxLoc;
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::minMaxLoc(src, &minVal, &maxVal, &minLoc, &maxLoc);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, MinMaxLoc, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// CountNonZero
|
|
|
|
|
|
|
|
GPU_PERF_TEST(CountNonZero, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src, 0.0, 1.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
int dst;
|
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
dst = cv::countNonZero(src);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, CountNonZero, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// AddWeighted
|
|
|
|
|
|
|
|
GPU_PERF_TEST(AddWeighted, cv::gpu::DeviceInfo, cv::Size, perf::MatType)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, type);
|
|
|
|
cv::Mat src2(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src1, 0.0, 100.0);
|
|
|
|
fill(src2, 0.0, 100.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::addWeighted(src1, 0.5, src2, 0.5, 0.0, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, AddWeighted, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Reduce
|
|
|
|
|
|
|
|
GPU_PERF_TEST(Reduce, cv::gpu::DeviceInfo, cv::Size, perf::MatType, FlipCode)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
int type = GET_PARAM(2);
|
|
|
|
int dim = GET_PARAM(3);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src(size, type);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src, 0.0, 10.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::reduce(src, dst, dim, CV_REDUCE_MIN);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, Reduce, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
|
|
|
GPU_TYPICAL_MAT_SIZES,
|
|
|
|
testing::Values(CV_8UC1, CV_16UC1, CV_32FC1),
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values((int) HORIZONTAL_AXIS, (int) VERTICAL_AXIS)));
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// GEMM
|
|
|
|
|
|
|
|
GPU_PERF_TEST(GEMM, cv::gpu::DeviceInfo, cv::Size)
|
|
|
|
{
|
|
|
|
cv::Size size = GET_PARAM(1);
|
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat src1(size, CV_32FC1);
|
|
|
|
cv::Mat src2(size, CV_32FC1);
|
|
|
|
cv::Mat src3(size, CV_32FC1);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
fill(src1, 0.0, 10.0);
|
|
|
|
fill(src2, 0.0, 10.0);
|
|
|
|
fill(src3, 0.0, 10.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::Mat dst;
|
2012-05-22 16:29:08 +08:00
|
|
|
|
2012-05-22 18:29:58 +08:00
|
|
|
declare.time(15.0);
|
2012-05-22 16:29:08 +08:00
|
|
|
|
|
|
|
TEST_CYCLE()
|
|
|
|
{
|
2012-05-22 18:29:58 +08:00
|
|
|
cv::gemm(src1, src2, 1.0, src3, 1.0, dst);
|
2012-05-22 16:29:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_CASE_P(Arithm, GEMM, testing::Combine(
|
2012-05-22 18:29:58 +08:00
|
|
|
ALL_DEVICES,
|
2012-05-22 16:29:08 +08:00
|
|
|
testing::Values(cv::Size(512, 512), cv::Size(1024, 1024), cv::Size(2048, 2048))));
|
|
|
|
|
|
|
|
#endif
|