Files
opencv-wasm/modules/gapi/test/common/gapi_operators_tests_inl.hpp
2022-05-06 01:58:53 +08:00

168 lines
5.3 KiB
C++

// 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) 2018 Intel Corporation
#ifndef OPENCV_GAPI_OPERATOR_TESTS_INL_COMMON_HPP
#define OPENCV_GAPI_OPERATOR_TESTS_INL_COMMON_HPP
#include "gapi_operators_tests.hpp"
namespace opencv_test
{
TEST_P(MathOperatorMatScalarTest, OperatorAccuracyTest )
{
g_api_ocv_pair_mat_scalar funcs(op);
auto fun_gapi = funcs.g_api_function;
auto fun_ocv = funcs.ocv_function;
if (op == DIVR)
in_mat1.setTo(1, in_mat1 == 0); // avoiding zeros in divide input data
if (op == DIV)
sc += Scalar(sc[0] == 0, sc[1] == 0, sc[2] == 0, sc[3] == 0); // avoiding zeros in divide input data
// G-API code & corresponding OpenCV code ////////////////////////////////
cv::GMat in1;
cv::GScalar in2;
auto out = fun_gapi(in1, in2);
cv::GComputation c(GIn(in1, in2), GOut(out));
c.apply(gin(in_mat1, sc), gout(out_mat_gapi), getCompileArgs());
fun_ocv(in_mat1, sc, out_mat_ocv);
// Comparison //////////////////////////////////////////////////////////////
{
ASSERT_EQ(out_mat_gapi.size(), sz);
EXPECT_TRUE(cmpF(out_mat_gapi, out_mat_ocv));
}
}
TEST_P(MathOperatorMatMatTest, OperatorAccuracyTest )
{
g_api_ocv_pair_mat_mat funcs(op);
auto fun_gapi = funcs.g_api_function;
auto fun_ocv = funcs.ocv_function;
if (op == DIV)
in_mat2.setTo(1, in_mat2 == 0); // avoiding zeros in divide input data
// G-API code & corresponding OpenCV code ////////////////////////////////
cv::GMat in1;
cv::GMat in2;
auto out = fun_gapi(in1, in2);
cv::GComputation c(GIn(in1, in2), GOut(out));
c.apply(gin(in_mat1, in_mat2), gout(out_mat_gapi), getCompileArgs());
fun_ocv(in_mat1, in_mat2, out_mat_ocv);
// Comparison //////////////////////////////////////////////////////////////
{
ASSERT_EQ(out_mat_gapi.size(), sz);
EXPECT_TRUE(cmpF(out_mat_gapi, out_mat_ocv));
}
}
TEST_P(NotOperatorTest, OperatorAccuracyTest)
{
// G-API code //////////////////////////////////////////////////////////////
cv::GMat in;
auto out = ~in;
cv::GComputation c(in, out);
c.apply(in_mat1, out_mat_gapi, getCompileArgs());
// OpenCV code /////////////////////////////////////////////////////////////
{
out_mat_ocv =~in_mat1;
}
// Comparison //////////////////////////////////////////////////////////////
{
ASSERT_EQ(out_mat_gapi.size(), sz);
EXPECT_EQ(0, cvtest::norm(out_mat_ocv, out_mat_gapi, NORM_INF));
}
}
namespace for_test
{
class Foo {};
inline int operator&(Foo, int) { return 1; }
inline int operator|(Foo, int) { return 1; }
inline int operator^(Foo, int) { return 1; }
inline int operator~(Foo) { return 1; }
inline int operator+(Foo, int) { return 1; }
inline int operator-(Foo, int) { return 1; }
inline int operator*(Foo, int) { return 1; }
inline int operator/(Foo, int) { return 1; }
inline int operator> (Foo, int) { return 1; }
inline int operator>=(Foo, int) { return 1; }
inline int operator< (Foo, int) { return 1; }
inline int operator<=(Foo, int) { return 1; }
inline int operator==(Foo, int) { return 1; }
inline int operator!=(Foo, int) { return 1; }
TEST(CVNamespaceOperatorsTest, OperatorCompilationTest)
{
cv::GScalar sc;
cv::GMat mat_in1, mat_in2;
cv::GMat op_not = ~ mat_in1;
cv::GMat op_mat_mat1 = mat_in1 & mat_in2;
cv::GMat op_mat_mat2 = mat_in1 | mat_in2;
cv::GMat op_mat_mat3 = mat_in1 ^ mat_in2;
cv::GMat op_mat_mat4 = mat_in1 + mat_in2;
cv::GMat op_mat_mat5 = mat_in1 - mat_in2;
cv::GMat op_mat_mat6 = mat_in1 / mat_in2;
cv::GMat op_mat_mat7 = mat_in1 > mat_in2;
cv::GMat op_mat_mat8 = mat_in1 >= mat_in2;
cv::GMat op_mat_mat9 = mat_in1 < mat_in2;
cv::GMat op_mat_mat10 = mat_in1 <= mat_in2;
cv::GMat op_mat_mat11 = mat_in1 == mat_in2;
cv::GMat op_mat_mat12 = mat_in1 != mat_in2;
cv::GMat op_mat_sc1 = mat_in1 & sc;
cv::GMat op_mat_sc2 = mat_in1 | sc;
cv::GMat op_mat_sc3 = mat_in1 ^ sc;
cv::GMat op_mat_sc4 = mat_in1 + sc;
cv::GMat op_mat_sc5 = mat_in1 - sc;
cv::GMat op_mat_sc6 = mat_in1 * sc;
cv::GMat op_mat_sc7 = mat_in1 / sc;
cv::GMat op_mat_sc8 = mat_in1 > sc;
cv::GMat op_mat_sc9 = mat_in1 >= sc;
cv::GMat op_mat_sc10 = mat_in1 < sc;
cv::GMat op_mat_sc11 = mat_in1 <= sc;
cv::GMat op_mat_sc12 = mat_in1 == sc;
cv::GMat op_mat_sc13 = mat_in1 != sc;
cv::GMat op_sc_mat1 = sc & mat_in2;
cv::GMat op_sc_mat2 = sc | mat_in2;
cv::GMat op_sc_mat3 = sc ^ mat_in2;
cv::GMat op_sc_mat4 = sc + mat_in2;
cv::GMat op_sc_mat5 = sc - mat_in2;
cv::GMat op_sc_mat6 = sc * mat_in2;
cv::GMat op_sc_mat7 = sc / mat_in2;
cv::GMat op_sc_mat8 = sc > mat_in2;
cv::GMat op_sc_mat9 = sc >= mat_in2;
cv::GMat op_sc_mat10 = sc < mat_in2;
cv::GMat op_sc_mat11 = sc <= mat_in2;
cv::GMat op_sc_mat12 = sc == mat_in2;
cv::GMat op_sc_mat13 = sc != mat_in2;
cv::GMat mul_mat_float1 = mat_in1 * 1.0f;
cv::GMat mul_mat_float2 = 1.0f * mat_in2;
// No compilation errors expected
}
} // for_test
} // opencv_test
#endif // OPENCV_GAPI_OPERATOR_TESTS_INL_COMMON_HPP