Merge remote-tracking branch 'upstream/2.4' into merge-2.4
* #1538 from StevenPuttemans:bugfix_3283 * #1545 from alalek:ocl_test_fix_rng * #1551 from alalek:cmake_install_win * #1570 from ilya-lavrenov:ipp_warn_fix * #1573 from alalek:perf_simple_strategy * #1574 from alalek:svm_workaround * #1576 from alalek:ocl_fix_cl_double * #1577 from ilya-lavrenov:ocl_setto_opencl12 * #1578 from asmorkalov:android_fd_cp_fix * #1579 from ilya-lavrenov:ocl_norm * #1582 from sperrholz:ocl-arithm-additions * #1586 from ilya-lavrenov:ocl_setto_win_fix * #1589 from ilya-lavrenov:pr1582_fix * #1591 from alalek:ocl_remove_cl_hpp_h * #1592 from alalek:ocl_program_cache_update * #1593 from ilya-lavrenov:ocl_war_on_double * #1594 from ilya-lavrenov:ocl_perf * #1595 from alalek:cl_code_cleanup * #1596 from alalek:test_fix_run_py * #1597 from alalek:ocl_fix_cleanup * #1598 from alalek:ocl_fix_build_mac * #1599 from ilya-lavrenov:ocl_mac_kernel_warnings * #1601 from ilya-lavrenov:ocl_fix_tvl1_and_sparse * #1602 from alalek:ocl_test_dump_info * #1603 from ilya-lavrenov:ocl_disable_svm_noblas * #1605 from alalek:ocl_fixes * #1606 from ilya-lavrenov:ocl_imgproc * #1607 from ilya-lavrenov:ocl_fft_cleanup * #1608 from alalek:fix_warn_upd_haar * #1609 from ilya-lavrenov:ocl_some_optimization * #1610 from alalek:ocl_fix_perf_kalman * #1612 from alalek:ocl_fix_string_info * #1614 from ilya-lavrenov:ocl_svm_misprint * #1616 from ilya-lavrenov:ocl_cvtColor * #1617 from ilya-lavrenov:ocl_info * #1622 from a0byte:2.4 * #1625 from ilya-lavrenov:to_string Conflicts: cmake/OpenCVConfig.cmake cmake/OpenCVDetectPython.cmake cmake/OpenCVGenConfig.cmake modules/core/CMakeLists.txt modules/nonfree/src/surf.ocl.cpp modules/ocl/include/opencv2/ocl/ocl.hpp modules/ocl/include/opencv2/ocl/private/util.hpp modules/ocl/perf/main.cpp modules/ocl/src/arithm.cpp modules/ocl/src/cl_operations.cpp modules/ocl/src/cl_programcache.cpp modules/ocl/src/color.cpp modules/ocl/src/fft.cpp modules/ocl/src/filtering.cpp modules/ocl/src/gemm.cpp modules/ocl/src/haar.cpp modules/ocl/src/imgproc.cpp modules/ocl/src/matrix_operations.cpp modules/ocl/src/pyrlk.cpp modules/ocl/src/split_merge.cpp modules/ocl/src/svm.cpp modules/ocl/test/main.cpp modules/ocl/test/test_fft.cpp modules/ocl/test/test_moments.cpp modules/ocl/test/test_objdetect.cpp modules/ocl/test/test_optflow.cpp modules/ocl/test/utility.hpp modules/python/CMakeLists.txt modules/ts/include/opencv2/ts.hpp modules/ts/src/ts_perf.cpp samples/android/face-detection/jni/DetectionBasedTracker_jni.cpp
This commit is contained in:
		| @@ -293,8 +293,6 @@ Calculates the up-right bounding rectangle of a point set. | ||||
