perf_moments.cpp 1.34 KB
Newer Older
wester committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
// This file is part of OpenCV project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at http://opencv.org/license.html.

// Copyright (C) 2014, Itseez, Inc., all rights reserved.
// Third party copyrights are property of their respective owners.

#include "perf_precomp.hpp"

using namespace std;
using namespace cv;
using namespace perf;
using namespace testing;
using std::tr1::make_tuple;
using std::tr1::get;

typedef std::tr1::tuple<Size, MatDepth, bool> MomentsParams_t;
typedef perf::TestBaseWithParam<MomentsParams_t> MomentsFixture_val;

PERF_TEST_P(MomentsFixture_val, Moments1,
    ::testing::Combine(
    testing::Values(TYPICAL_MAT_SIZES),
    testing::Values(CV_16U, CV_16S, CV_32F, CV_64F),
    testing::Bool()))
{
    const MomentsParams_t params = GetParam();
    const Size srcSize = get<0>(params);
    const MatDepth srcDepth = get<1>(params);
    const bool binaryImage = get<2>(params);

    cv::Moments m;
    Mat src(srcSize, srcDepth);
    declare.in(src, WARMUP_RNG);

    TEST_CYCLE() m = cv::moments(src, binaryImage);

    int len = (int)sizeof(cv::Moments) / sizeof(double);
    cv::Mat mat(1, len, CV_64F, (void*)&m);
    //adding 1 to moments to avoid accidental tests fail on values close to 0
    mat += 1;


    SANITY_CHECK_MOMENTS(m, 2e-4, ERROR_RELATIVE);
}