12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973 |
- /*M///////////////////////////////////////////////////////////////////////////////////////
- //
- // IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
- //
- // By downloading, copying, installing or using the software you agree to this license.
- // If you do not agree to this license, do not download, install,
- // copy or use the software.
- //
- //
- // License Agreement
- // For Open Source Computer Vision Library
- //
- // Copyright (C) 2010-2013, Advanced Micro Devices, Inc., all rights reserved.
- // Third party copyrights are property of their respective owners.
- //
- // Redistribution and use in source and binary forms, with or without modification,
- // are permitted provided that the following conditions are met:
- //
- // * Redistribution's of source code must retain the above copyright notice,
- // this list of conditions and the following disclaimer.
- //
- // * Redistribution's in binary form must reproduce the above copyright notice,
- // this list of conditions and the following disclaimer in the documentation
- // and/or other materials provided with the distribution.
- //
- // * The name of the copyright holders may not be used to endorse or promote products
- // derived from this software without specific prior written permission.
- //
- // This software is provided by the copyright holders and contributors "as is" and
- // any express or implied warranties, including, but not limited to, the implied
- // warranties of merchantability and fitness for a particular purpose are disclaimed.
- // In no event shall the OpenCV Foundation or contributors be liable for any direct,
- // indirect, incidental, special, exemplary, or consequential damages
- // (including, but not limited to, procurement of substitute goods or services;
- // loss of use, data, or profits; or business interruption) however caused
- // and on any theory of liability, whether in contract, strict liability,
- // or tort (including negligence or otherwise) arising in any way out of
- // the use of this software, even if advised of the possibility of such damage.
- //
- //M*/
- #include "../test_precomp.hpp"
- #include "opencv2/ts/ocl_test.hpp"
- #ifdef HAVE_OPENCL
- namespace opencv_test {
- namespace ocl {
- //////////////////////////////// LUT /////////////////////////////////////////////////
- PARAM_TEST_CASE(Lut, MatDepth, MatDepth, Channels, bool, bool)
- {
- int src_depth, lut_depth;
- int cn;
- bool use_roi, same_cn;
- TEST_DECLARE_INPUT_PARAMETER(src);
- TEST_DECLARE_INPUT_PARAMETER(lut);
- TEST_DECLARE_OUTPUT_PARAMETER(dst);
- virtual void SetUp()
- {
- src_depth = GET_PARAM(0);
- lut_depth = GET_PARAM(1);
- cn = GET_PARAM(2);
- same_cn = GET_PARAM(3);
- use_roi = GET_PARAM(4);
- }
- void generateTestData()
- {
- const int src_type = CV_MAKE_TYPE(src_depth, cn);
- const int lut_type = CV_MAKE_TYPE(lut_depth, same_cn ? cn : 1);
- const int dst_type = CV_MAKE_TYPE(lut_depth, cn);
- Size roiSize = randomSize(1, MAX_VALUE);
- Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src, src_roi, roiSize, srcBorder, src_type, 0, 256);
- Size lutRoiSize = Size(256, 1);
- Border lutBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(lut, lut_roi, lutRoiSize, lutBorder, lut_type, 5, 16);
- Border dstBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst, dst_roi, roiSize, dstBorder, dst_type, 5, 16);
- UMAT_UPLOAD_INPUT_PARAMETER(src);
- UMAT_UPLOAD_INPUT_PARAMETER(lut);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst);
- }
- void Near(double threshold = 0.)
- {
- OCL_EXPECT_MATS_NEAR(dst, threshold);
- }
- };
- OCL_TEST_P(Lut, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::LUT(src_roi, lut_roi, dst_roi));
- OCL_ON(cv::LUT(usrc_roi, ulut_roi, udst_roi));
- Near();
- }
- }
- ///////////////////////// ArithmTestBase ///////////////////////////
- PARAM_TEST_CASE(ArithmTestBase, MatDepth, Channels, bool)
- {
- int depth;
- int cn;
- bool use_roi;
- cv::Scalar val;
- cv::Scalar val_in_range;
- TEST_DECLARE_INPUT_PARAMETER(src1);
- TEST_DECLARE_INPUT_PARAMETER(src2);
- TEST_DECLARE_INPUT_PARAMETER(mask);
- TEST_DECLARE_OUTPUT_PARAMETER(dst1);
- TEST_DECLARE_OUTPUT_PARAMETER(dst2);
- virtual void SetUp()
- {
- depth = GET_PARAM(0);
- cn = GET_PARAM(1);
- use_roi = GET_PARAM(2);
- }
- void generateTestData(bool with_val_in_range = false)
- {
- const int type = CV_MAKE_TYPE(depth, cn);
- double minV = cvtest::getMinVal(type);
- double maxV = cvtest::getMaxVal(type);
- Size roiSize = randomSize(1, MAX_VALUE);
- Border src1Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src1, src1_roi, roiSize, src1Border, type, 2, 11); // FIXIT: Test with minV, maxV
- Border src2Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src2, src2_roi, roiSize, src2Border, type, std::max(-1540., minV), std::min(1740., maxV));
- Border dst1Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst1, dst1_roi, roiSize, dst1Border, type, 5, 16);
- Border dst2Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst2, dst2_roi, roiSize, dst2Border, type, 5, 16);
- Border maskBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(mask, mask_roi, roiSize, maskBorder, CV_8UC1, 0, 2);
- cv::threshold(mask, mask, 0.5, 255., CV_8UC1);
- *mask.ptr(0) = 255; // prevent test case with mask filled 0 only
- val = cv::Scalar(rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0),
- rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0));
- if (with_val_in_range)
- {
- val_in_range = cv::Scalar(rng.uniform(minV, maxV), rng.uniform(minV, maxV),
- rng.uniform(minV, maxV), rng.uniform(minV, maxV));
- }
- UMAT_UPLOAD_INPUT_PARAMETER(src1);
- UMAT_UPLOAD_INPUT_PARAMETER(src2);
- UMAT_UPLOAD_INPUT_PARAMETER(mask);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst1);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst2);
- }
- void Near(double threshold = 0., bool relative = false)
- {
- if (!relative)
- OCL_EXPECT_MATS_NEAR(dst1, threshold);
- else
- OCL_EXPECT_MATS_NEAR_RELATIVE(dst1, threshold);
- }
- void Near1(double threshold = 0.)
- {
- OCL_EXPECT_MATS_NEAR(dst2, threshold);
- }
- };
- //////////////////////////////// Add /////////////////////////////////////////////////
- typedef ArithmTestBase Add;
- OCL_TEST_P(Add, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::add(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::add(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Add, Mat_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::add(src1_roi, src2_roi, dst1_roi, mask_roi));
- OCL_ON(cv::add(usrc1_roi, usrc2_roi, udst1_roi, umask_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Add, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::add(src1_roi, val, dst1_roi));
- OCL_ON(cv::add(val, usrc1_roi, udst1_roi));
- Near(1e-5);
- }
- }
- OCL_TEST_P(Add, Scalar_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::add(src1_roi, val, dst1_roi, mask_roi));
- OCL_ON(cv::add(usrc1_roi, val, udst1_roi, umask_roi));
- Near(1e-5);
- }
- }
- //////////////////////////////////////// Subtract //////////////////////////////////////////////
- typedef ArithmTestBase Subtract;
- OCL_TEST_P(Subtract, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::subtract(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::subtract(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Subtract, Mat_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::subtract(src1_roi, src2_roi, dst1_roi, mask_roi));
- OCL_ON(cv::subtract(usrc1_roi, usrc2_roi, udst1_roi, umask_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Subtract, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::subtract(val, src1_roi, dst1_roi));
- OCL_ON(cv::subtract(val, usrc1_roi, udst1_roi));
- Near(1e-5);
- }
- }
- OCL_TEST_P(Subtract, Scalar_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::subtract(src1_roi, val, dst1_roi, mask_roi));
- OCL_ON(cv::subtract(usrc1_roi, val, udst1_roi, umask_roi));
- Near(1e-5);
- }
- }
- //////////////////////////////// Mul /////////////////////////////////////////////////
- typedef ArithmTestBase Mul;
- OCL_TEST_P(Mul, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::multiply(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::multiply(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Mul, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::multiply(src1_roi, val, dst1_roi));
- OCL_ON(cv::multiply(val, usrc1_roi, udst1_roi));
- Near(udst1_roi.depth() >= CV_32F ? 1e-3 : 1);
- }
- }
- OCL_TEST_P(Mul, Mat_Scale)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::multiply(src1_roi, src2_roi, dst1_roi, val[0]));
- OCL_ON(cv::multiply(usrc1_roi, usrc2_roi, udst1_roi, val[0]));
- if (udst1_roi.depth() >= CV_32F)
- #ifdef __ANDROID__
- Near(2e-1, true);
- #else
- Near(1e-3, true);
- #endif
- else
- Near(1);
- }
- }
- OCL_TEST_P(Mul, Mat_Scalar_Scale)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::multiply(src1_roi, val, dst1_roi, val[0]));
- OCL_ON(cv::multiply(usrc1_roi, val, udst1_roi, val[0]));
- if (udst1_roi.depth() >= CV_32F)
- Near(1e-6, true);
- else
- Near(1);
- }
- }
- //////////////////////////////// Div /////////////////////////////////////////////////
- typedef ArithmTestBase Div;
- OCL_TEST_P(Div, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::divide(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::divide(usrc1_roi, usrc2_roi, udst1_roi));
- Near(1);
- }
- }
- OCL_TEST_P(Div, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::divide(val, src1_roi, dst1_roi));
- OCL_ON(cv::divide(val, usrc1_roi, udst1_roi));
- Near(udst1_roi.depth() >= CV_32F ? 1e-3 : 1);
- }
- }
- OCL_TEST_P(Div, Scalar2)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::divide(src1_roi, val, dst1_roi));
- OCL_ON(cv::divide(usrc1_roi, val, udst1_roi));
- Near(udst1_roi.depth() >= CV_32F ? 1e-3 : 1);
- }
- }
- OCL_TEST_P(Div, Mat_Scale)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::divide(src1_roi, src2_roi, dst1_roi, val[0]));
- OCL_ON(cv::divide(usrc1_roi, usrc2_roi, udst1_roi, val[0]));
- Near(udst1_roi.depth() >= CV_32F ? 4e-3 : 1);
- }
- }
- OCL_TEST_P(Div, Mat_Scalar_Scale)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::divide(src1_roi, val, dst1_roi, val[0]));
- OCL_ON(cv::divide(usrc1_roi, val, udst1_roi, val[0]));
- Near(udst1_roi.depth() >= CV_32F ? 4e-3 : 1);
- }
- }
- OCL_TEST_P(Div, Recip)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::divide(val[0], src1_roi, dst1_roi));
- OCL_ON(cv::divide(val[0], usrc1_roi, udst1_roi));
- Near(udst1_roi.depth() >= CV_32F ? 1e-3 : 1);
- }
- }
- //////////////////////////////// Min/Max /////////////////////////////////////////////////
- typedef ArithmTestBase Min;
- OCL_TEST_P(Min, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::min(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::min(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- typedef ArithmTestBase Max;
- OCL_TEST_P(Max, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::max(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::max(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- //////////////////////////////// Absdiff /////////////////////////////////////////////////
- typedef ArithmTestBase Absdiff;
- OCL_TEST_P(Absdiff, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::absdiff(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::absdiff(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Absdiff, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::absdiff(src1_roi, val, dst1_roi));
- OCL_ON(cv::absdiff(usrc1_roi, val, udst1_roi));
- Near(1e-5);
- }
- }
- //////////////////////////////// CartToPolar /////////////////////////////////////////////////
- typedef ArithmTestBase CartToPolar;
- OCL_TEST_P(CartToPolar, angleInDegree)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::cartToPolar(src1_roi, src2_roi, dst1_roi, dst2_roi, true));
- OCL_ON(cv::cartToPolar(usrc1_roi, usrc2_roi, udst1_roi, udst2_roi, true));
- Near(0.5);
- Near1(0.5);
- }
- }
- OCL_TEST_P(CartToPolar, angleInRadians)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::cartToPolar(src1_roi, src2_roi, dst1_roi, dst2_roi));
- OCL_ON(cv::cartToPolar(usrc1_roi, usrc2_roi, udst1_roi, udst2_roi));
- Near(0.5);
- Near1(0.5);
- }
- }
- //////////////////////////////// PolarToCart /////////////////////////////////////////////////
- typedef ArithmTestBase PolarToCart;
- OCL_TEST_P(PolarToCart, angleInDegree)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::polarToCart(src1_roi, src2_roi, dst1_roi, dst2_roi, true));
- OCL_ON(cv::polarToCart(usrc1_roi, usrc2_roi, udst1_roi, udst2_roi, true));
- Near(0.5);
- Near1(0.5);
- }
- }
- OCL_TEST_P(PolarToCart, angleInRadians)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::polarToCart(src1_roi, src2_roi, dst1_roi, dst2_roi));
- OCL_ON(cv::polarToCart(usrc1_roi, usrc2_roi, udst1_roi, udst2_roi));
- Near(0.5);
- Near1(0.5);
- }
- }
- //////////////////////////////// Transpose /////////////////////////////////////////////////
- typedef ArithmTestBase Transpose;
- OCL_TEST_P(Transpose, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- Size roiSize = src1_roi.size();
- Border dst1Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst1, dst1_roi, Size(roiSize.height, roiSize.width), dst1Border, src1.type(), 5, 16);
- UMAT_UPLOAD_INPUT_PARAMETER(dst1);
- OCL_OFF(cv::transpose(src1_roi, dst1_roi));
- OCL_ON(cv::transpose(usrc1_roi, udst1_roi));
- Near(1e-5);
- }
- }
- OCL_TEST_P(Transpose, SquareInplace)
- {
- const int type = CV_MAKE_TYPE(depth, cn);
- for (int j = 0; j < test_loop_times; j++)
- {
- Size roiSize = randomSize(1, MAX_VALUE);
- roiSize.height = roiSize.width; // make it square
- Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src1, src1_roi, roiSize, srcBorder, type, 5, 16);
- UMAT_UPLOAD_OUTPUT_PARAMETER(src1);
- OCL_OFF(cv::transpose(src1_roi, src1_roi));
- OCL_ON(cv::transpose(usrc1_roi, usrc1_roi));
- OCL_EXPECT_MATS_NEAR(src1, 0);
- }
- }
- //////////////////////////////// Bitwise_and /////////////////////////////////////////////////
- typedef ArithmTestBase Bitwise_and;
- OCL_TEST_P(Bitwise_and, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_and(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::bitwise_and(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Bitwise_and, Mat_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_and(src1_roi, src2_roi, dst1_roi, mask_roi));
- OCL_ON(cv::bitwise_and(usrc1_roi, usrc2_roi, udst1_roi, umask_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Bitwise_and, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_and(src1_roi, val, dst1_roi));
- OCL_ON(cv::bitwise_and(usrc1_roi, val, udst1_roi));
- Near(1e-5);
- }
- }
- OCL_TEST_P(Bitwise_and, Scalar_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_and(src1_roi, val, dst1_roi, mask_roi));
- OCL_ON(cv::bitwise_and(usrc1_roi, val, udst1_roi, umask_roi));
- Near(1e-5);
- }
- }
- //////////////////////////////// Bitwise_or /////////////////////////////////////////////////
- typedef ArithmTestBase Bitwise_or;
- OCL_TEST_P(Bitwise_or, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_or(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::bitwise_or(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Bitwise_or, Mat_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_or(src1_roi, src2_roi, dst1_roi, mask_roi));
- OCL_ON(cv::bitwise_or(usrc1_roi, usrc2_roi, udst1_roi, umask_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Bitwise_or, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_or(src1_roi, val, dst1_roi));
- OCL_ON(cv::bitwise_or(usrc1_roi, val, udst1_roi));
- Near(1e-5);
- }
- }
- OCL_TEST_P(Bitwise_or, Scalar_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_or(src1_roi, val, dst1_roi, mask_roi));
- OCL_ON(cv::bitwise_or(val, usrc1_roi, udst1_roi, umask_roi));
- Near(1e-5);
- }
- }
- //////////////////////////////// Bitwise_xor /////////////////////////////////////////////////
- typedef ArithmTestBase Bitwise_xor;
- OCL_TEST_P(Bitwise_xor, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_xor(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::bitwise_xor(usrc1_roi, usrc2_roi, udst1_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Bitwise_xor, Mat_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_xor(src1_roi, src2_roi, dst1_roi, mask_roi));
- OCL_ON(cv::bitwise_xor(usrc1_roi, usrc2_roi, udst1_roi, umask_roi));
- Near(0);
- }
- }
- OCL_TEST_P(Bitwise_xor, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_xor(src1_roi, val, dst1_roi));
- OCL_ON(cv::bitwise_xor(usrc1_roi, val, udst1_roi));
- Near(1e-5);
- }
- }
- OCL_TEST_P(Bitwise_xor, Scalar_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_xor(src1_roi, val, dst1_roi, mask_roi));
- OCL_ON(cv::bitwise_xor(usrc1_roi, val, udst1_roi, umask_roi));
- Near(1e-5);
- }
- }
- //////////////////////////////// Bitwise_not /////////////////////////////////////////////////
- typedef ArithmTestBase Bitwise_not;
- OCL_TEST_P(Bitwise_not, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::bitwise_not(src1_roi, dst1_roi));
- OCL_ON(cv::bitwise_not(usrc1_roi, udst1_roi));
- Near(0);
- }
- }
- //////////////////////////////// Compare /////////////////////////////////////////////////
- typedef ArithmTestBase Compare;
- static const int cmp_codes[] = { CMP_EQ, CMP_GT, CMP_GE, CMP_LT, CMP_LE, CMP_NE };
- static const char * cmp_strs[] = { "CMP_EQ", "CMP_GT", "CMP_GE", "CMP_LT", "CMP_LE", "CMP_NE" };
- static const int cmp_num = sizeof(cmp_codes) / sizeof(int);
- OCL_TEST_P(Compare, Mat)
- {
- for (int i = 0; i < cmp_num; ++i)
- {
- SCOPED_TRACE(cmp_strs[i]);
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::compare(src1_roi, src2_roi, dst1_roi, cmp_codes[i]));
- OCL_ON(cv::compare(usrc1_roi, usrc2_roi, udst1_roi, cmp_codes[i]));
- Near(0);
- }
- }
- }
- OCL_TEST_P(Compare, Scalar)
- {
- for (int i = 0; i < cmp_num; ++i)
- {
- SCOPED_TRACE(cmp_strs[i]);
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData(true);
- OCL_OFF(cv::compare(src1_roi, val_in_range, dst1_roi, cmp_codes[i]));
- OCL_ON(cv::compare(usrc1_roi, val_in_range, udst1_roi, cmp_codes[i]));
- Near(0);
- }
- }
- }
- OCL_TEST_P(Compare, Scalar2)
- {
- for (int i = 0; i < cmp_num; ++i)
- {
- SCOPED_TRACE(cmp_strs[i]);
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData(true);
- OCL_OFF(cv::compare(val_in_range, src1_roi, dst1_roi, cmp_codes[i]));
- OCL_ON(cv::compare(val_in_range, usrc1_roi, udst1_roi, cmp_codes[i]));
- Near(0);
- }
- }
- }
- //////////////////////////////// Pow /////////////////////////////////////////////////
- typedef ArithmTestBase Pow;
- OCL_TEST_P(Pow, Mat)
- {
- static const double pows[] = { -4, -1, -2.5, 0, 1, 2, 3.7, 4 };
- for (int j = 0; j < 1/*test_loop_times*/; j++)
- for (int k = 0, size = sizeof(pows) / sizeof(double); k < size; ++k)
- {
- SCOPED_TRACE(pows[k]);
- generateTestData();
- OCL_OFF(cv::pow(src1_roi, pows[k], dst1_roi));
- OCL_ON(cv::pow(usrc1_roi, pows[k], udst1_roi));
- OCL_EXPECT_MATS_NEAR_RELATIVE(dst1, 1e-5);
- }
- }
- //////////////////////////////// AddWeighted /////////////////////////////////////////////////
- typedef ArithmTestBase AddWeighted;
- OCL_TEST_P(AddWeighted, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- const double alpha = 2.0, beta = 1.0, gama = 3.0;
- OCL_OFF(cv::addWeighted(src1_roi, alpha, src2_roi, beta, gama, dst1_roi));
- OCL_ON(cv::addWeighted(usrc1_roi, alpha, usrc2_roi, beta, gama, udst1_roi));
- if(dst1_roi.depth() >= CV_32F)
- Near(3e-4, true);
- else
- Near(1);
- }
- }
- //////////////////////////////// setIdentity /////////////////////////////////////////////////
- typedef ArithmTestBase SetIdentity;
- OCL_TEST_P(SetIdentity, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::setIdentity(dst1_roi, val));
- OCL_ON(cv::setIdentity(udst1_roi, val));
- Near(0);
- }
- }
- //// Repeat
- struct RepeatTestCase :
- public ArithmTestBase
- {
- int nx, ny;
- void generateTestData()
- {
- const int type = CV_MAKE_TYPE(depth, cn);
- nx = randomInt(1, 4);
- ny = randomInt(1, 4);
- Size srcRoiSize = randomSize(1, MAX_VALUE);
- Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src1, src1_roi, srcRoiSize, srcBorder, type, 2, 11);
- Size dstRoiSize(srcRoiSize.width * nx, srcRoiSize.height * ny);
- Border dst1Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst1, dst1_roi, dstRoiSize, dst1Border, type, 5, 16);
- UMAT_UPLOAD_INPUT_PARAMETER(src1);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst1);
- }
- };
- typedef RepeatTestCase Repeat;
- OCL_TEST_P(Repeat, Mat)
- {
- for (int i = 0; i < test_loop_times; ++i)
- {
- generateTestData();
- OCL_OFF(cv::repeat(src1_roi, ny, nx, dst1_roi));
- OCL_ON(cv::repeat(usrc1_roi, ny, nx, udst1_roi));
- Near();
- }
- }
- //////////////////////////////// CountNonZero /////////////////////////////////////////////////
- typedef ArithmTestBase CountNonZero;
- OCL_TEST_P(CountNonZero, MAT)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- int cpures, gpures;
- OCL_OFF(cpures = cv::countNonZero(src1_roi));
- OCL_ON(gpures = cv::countNonZero(usrc1_roi));
- EXPECT_EQ(cpures, gpures);
- }
- }
- //////////////////////////////// Sum /////////////////////////////////////////////////
- typedef ArithmTestBase Sum;
- OCL_TEST_P(Sum, MAT)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- Scalar cpures, gpures;
- OCL_OFF(cpures = cv::sum(src1_roi));
- OCL_ON(gpures = cv::sum(usrc1_roi));
- for (int i = 0; i < cn; ++i)
- EXPECT_NEAR(cpures[i], gpures[i], 0.1);
- }
- }
- //////////////////////////////// meanStdDev /////////////////////////////////////////////////
- typedef ArithmTestBase MeanStdDev;
- OCL_TEST_P(MeanStdDev, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- Scalar cpu_mean, cpu_stddev;
- Scalar gpu_mean, gpu_stddev;
- OCL_OFF(cv::meanStdDev(src1_roi, cpu_mean, cpu_stddev));
- OCL_ON(cv::meanStdDev(usrc1_roi, gpu_mean, gpu_stddev));
- for (int i = 0; i < cn; ++i)
- {
- EXPECT_NEAR(cpu_mean[i], gpu_mean[i], 0.1);
- EXPECT_NEAR(cpu_stddev[i], gpu_stddev[i], 0.1);
- }
- }
- }
- OCL_TEST_P(MeanStdDev, Mat_Mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- Scalar cpu_mean, cpu_stddev;
- Scalar gpu_mean, gpu_stddev;
- OCL_OFF(cv::meanStdDev(src1_roi, cpu_mean, cpu_stddev, mask_roi));
- OCL_ON(cv::meanStdDev(usrc1_roi, gpu_mean, gpu_stddev, umask_roi));
- for (int i = 0; i < cn; ++i)
- {
- EXPECT_NEAR(cpu_mean[i], gpu_mean[i], 0.1);
- EXPECT_NEAR(cpu_stddev[i], gpu_stddev[i], 0.1);
- }
- }
- }
- OCL_TEST(MeanStdDev_, ZeroMask)
- {
- Size size(5, 5);
- UMat um(size, CV_32SC1), umask(size, CV_8UC1, Scalar::all(0));
- Mat m(size, CV_32SC1), mask(size, CV_8UC1, Scalar::all(0));
- Scalar cpu_mean, cpu_stddev;
- Scalar gpu_mean, gpu_stddev;
- OCL_OFF(cv::meanStdDev(m, cpu_mean, cpu_stddev, mask));
- OCL_ON(cv::meanStdDev(um, gpu_mean, gpu_stddev, umask));
- for (int i = 0; i < 4; ++i)
- {
- EXPECT_NEAR(cpu_mean[i], gpu_mean[i], 0.1);
- EXPECT_NEAR(cpu_stddev[i], gpu_stddev[i], 0.1);
- }
- }
- //////////////////////////////////////// Log /////////////////////////////////////////
- typedef ArithmTestBase Log;
- OCL_TEST_P(Log, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::log(src1_roi, dst1_roi));
- OCL_ON(cv::log(usrc1_roi, udst1_roi));
- Near(1);
- }
- }
- //////////////////////////////////////// Exp /////////////////////////////////////////
- typedef ArithmTestBase Exp;
- OCL_TEST_P(Exp, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::exp(src1_roi, dst1_roi));
- OCL_ON(cv::exp(usrc1_roi, udst1_roi));
- Near(2);
- }
- }
- //////////////////////////////////////// Phase /////////////////////////////////////////
- typedef ArithmTestBase Phase;
- OCL_TEST_P(Phase, angleInDegree)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::phase(src1_roi, src2_roi, dst1_roi, true));
- OCL_ON(cv::phase(usrc1_roi, usrc2_roi, udst1_roi, true));
- Near(1e-2);
- }
- }
- OCL_TEST_P(Phase, angleInRadians)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::phase(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::phase(usrc1_roi, usrc2_roi, udst1_roi));
- Near(1e-2);
- }
- }
- //////////////////////////////////////// Magnitude /////////////////////////////////////////
- typedef ArithmTestBase Magnitude;
- OCL_TEST_P(Magnitude, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::magnitude(src1_roi, src2_roi, dst1_roi));
- OCL_ON(cv::magnitude(usrc1_roi, usrc2_roi, udst1_roi));
- Near(depth == CV_64F ? 1e-5 : 1e-2);
- }
- }
- //////////////////////////////// Flip /////////////////////////////////////////////////
- typedef ArithmTestBase Flip;
- OCL_TEST_P(Flip, X)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::flip(src1_roi, dst1_roi, 0));
- OCL_ON(cv::flip(usrc1_roi, udst1_roi, 0));
- Near(0);
- }
- }
- OCL_TEST_P(Flip, Y)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::flip(src1_roi, dst1_roi, 1));
- OCL_ON(cv::flip(usrc1_roi, udst1_roi, 1));
- Near(0);
- }
- }
- OCL_TEST_P(Flip, BOTH)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::flip(src1_roi, dst1_roi, -1));
- OCL_ON(cv::flip(usrc1_roi, udst1_roi, -1));
- Near(0);
- }
- }
- //////////////////////////////////////// minMaxIdx /////////////////////////////////////////
- typedef ArithmTestBase MinMaxIdx;
- OCL_TEST_P(MinMaxIdx, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- int p1[2], p2[2], up1[2], up2[2];
- double minv, maxv, uminv, umaxv;
- if (cn > 1)
- {
- OCL_OFF(cv::minMaxIdx(src2_roi, &minv, &maxv) );
- OCL_ON(cv::minMaxIdx(usrc2_roi, &uminv, &umaxv));
- EXPECT_DOUBLE_EQ(minv, uminv);
- EXPECT_DOUBLE_EQ(maxv, umaxv);
- }
- else
- {
- OCL_OFF(cv::minMaxIdx(src2_roi, &minv, &maxv, p1, p2, noArray()));
- OCL_ON(cv::minMaxIdx(usrc2_roi, &uminv, &umaxv, up1, up2, noArray()));
- EXPECT_DOUBLE_EQ(minv, uminv);
- EXPECT_DOUBLE_EQ(maxv, umaxv);
- for (int i = 0; i < 2; i++)
- {
- EXPECT_EQ(p1[i], up1[i]);
- EXPECT_EQ(p2[i], up2[i]);
- }
- }
- }
- }
- typedef ArithmTestBase MinMaxIdx_Mask;
- OCL_TEST_P(MinMaxIdx_Mask, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- int p1[2], p2[2], up1[2], up2[2];
- double minv, maxv, uminv, umaxv;
- OCL_OFF(cv::minMaxIdx(src2_roi, &minv, &maxv, p1, p2, mask_roi));
- OCL_ON(cv::minMaxIdx(usrc2_roi, &uminv, &umaxv, up1, up2, umask_roi));
- EXPECT_DOUBLE_EQ(minv, uminv);
- EXPECT_DOUBLE_EQ(maxv, umaxv);
- for( int i = 0; i < 2; i++)
- {
- EXPECT_EQ(p1[i], up1[i]);
- EXPECT_EQ(p2[i], up2[i]);
- }
- }
- }
- //////////////////////////////// Norm /////////////////////////////////////////////////
- static bool relativeError(double actual, double expected, double eps)
- {
- return std::abs(actual - expected) < eps*(1 + std::abs(actual));
- }
- typedef ArithmTestBase Norm;
- OCL_TEST_P(Norm, NORM_INF_1arg)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, NORM_INF));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, NORM_INF));
- EXPECT_NEAR(cpuRes, gpuRes, 0.1);
- }
- }
- OCL_TEST_P(Norm, NORM_INF_1arg_mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, NORM_INF, mask_roi));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, NORM_INF, umask_roi));
- EXPECT_NEAR(cpuRes, gpuRes, 0.2);
- }
- }
- OCL_TEST_P(Norm, NORM_L1_1arg)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, NORM_L1));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, NORM_L1));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L1_1arg_mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, NORM_L1, mask_roi));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, NORM_L1, umask_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L2_1arg)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, NORM_L2));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, NORM_L2));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L2_1arg_mask)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, NORM_L2, mask_roi));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, NORM_L2, umask_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_INF_2args)
- {
- for (int relative = 0; relative < 2; ++relative)
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- SCOPED_TRACE(relative ? "NORM_RELATIVE" : "");
- int type = NORM_INF;
- if (relative == 1)
- type |= NORM_RELATIVE;
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, src2_roi, type));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, usrc2_roi, type));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_INF_2args_mask)
- {
- for (int relative = 0; relative < 2; ++relative)
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- SCOPED_TRACE(relative ? "NORM_RELATIVE" : "");
- int type = NORM_INF;
- if (relative == 1)
- type |= NORM_RELATIVE;
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, src2_roi, type, mask_roi));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, usrc2_roi, type, umask_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L1_2args)
- {
- for (int relative = 0; relative < 2; ++relative)
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- SCOPED_TRACE(relative ? "NORM_RELATIVE" : "");
- int type = NORM_L1;
- if (relative == 1)
- type |= NORM_RELATIVE;
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, src2_roi, type));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, usrc2_roi, type));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L1_2args_mask)
- {
- for (int relative = 0; relative < 2; ++relative)
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- SCOPED_TRACE(relative ? "NORM_RELATIVE" : "");
- int type = NORM_L1;
- if (relative == 1)
- type |= NORM_RELATIVE;
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, src2_roi, type, mask_roi));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, usrc2_roi, type, umask_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L2_2args)
- {
- for (int relative = 0; relative < 2; ++relative)
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- SCOPED_TRACE(relative ? "NORM_RELATIVE" : "");
- int type = NORM_L2;
- if (relative == 1)
- type |= NORM_RELATIVE;
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, src2_roi, type));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, usrc2_roi, type));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- OCL_TEST_P(Norm, NORM_L2_2args_mask)
- {
- for (int relative = 0; relative < 2; ++relative)
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- SCOPED_TRACE(relative ? "NORM_RELATIVE" : "");
- int type = NORM_L2;
- if (relative == 1)
- type |= NORM_RELATIVE;
- OCL_OFF(const double cpuRes = cv::norm(src1_roi, src2_roi, type, mask_roi));
- OCL_ON(const double gpuRes = cv::norm(usrc1_roi, usrc2_roi, type, umask_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- //////////////////////////////// UMat::dot ////////////////////////////////////////////////
- typedef ArithmTestBase UMatDot;
- OCL_TEST_P(UMatDot, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(const double cpuRes = src1_roi.dot(src2_roi));
- OCL_ON(const double gpuRes = usrc1_roi.dot(usrc2_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-5);
- }
- }
- //////////////////////////////// Sqrt ////////////////////////////////////////////////
- typedef ArithmTestBase Sqrt;
- OCL_TEST_P(Sqrt, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::sqrt(src1_roi, dst1_roi));
- OCL_ON(cv::sqrt(usrc1_roi, udst1_roi));
- Near(1);
- }
- }
- //////////////////////////////// Normalize ////////////////////////////////////////////////
- typedef ArithmTestBase Normalize;
- OCL_TEST_P(Normalize, Mat)
- {
- static int modes[] = { CV_MINMAX, CV_L2, CV_L1, CV_C };
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- for (int i = 0, size = sizeof(modes) / sizeof(modes[0]); i < size; ++i)
- {
- OCL_OFF(cv::normalize(src1_roi, dst1_roi, 10, 110, modes[i], src1_roi.type(), mask_roi));
- OCL_ON(cv::normalize(usrc1_roi, udst1_roi, 10, 110, modes[i], src1_roi.type(), umask_roi));
- Near(1);
- }
- }
- }
- //////////////////////////////////////// InRange ///////////////////////////////////////////////
- PARAM_TEST_CASE(InRange, MatDepth, Channels, bool /*Scalar or not*/, bool /*Roi*/)
- {
- int depth;
- int cn;
- bool scalars, use_roi;
- cv::Scalar val1, val2;
- TEST_DECLARE_INPUT_PARAMETER(src1);
- TEST_DECLARE_INPUT_PARAMETER(src2);
- TEST_DECLARE_INPUT_PARAMETER(src3);
- TEST_DECLARE_OUTPUT_PARAMETER(dst);
- virtual void SetUp()
- {
- depth = GET_PARAM(0);
- cn = GET_PARAM(1);
- scalars = GET_PARAM(2);
- use_roi = GET_PARAM(3);
- }
- void generateTestData()
- {
- const int type = CV_MAKE_TYPE(depth, cn);
- Size roiSize = randomSize(1, MAX_VALUE);
- Border src1Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src1, src1_roi, roiSize, src1Border, type, -40, 40);
- Border src2Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src2, src2_roi, roiSize, src2Border, type, -40, 40);
- Border src3Border = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src3, src3_roi, roiSize, src3Border, type, -40, 40);
- Border dstBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst, dst_roi, roiSize, dstBorder, CV_8UC1, 5, 16);
- val1 = cv::Scalar(rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0),
- rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0));
- val2 = cv::Scalar(rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0),
- rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0));
- UMAT_UPLOAD_INPUT_PARAMETER(src1);
- UMAT_UPLOAD_INPUT_PARAMETER(src2);
- UMAT_UPLOAD_INPUT_PARAMETER(src3);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst);
- }
- void Near()
- {
- OCL_EXPECT_MATS_NEAR(dst, 0);
- }
- };
- OCL_TEST_P(InRange, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::inRange(src1_roi, src2_roi, src3_roi, dst_roi));
- OCL_ON(cv::inRange(usrc1_roi, usrc2_roi, usrc3_roi, udst_roi));
- Near();
- }
- }
- OCL_TEST_P(InRange, Scalar)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::inRange(src1_roi, val1, val2, dst_roi));
- OCL_ON(cv::inRange(usrc1_roi, val1, val2, udst_roi));
- Near();
- }
- }
- //////////////////////////////// ConvertScaleAbs ////////////////////////////////////////////////
- PARAM_TEST_CASE(ConvertScaleAbs, MatDepth, Channels, bool)
- {
- int depth;
- int cn;
- bool use_roi;
- cv::Scalar val;
- TEST_DECLARE_INPUT_PARAMETER(src);
- TEST_DECLARE_OUTPUT_PARAMETER(dst);
- virtual void SetUp()
- {
- depth = GET_PARAM(0);
- cn = GET_PARAM(1);
- use_roi = GET_PARAM(2);
- }
- void generateTestData()
- {
- const int stype = CV_MAKE_TYPE(depth, cn);
- const int dtype = CV_MAKE_TYPE(CV_8U, cn);
- Size roiSize = randomSize(1, MAX_VALUE);
- Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src, src_roi, roiSize, srcBorder, stype, -11, 11); // FIXIT: Test with minV, maxV
- Border dstBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst, dst_roi, roiSize, dstBorder, dtype, 5, 16);
- val = cv::Scalar(rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0),
- rng.uniform(-100.0, 100.0), rng.uniform(-100.0, 100.0));
- UMAT_UPLOAD_INPUT_PARAMETER(src);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst);
- }
- void Near(double threshold = 0.)
- {
- OCL_EXPECT_MATS_NEAR(dst, threshold);
- }
- };
- OCL_TEST_P(ConvertScaleAbs, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::convertScaleAbs(src_roi, dst_roi, val[0], val[1]));
- OCL_ON(cv::convertScaleAbs(usrc_roi, udst_roi, val[0], val[1]));
- Near(1);
- }
- }
- //////////////////////////////// ConvertFp16 ////////////////////////////////////////////////
- PARAM_TEST_CASE(ConvertFp16, Channels, bool)
- {
- int cn;
- bool fromHalf;
- cv::Scalar val;
- TEST_DECLARE_INPUT_PARAMETER(src);
- TEST_DECLARE_OUTPUT_PARAMETER(dst);
- virtual void SetUp()
- {
- cn = GET_PARAM(0);
- fromHalf = GET_PARAM(1);
- }
- void generateTestData()
- {
- const int stype = CV_MAKE_TYPE(fromHalf ? CV_32F : CV_16S, cn);
- const int dtype = CV_MAKE_TYPE(fromHalf ? CV_16S : CV_32F, cn);
- Size roiSize = randomSize(1, MAX_VALUE);
- Border srcBorder = randomBorder(0, 0);
- randomSubMat(src, src_roi, roiSize, srcBorder, stype, -11, 11); // FIXIT: Test with minV, maxV
- if (stype == CV_MAKE_TYPE(CV_16S, cn)) // eliminate NaN/Inf FP16 values
- {
- RNG dataRng(rng.next());
- Mat src_i32 = cvtest::randomMat(dataRng, roiSize, CV_MAKE_TYPE(CV_32S, cn), 0, 0x7c00, false);
- Mat shift_i32 = cvtest::randomMat(dataRng, roiSize, src_i32.type(), -1, 1, false); // values: -1, 0
- src_i32 = src_i32 + (shift_i32 * 0x8000);
- src_i32.convertTo(src_roi, stype);
- }
- Border dstBorder = randomBorder(0, 0);
- randomSubMat(dst, dst_roi, roiSize, dstBorder, dtype, 5, 16);
- UMAT_UPLOAD_INPUT_PARAMETER(src);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst);
- }
- void Near(double threshold = 0.)
- {
- OCL_EXPECT_MATS_NEAR(dst, threshold);
- }
- };
- OCL_TEST_P(ConvertFp16, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::convertFp16(src_roi, dst_roi));
- OCL_ON(cv::convertFp16(usrc_roi, udst_roi));
- Near(1);
- }
- }
- //////////////////////////////// ScaleAdd ////////////////////////////////////////////////
- typedef ArithmTestBase ScaleAdd;
- OCL_TEST_P(ScaleAdd, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::scaleAdd(src1_roi, val[0], src2_roi, dst1_roi));
- OCL_ON(cv::scaleAdd(usrc1_roi, val[0], usrc2_roi, udst1_roi));
- Near(depth <= CV_32S ? 1 : 1e-3);
- }
- }
- //////////////////////////////// PatchNans ////////////////////////////////////////////////
- PARAM_TEST_CASE(PatchNaNs, Channels, bool)
- {
- int cn;
- bool use_roi;
- double value;
- TEST_DECLARE_INPUT_PARAMETER(src);
- virtual void SetUp()
- {
- cn = GET_PARAM(0);
- use_roi = GET_PARAM(1);
- }
- void generateTestData()
- {
- const int type = CV_MAKE_TYPE(CV_32F, cn);
- Size roiSize = randomSize(1, 10);
- Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src, src_roi, roiSize, srcBorder, type, -40, 40);
- // generating NaNs
- roiSize.width *= cn;
- for (int y = 0; y < roiSize.height; ++y)
- {
- float * const ptr = src_roi.ptr<float>(y);
- for (int x = 0; x < roiSize.width; ++x)
- ptr[x] = randomInt(-1, 1) == 0 ? std::numeric_limits<float>::quiet_NaN() : ptr[x];
- }
- value = randomDouble(-100, 100);
- UMAT_UPLOAD_INPUT_PARAMETER(src);
- }
- void Near()
- {
- OCL_EXPECT_MATS_NEAR(src, 0);
- }
- };
- OCL_TEST_P(PatchNaNs, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::patchNaNs(src_roi, value));
- OCL_ON(cv::patchNaNs(usrc_roi, value));
- Near();
- }
- }
- //////////////////////////////// Psnr ////////////////////////////////////////////////
- typedef ArithmTestBase Psnr;
- OCL_TEST_P(Psnr, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- double cpuRes = 0, gpuRes = 0;
- OCL_OFF(cpuRes = cv::PSNR(src1_roi, src2_roi));
- OCL_ON(gpuRes = cv::PSNR(usrc1_roi, usrc2_roi));
- EXPECT_PRED3(relativeError, cpuRes, gpuRes, 1e-6);
- }
- }
- //////////////////////////////////////// Reduce /////////////////////////////////////////////
- PARAM_TEST_CASE(Reduce, std::pair<MatDepth, MatDepth>, Channels, int, bool)
- {
- int sdepth, ddepth, cn, dim, dtype;
- bool use_roi;
- TEST_DECLARE_INPUT_PARAMETER(src);
- TEST_DECLARE_OUTPUT_PARAMETER(dst);
- virtual void SetUp()
- {
- const std::pair<MatDepth, MatDepth> p = GET_PARAM(0);
- sdepth = p.first;
- ddepth = p.second;
- cn = GET_PARAM(1);
- dim = GET_PARAM(2);
- use_roi = GET_PARAM(3);
- }
- void generateTestData()
- {
- const int stype = CV_MAKE_TYPE(sdepth, cn);
- dtype = CV_MAKE_TYPE(ddepth, cn);
- Size roiSize = randomSize(1, MAX_VALUE);
- Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(src, src_roi, roiSize, srcBorder, stype, -40, 40);
- Size dstRoiSize = Size(dim == 0 ? roiSize.width : 1, dim == 0 ? 1 : roiSize.height);
- Border dstBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
- randomSubMat(dst, dst_roi, dstRoiSize, dstBorder, dtype, 5, 16);
- UMAT_UPLOAD_INPUT_PARAMETER(src);
- UMAT_UPLOAD_OUTPUT_PARAMETER(dst);
- }
- };
- typedef Reduce ReduceSum;
- OCL_TEST_P(ReduceSum, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::reduce(src_roi, dst_roi, dim, REDUCE_SUM, dtype));
- OCL_ON(cv::reduce(usrc_roi, udst_roi, dim, REDUCE_SUM, dtype));
- double eps = ddepth <= CV_32S ? 1 : 7e-4;
- OCL_EXPECT_MATS_NEAR(dst, eps);
- }
- }
- typedef Reduce ReduceMax;
- OCL_TEST_P(ReduceMax, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::reduce(src_roi, dst_roi, dim, REDUCE_MAX, dtype));
- OCL_ON(cv::reduce(usrc_roi, udst_roi, dim, REDUCE_MAX, dtype));
- OCL_EXPECT_MATS_NEAR(dst, 0);
- }
- }
- typedef Reduce ReduceMin;
- OCL_TEST_P(ReduceMin, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::reduce(src_roi, dst_roi, dim, REDUCE_MIN, dtype));
- OCL_ON(cv::reduce(usrc_roi, udst_roi, dim, REDUCE_MIN, dtype));
- OCL_EXPECT_MATS_NEAR(dst, 0);
- }
- }
- typedef Reduce ReduceAvg;
- OCL_TEST_P(ReduceAvg, Mat)
- {
- for (int j = 0; j < test_loop_times; j++)
- {
- generateTestData();
- OCL_OFF(cv::reduce(src_roi, dst_roi, dim, REDUCE_AVG, dtype));
- OCL_ON(cv::reduce(usrc_roi, udst_roi, dim, REDUCE_AVG, dtype));
- double eps = ddepth <= CV_32S ? 1 : 6e-6;
- OCL_EXPECT_MATS_NEAR(dst, eps);
- }
- }
- //////////////////////////////////////// Instantiation /////////////////////////////////////////
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Lut, Combine(::testing::Values(CV_8U, CV_8S), OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool(), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Add, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Subtract, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Mul, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Div, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Min, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Max, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Absdiff, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, CartToPolar, Combine(testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, PolarToCart, Combine(testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Transpose, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Bitwise_and, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Bitwise_not, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Bitwise_xor, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Bitwise_or, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Pow, Combine(testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Compare, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, AddWeighted, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, SetIdentity, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Repeat, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, CountNonZero, Combine(OCL_ALL_DEPTHS, testing::Values(Channels(1)), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Sum, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, MeanStdDev, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Log, Combine(::testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Exp, Combine(::testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Phase, Combine(::testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Magnitude, Combine(::testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Flip, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, MinMaxIdx, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, MinMaxIdx_Mask, Combine(OCL_ALL_DEPTHS, ::testing::Values(Channels(1)), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Norm, Combine(OCL_ALL_DEPTHS_16F, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Sqrt, Combine(::testing::Values(CV_32F, CV_64F), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Normalize, Combine(OCL_ALL_DEPTHS, Values(Channels(1)), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, InRange, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool(), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ConvertScaleAbs, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ConvertFp16, Combine(OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ScaleAdd, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, PatchNaNs, Combine(OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, Psnr, Combine(::testing::Values((MatDepth)CV_8U), OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, UMatDot, Combine(OCL_ALL_DEPTHS, OCL_ALL_CHANNELS, Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ReduceSum, Combine(testing::Values(std::make_pair<MatDepth, MatDepth>(CV_8U, CV_32S),
- std::make_pair<MatDepth, MatDepth>(CV_8U, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_8U, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_16U, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_16U, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_16S, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_16S, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_32F, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_32F, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_64F, CV_64F)),
- OCL_ALL_CHANNELS, testing::Values(0, 1), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ReduceAvg, Combine(testing::Values(std::make_pair<MatDepth, MatDepth>(CV_8U, CV_32S),
- std::make_pair<MatDepth, MatDepth>(CV_8U, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_8U, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_16U, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_16U, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_16S, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_16S, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_32F, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_32F, CV_64F),
- std::make_pair<MatDepth, MatDepth>(CV_64F, CV_64F)),
- OCL_ALL_CHANNELS, testing::Values(0, 1), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ReduceMax, Combine(testing::Values(std::make_pair<MatDepth, MatDepth>(CV_8U, CV_8U),
- std::make_pair<MatDepth, MatDepth>(CV_16U, CV_16U),
- std::make_pair<MatDepth, MatDepth>(CV_16S, CV_16S),
- std::make_pair<MatDepth, MatDepth>(CV_32F, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_64F, CV_64F)),
- OCL_ALL_CHANNELS, testing::Values(0, 1), Bool()));
- OCL_INSTANTIATE_TEST_CASE_P(Arithm, ReduceMin, Combine(testing::Values(std::make_pair<MatDepth, MatDepth>(CV_8U, CV_8U),
- std::make_pair<MatDepth, MatDepth>(CV_16U, CV_16U),
- std::make_pair<MatDepth, MatDepth>(CV_16S, CV_16S),
- std::make_pair<MatDepth, MatDepth>(CV_32F, CV_32F),
- std::make_pair<MatDepth, MatDepth>(CV_64F, CV_64F)),
- OCL_ALL_CHANNELS, testing::Values(0, 1), Bool()));
- // T-API BUG (haveOpenCL() is false): modules/core/src/matrix.cpp:212: error: (-215) u->refcount == 0 in function deallocate
- OCL_TEST(Normalize, DISABLED_regression_5876_inplace_change_type)
- {
- double initial_values[] = {1, 2, 5, 4, 3};
- float result_values[] = {0, 0.25, 1, 0.75, 0.5};
- Mat m(Size(5, 1), CV_64FC1, initial_values);
- Mat result(Size(5, 1), CV_32FC1, result_values);
- UMat um; m.copyTo(um);
- UMat uresult; result.copyTo(uresult);
- OCL_ON(normalize(um, um, 1, 0, NORM_MINMAX, CV_32F));
- EXPECT_EQ(0, cvtest::norm(um, uresult, NORM_INF));
- }
- } } // namespace opencv_test::ocl
- #endif // HAVE_OPENCL
|