mirror of https://github.com/opencv/opencv.git
Merge pull request #18343 from TolyaTalamanov:at/support-return-tuple
[G-API] Support std::tuple for return typepull/18365/head
commit
7163781639
5 changed files with 80 additions and 3 deletions
@ -0,0 +1,42 @@ |
||||
#!/usr/bin/env python |
||||
|
||||
import numpy as np |
||||
import cv2 as cv |
||||
|
||||
from tests_common import NewOpenCVTests |
||||
|
||||
|
||||
# Plaidml is an optional backend |
||||
pkgs = [ |
||||
cv.gapi.core.ocl.kernels(), |
||||
cv.gapi.core.cpu.kernels(), |
||||
cv.gapi.core.fluid.kernels() |
||||
# cv.gapi.core.plaidml.kernels() |
||||
] |
||||
|
||||
|
||||
class gapi_sample_pipelines(NewOpenCVTests): |
||||
|
||||
# NB: This test check multiple outputs for operation |
||||
def test_mean_over_r(self): |
||||
sz = (100, 100, 3) |
||||
in_mat = np.random.randint(0, 100, sz).astype(np.uint8) |
||||
|
||||
# # OpenCV |
||||
_, _, r_ch = cv.split(in_mat) |
||||
expected = cv.mean(r_ch) |
||||
|
||||
# G-API |
||||
g_in = cv.GMat() |
||||
b, g, r = cv.gapi.split3(g_in) |
||||
g_out = cv.gapi.mean(r) |
||||
comp = cv.GComputation(g_in, g_out) |
||||
|
||||
for pkg in pkgs: |
||||
actual = comp.apply(in_mat, args=cv.compile_args(pkg)) |
||||
# Comparison |
||||
self.assertEqual(0.0, cv.norm(expected, actual, cv.NORM_INF)) |
||||
|
||||
|
||||
if __name__ == '__main__': |
||||
NewOpenCVTests.bootstrap() |
Loading…
Reference in new issue