| The function calculates and returns the minimal up-right bounding rectangle for the specified point set. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| contourArea | ||||
| --------------- | ||||
| Calculates a contour area. | ||||
| @@ -417,6 +415,7 @@ Fits an ellipse around a set of 2D points. | ||||
|         * Nx2 numpy array (Python interface) | ||||
|  | ||||
| The function calculates the ellipse that fits (in a least-squares sense) a set of 2D points best of all. It returns the rotated rectangle in which the ellipse is inscribed. The algorithm [Fitzgibbon95]_ is used. | ||||
| Developer should keep in mind that it is possible that the returned ellipse/rotatedRect data contains negative indices, due to the data points being close to the border of the containing Mat element. | ||||
|  | ||||
| .. note:: | ||||
|  | ||||
| @@ -539,7 +538,7 @@ Finds a rotated rectangle of the minimum area enclosing the input 2D point set. | ||||
|         * Nx2 numpy array (Python interface) | ||||
|  | ||||
| The function calculates and returns the minimum-area bounding rectangle (possibly rotated) for a specified point set. See the OpenCV sample ``minarea.cpp`` . | ||||
|  | ||||
| Developer should keep in mind that the returned rotatedRect can contain negative indices when data is close the the containing Mat element boundary. | ||||
|  | ||||
|  | ||||
| boxPoints | ||||
|   | ||||
| @@ -115,7 +115,7 @@ void cv::Canny( InputArray _src, OutputArray _dst, | ||||
|  | ||||
| #ifdef USE_IPP_CANNY | ||||
|     if( aperture_size == 3 && !L2gradient && | ||||
|         ippCanny(src, dst, low_thresh, high_thresh) >= 0 ) | ||||
|         ippCanny(src, dst, (float)low_thresh, (float)high_thresh) ) | ||||
|         return; | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -218,7 +218,7 @@ public: | ||||
|     { | ||||
|         const void *yS = src.ptr<uchar>(range.start); | ||||
|         void *yD = dst.ptr<uchar>(range.start); | ||||
|         if( cvt(yS, (int)src.step[0], yD, (int)dst.step[0], src.cols, range.end - range.start) < 0 ) | ||||
|         if( !cvt(yS, (int)src.step[0], yD, (int)dst.step[0], src.cols, range.end - range.start) ) | ||||
|             *ok = false; | ||||
|     } | ||||
|  | ||||
| @@ -730,7 +730,7 @@ template<> struct RGB2Gray<uchar> | ||||
| { | ||||
|     typedef uchar channel_type; | ||||
|  | ||||
|     RGB2Gray<uchar>(int _srccn, int blueIdx, const int* coeffs) : srccn(_srccn) | ||||
|     RGB2Gray(int _srccn, int blueIdx, const int* coeffs) : srccn(_srccn) | ||||
|     { | ||||
|         const int coeffs0[] = { R2Y, G2Y, B2Y }; | ||||
|         if(!coeffs) coeffs = coeffs0; | ||||
| @@ -761,7 +761,7 @@ template<> struct RGB2Gray<ushort> | ||||
| { | ||||
|     typedef ushort channel_type; | ||||
|  | ||||
|     RGB2Gray<ushort>(int _srccn, int blueIdx, const int* _coeffs) : srccn(_srccn) | ||||
|     RGB2Gray(int _srccn, int blueIdx, const int* _coeffs) : srccn(_srccn) | ||||
|     { | ||||
|         static const int coeffs0[] = { R2Y, G2Y, B2Y }; | ||||
|         memcpy(coeffs, _coeffs ? _coeffs : coeffs0, 3*sizeof(coeffs[0])); | ||||
|   | ||||
| @@ -212,8 +212,8 @@ static bool IPPDerivScharr(const Mat& src, Mat& dst, int ddepth, int dx, int dy, | ||||
|                      ippiFilterScharrVertGetBufferSize_8u16s_C1R(roi,&bufSize); | ||||
|                      buffer.allocate(bufSize); | ||||
|  | ||||
|                      ippiFilterScharrVertBorder_8u16s_C1R((const Ipp8u*)src.data, src.step, | ||||
|                         (Ipp16s*)dst.data, dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|                      ippiFilterScharrVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step, | ||||
|                         (Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|  | ||||
|                      return true; | ||||
|                   } | ||||
| @@ -223,8 +223,8 @@ static bool IPPDerivScharr(const Mat& src, Mat& dst, int ddepth, int dx, int dy, | ||||
|                      ippiFilterScharrHorizGetBufferSize_8u16s_C1R(roi,&bufSize); | ||||
|                      buffer.allocate(bufSize); | ||||
|  | ||||
|                      ippiFilterScharrHorizBorder_8u16s_C1R((const Ipp8u*)src.data, src.step, | ||||
|                         (Ipp16s*)dst.data, dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|                      ippiFilterScharrHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step, | ||||
|                         (Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|  | ||||
|                      return true; | ||||
|                   } | ||||
| @@ -245,12 +245,12 @@ static bool IPPDerivScharr(const Mat& src, Mat& dst, int ddepth, int dx, int dy, | ||||
|                   ippiFilterScharrVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows),&bufSize); | ||||
|                   buffer.allocate(bufSize); | ||||
|  | ||||
|                   ippiFilterScharrVertBorder_32f_C1R((const Ipp32f*)src.data, src.step, | ||||
|                      (Ipp32f*)dst.data, dst.step, ippiSize(src.cols, src.rows), | ||||
|                   ippiFilterScharrVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step, | ||||
|                      (Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), | ||||
|                                             ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|                   if(scale != 1) | ||||
|                      /* IPP is fast, so MulC produce very little perf degradation */ | ||||
|                      ippiMulC_32f_C1IR((Ipp32f)scale,(Ipp32f*)dst.data,dst.step,ippiSize(dst.cols*dst.channels(),dst.rows)); | ||||
|                      ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f*)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows)); | ||||
|  | ||||
|                   return true; | ||||
|                } | ||||
| @@ -260,11 +260,11 @@ static bool IPPDerivScharr(const Mat& src, Mat& dst, int ddepth, int dx, int dy, | ||||
|                   ippiFilterScharrHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows),&bufSize); | ||||
|                   buffer.allocate(bufSize); | ||||
|  | ||||
|                   ippiFilterScharrHorizBorder_32f_C1R((const Ipp32f*)src.data, src.step, | ||||
|                      (Ipp32f*)dst.data, dst.step, ippiSize(src.cols, src.rows), | ||||
|                   ippiFilterScharrHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step, | ||||
|                      (Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), | ||||
|                                             ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|                   if(scale != 1) | ||||
|                      ippiMulC_32f_C1IR((Ipp32f)scale,(Ipp32f *)dst.data,dst.step,ippiSize(dst.cols*dst.channels(),dst.rows)); | ||||
|                      ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows)); | ||||
|  | ||||
|                   return true; | ||||
|                } | ||||
| @@ -297,8 +297,8 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelNegVertGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelNegVertBorder_8u16s_C1R((const Ipp8u*)src.data, src.step, | ||||
|                (Ipp16s*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelNegVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step, | ||||
|                (Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|             return true; | ||||
|          } | ||||
| @@ -308,8 +308,8 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelHorizGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelHorizBorder_8u16s_C1R((const Ipp8u*)src.data, src.step, | ||||
|                (Ipp16s*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step, | ||||
|                (Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|  | ||||
|             return true; | ||||
| @@ -320,8 +320,8 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelVertSecondGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelVertSecondBorder_8u16s_C1R((const Ipp8u*)src.data, src.step, | ||||
|                (Ipp16s*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelVertSecondBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step, | ||||
|                (Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|  | ||||
|             return true; | ||||
| @@ -332,8 +332,8 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelHorizSecondGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelHorizSecondBorder_8u16s_C1R((const Ipp8u*)src.data, src.step, | ||||
|                (Ipp16s*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelHorizSecondBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step, | ||||
|                (Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|  | ||||
|             return true; | ||||
| @@ -344,14 +344,14 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|       { | ||||
|          if((dx == 1) && (dy == 0)) | ||||
|          { | ||||
|             ippiFilterSobelNegVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             ippiFilterSobelNegVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), &bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelNegVertBorder_32f_C1R((const Ipp32f*)src.data, src.step, | ||||
|                (Ipp32f*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelNegVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step, | ||||
|                (Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|             if(scale != 1) | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale,(Ipp32f *)dst.data,dst.step,ippiSize(dst.cols*dst.channels(),dst.rows)); | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows)); | ||||
|  | ||||
|             return true; | ||||
|          } | ||||
| @@ -361,11 +361,11 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelHorizBorder_32f_C1R((const Ipp32f*)src.data, src.step, | ||||
|                (Ipp32f*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step, | ||||
|                (Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|             if(scale != 1) | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale,(Ipp32f *)dst.data,dst.step,ippiSize(dst.cols*dst.channels(),dst.rows)); | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows)); | ||||
|  | ||||
|             return true; | ||||
|          } | ||||
| @@ -375,11 +375,11 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelVertSecondGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelVertSecondBorder_32f_C1R((const Ipp32f*)src.data, src.step, | ||||
|                (Ipp32f*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelVertSecondBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step, | ||||
|                (Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|             if(scale != 1) | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale,(Ipp32f *)dst.data,dst.step,ippiSize(dst.cols*dst.channels(),dst.rows)); | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows)); | ||||
|  | ||||
|             return true; | ||||
|          } | ||||
| @@ -389,11 +389,11 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k | ||||
|             ippiFilterSobelHorizSecondGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize); | ||||
|             buffer.allocate(bufSize); | ||||
|  | ||||
|             ippiFilterSobelHorizSecondBorder_32f_C1R((const Ipp32f*)src.data, src.step, | ||||
|                (Ipp32f*)dst.data, dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|             ippiFilterSobelHorizSecondBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step, | ||||
|                (Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), | ||||
|                                       ippBorderRepl, 0, (Ipp8u*)(char*)buffer); | ||||
|             if(scale != 1) | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale,(Ipp32f *)dst.data,dst.step,ippiSize(dst.cols*dst.channels(),dst.rows)); | ||||
|                ippiMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows)); | ||||
|  | ||||
|             return true; | ||||
|          } | ||||
|   | ||||
| @@ -252,11 +252,11 @@ void cv::integral( InputArray _src, OutputArray _sum, OutputArray _sqsum, Output | ||||
|                 { | ||||
|                     _sqsum.create( isize, CV_MAKETYPE( CV_64F, cn ) ); | ||||
|                     sqsum = _sqsum.getMat(); | ||||
|                     ippiSqrIntegral_8u32f64f_C1R( (const Ipp8u*)src.data, src.step, (Ipp32f*)sum.data, sum.step, (Ipp64f*)sqsum.data, sqsum.step, srcRoiSize, 0, 0 ); | ||||
|                     ippiSqrIntegral_8u32f64f_C1R( (const Ipp8u*)src.data, (int)src.step, (Ipp32f*)sum.data, (int)sum.step, (Ipp64f*)sqsum.data, (int)sqsum.step, srcRoiSize, 0, 0 ); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     ippiIntegral_8u32f_C1R( (const Ipp8u*)src.data, src.step, (Ipp32f*)sum.data, sum.step, srcRoiSize, 0 ); | ||||
|                     ippiIntegral_8u32f_C1R( (const Ipp8u*)src.data, (int)src.step, (Ipp32f*)sum.data, (int)sum.step, srcRoiSize, 0 ); | ||||
|                 } | ||||
|                 return; | ||||
|             } | ||||
| @@ -272,11 +272,11 @@ void cv::integral( InputArray _src, OutputArray _sum, OutputArray _sqsum, Output | ||||
|                 { | ||||
|                     _sqsum.create( isize, CV_MAKETYPE( CV_64F, cn ) ); | ||||
|                     sqsum = _sqsum.getMat(); | ||||
|                     ippiSqrIntegral_8u32s64f_C1R( (const Ipp8u*)src.data, src.step, (Ipp32s*)sum.data, sum.step, (Ipp64f*)sqsum.data, sqsum.step, srcRoiSize, 0, 0 ); | ||||
|                     ippiSqrIntegral_8u32s64f_C1R( (const Ipp8u*)src.data, (int)src.step, (Ipp32s*)sum.data, (int)sum.step, (Ipp64f*)sqsum.data, (int)sqsum.step, srcRoiSize, 0, 0 ); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     ippiIntegral_8u32s_C1R( (const Ipp8u*)src.data, src.step, (Ipp32s*)sum.data, sum.step, srcRoiSize, 0 ); | ||||
|                     ippiIntegral_8u32s_C1R( (const Ipp8u*)src.data, (int)src.step, (Ipp32s*)sum.data, (int)sum.step, srcRoiSize, 0 ); | ||||
|                 } | ||||
|                 return; | ||||
|             } | ||||
|   | ||||
| @@ -1445,14 +1445,14 @@ void CV_FitLineTest::generate_point_set( void* pointsSet ) | ||||
|         t = (float)((cvtest::randReal(rng)-0.5)*low_high_range*2); | ||||
|  | ||||
|         for( k = 0; k < n; k++ ) | ||||
|         { | ||||
|             p[k] = (float)((cvtest::randReal(rng)-0.5)*max_noise*2 + t*line0[k] + line0[k+n]); | ||||
|  | ||||
|         if( point_type == CV_32S ) | ||||
|             for( k = 0; k < n; k++ ) | ||||
|             if( point_type == CV_32S ) | ||||
|                 pi[k] = cvRound(p[k]); | ||||
|         else | ||||
|             for( k = 0; k < n; k++ ) | ||||
|             else | ||||
|                 pf[k] = p[k]; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Alexander Alekhin
					Alexander Alekhin