2012-10-17 07:18:30 +08:00
|
|
|
#include "perf_precomp.hpp"
|
|
|
|
|
2017-11-05 21:48:40 +08:00
|
|
|
namespace opencv_test
|
|
|
|
{
|
2012-10-17 07:18:30 +08:00
|
|
|
using namespace perf;
|
|
|
|
|
2017-11-05 21:48:40 +08:00
|
|
|
typedef tuple<Size, MatType, MatType, int, double> Size_DepthSrc_DepthDst_Channels_alpha_t;
|
2012-10-17 07:18:30 +08:00
|
|
|
typedef perf::TestBaseWithParam<Size_DepthSrc_DepthDst_Channels_alpha_t> Size_DepthSrc_DepthDst_Channels_alpha;
|
|
|
|
|
|
|
|
PERF_TEST_P( Size_DepthSrc_DepthDst_Channels_alpha, convertTo,
|
|
|
|
testing::Combine
|
|
|
|
(
|
|
|
|
testing::Values(szVGA, sz1080p),
|
|
|
|
testing::Values(CV_8U, CV_8S, CV_16U, CV_16S, CV_32S, CV_32F, CV_64F),
|
|
|
|
testing::Values(CV_8U, CV_8S, CV_16U, CV_16S, CV_32S, CV_32F, CV_64F),
|
|
|
|
testing::Values(1, 4),
|
|
|
|
testing::Values(1.0, 1./255)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
{
|
|
|
|
Size sz = get<0>(GetParam());
|
|
|
|
int depthSrc = get<1>(GetParam());
|
|
|
|
int depthDst = get<2>(GetParam());
|
|
|
|
int channels = get<3>(GetParam());
|
|
|
|
double alpha = get<4>(GetParam());
|
|
|
|
|
2016-10-18 21:53:37 +08:00
|
|
|
int maxValue = 255;
|
|
|
|
|
2012-10-17 07:18:30 +08:00
|
|
|
Mat src(sz, CV_MAKETYPE(depthSrc, channels));
|
2016-10-18 21:53:37 +08:00
|
|
|
randu(src, 0, maxValue);
|
2012-10-17 07:18:30 +08:00
|
|
|
Mat dst(sz, CV_MAKETYPE(depthDst, channels));
|
|
|
|
|
2013-02-06 18:53:33 +08:00
|
|
|
int runs = (sz.width <= 640) ? 8 : 1;
|
|
|
|
TEST_CYCLE_MULTIRUN(runs) src.convertTo(dst, depthDst, alpha);
|
2012-10-17 07:18:30 +08:00
|
|
|
|
2018-09-07 00:36:59 +08:00
|
|
|
double eps = depthSrc <= CV_32S && (depthDst <= CV_32S || depthDst == CV_64F) ? 1e-12 : (FLT_EPSILON * maxValue);
|
2016-10-18 21:53:37 +08:00
|
|
|
eps = eps * std::max(1.0, fabs(alpha));
|
|
|
|
SANITY_CHECK(dst, eps);
|
2012-10-17 07:18:30 +08:00
|
|
|
}
|
2017-11-05 21:48:40 +08:00
|
|
|
|
|
|
|
} // namespace
|