From 271f60ba7abd1f2c478757b4b92fb97f58333ed9 Mon Sep 17 00:00:00 2001 From: Andrey Pavlenko Date: Thu, 3 Apr 2014 16:21:04 +0400 Subject: [PATCH] fixing OCL run condition (build program failure for comparison 64F Mat with Scalar) --- modules/core/src/arithm.cpp | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/modules/core/src/arithm.cpp b/modules/core/src/arithm.cpp index a27e34c13c..58442e559b 100644 --- a/modules/core/src/arithm.cpp +++ b/modules/core/src/arithm.cpp @@ -2621,12 +2621,11 @@ static bool ocl_compare(InputArray _src1, InputArray _src2, OutputArray _dst, in int type1 = _src1.type(), depth1 = CV_MAT_DEPTH(type1), cn = CV_MAT_CN(type1), type2 = _src2.type(), depth2 = CV_MAT_DEPTH(type2); - if (!haveScalar) - { - if ( (!doubleSupport && depth1 == CV_64F) || - !_src1.sameSize(_src2) || type1 != type2) + if (!doubleSupport && depth1 == CV_64F) + return false; + + if (!haveScalar && (!_src1.sameSize(_src2) || type1 != type2)) return false; - } int kercn = haveScalar ? cn : ocl::predictOptimalVectorWidth(_src1, _src2, _dst); // Workaround for bug with "?:" operator in AMD OpenCL compiler