Change deprecated function ippicviMulC_32f_C1IR to ippicviMulC_32f_C1R. Check results of ipp function, if error was return run opencv branch of code
This commit is contained in:
@@ -210,73 +210,73 @@ static bool IPPDerivScharr(const Mat& src, Mat& dst, int ddepth, int dx, int dy,
|
|||||||
{
|
{
|
||||||
case CV_16S:
|
case CV_16S:
|
||||||
{
|
{
|
||||||
if((dx == 1) && (dy == 0))
|
if ((dx == 1) && (dy == 0))
|
||||||
{
|
{
|
||||||
ippicviFilterScharrVertGetBufferSize_8u16s_C1R(roi,&bufSize);
|
if (ippStsNoErr != ippicviFilterScharrVertGetBufferSize_8u16s_C1R(roi,&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
return (ippStsNoErr == ippicviFilterScharrVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
||||||
ippicviFilterScharrVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
(Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
||||||
(Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
if ((dx == 0) && (dy == 1))
|
||||||
if((dx == 0) && (dy == 1))
|
|
||||||
{
|
{
|
||||||
ippicviFilterScharrHorizGetBufferSize_8u16s_C1R(roi,&bufSize);
|
if (ippStsNoErr != ippicviFilterScharrHorizGetBufferSize_8u16s_C1R(roi,&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
return (ippStsNoErr == ippicviFilterScharrHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
||||||
ippicviFilterScharrHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
(Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
||||||
(Ipp16s*)dst.data, (int)dst.step, roi, ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
case CV_32F:
|
case CV_32F:
|
||||||
{
|
{
|
||||||
switch(dst.type())
|
switch(dst.type())
|
||||||
{
|
{
|
||||||
case CV_32F:
|
case CV_32F:
|
||||||
if((dx == 1) && (dy == 0))
|
|
||||||
{
|
{
|
||||||
ippicviFilterScharrVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows),&bufSize);
|
if ((dx == 1) && (dy == 0))
|
||||||
|
{
|
||||||
|
if (ippStsNoErr != ippicviFilterScharrVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows),&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
ippicviFilterScharrVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (ippStsNoErr != ippicviFilterScharrVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows),
|
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
if(scale != 1)
|
{
|
||||||
/* IPP is fast, so MulC produce very little perf degradation */
|
return false;
|
||||||
ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f*)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if((dx == 0) && (dy == 1))
|
if (scale != 1)
|
||||||
|
/* IPP is fast, so MulC produce very little perf degradation.*/
|
||||||
|
//ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f*)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
|
ippicviMulC_32f_C1R((Ipp32f*)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f*)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if ((dx == 0) && (dy == 1))
|
||||||
{
|
{
|
||||||
ippicviFilterScharrHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows),&bufSize);
|
if (ippStsNoErr != ippicviFilterScharrHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows),&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
ippicviFilterScharrHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
if (ippStsNoErr != ippicviFilterScharrHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows),
|
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
if(scale != 1)
|
return false;
|
||||||
ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
|
||||||
|
|
||||||
|
if (scale != 1)
|
||||||
|
ippicviMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -287,117 +287,126 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k
|
|||||||
{
|
{
|
||||||
int bufSize = 0;
|
int bufSize = 0;
|
||||||
cv::AutoBuffer<char> buffer;
|
cv::AutoBuffer<char> buffer;
|
||||||
|
if (ksize == 3 || ksize == 5)
|
||||||
if(ksize == 3 || ksize == 5)
|
|
||||||
{
|
{
|
||||||
if( ddepth < 0 )
|
if ( ddepth < 0 )
|
||||||
ddepth = src.depth();
|
ddepth = src.depth();
|
||||||
|
|
||||||
if(src.type() == CV_8U && dst.type() == CV_16S && scale == 1)
|
if (src.type() == CV_8U && dst.type() == CV_16S && scale == 1)
|
||||||
{
|
{
|
||||||
if((dx == 1) && (dy == 0))
|
if ((dx == 1) && (dy == 0))
|
||||||
{
|
{
|
||||||
ippicviFilterSobelNegVertGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
if (ippStsNoErr != ippicviFilterSobelNegVertGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
ippicviFilterSobelNegVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
return (ippStsNoErr == ippicviFilterSobelNegVertBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((dx == 0) && (dy == 1))
|
||||||
|
{
|
||||||
|
if (ippStsNoErr != ippicviFilterSobelHorizGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
|
return (ippStsNoErr == ippicviFilterSobelHorizBorder_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));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((dx == 2) && (dy == 0))
|
||||||
|
{
|
||||||
|
if (ippStsNoErr != ippicviFilterSobelVertSecondGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
|
return (ippStsNoErr == ippicviFilterSobelVertSecondBorder_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));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((dx == 0) && (dy == 2))
|
||||||
|
{
|
||||||
|
if (ippStsNoErr != ippicviFilterSobelHorizSecondGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
|
return (ippStsNoErr == ippicviFilterSobelHorizSecondBorder_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));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (src.type() == CV_32F && dst.type() == CV_32F)
|
||||||
|
{
|
||||||
|
if ((dx == 1) && (dy == 0))
|
||||||
|
{
|
||||||
|
if (ippStsNoErr != ippicviFilterSobelNegVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), &bufSize))
|
||||||
|
return false;
|
||||||
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
|
if (ippStsNoErr != ippicviFilterSobelNegVertBorder_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))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if(scale != 1)
|
||||||
|
ippicviMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((dx == 0) && (dy == 1))
|
if ((dx == 0) && (dy == 1))
|
||||||
{
|
{
|
||||||
ippicviFilterSobelHorizGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
if (ippStsNoErr != ippicviFilterSobelHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
ippicviFilterSobelHorizBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (ippStsNoErr != ippicviFilterSobelHorizBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if(scale != 1)
|
||||||
|
ippicviMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((dx == 2) && (dy == 0))
|
if((dx == 2) && (dy == 0))
|
||||||
{
|
{
|
||||||
ippicviFilterSobelVertSecondGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
if (ippStsNoErr != ippicviFilterSobelVertSecondGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
ippicviFilterSobelVertSecondBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (ippStsNoErr != ippicviFilterSobelVertSecondBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
||||||
(Ipp16s*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if(scale != 1)
|
||||||
|
ippicviMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((dx == 0) && (dy == 2))
|
if((dx == 0) && (dy == 2))
|
||||||
{
|
{
|
||||||
ippicviFilterSobelHorizSecondGetBufferSize_8u16s_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
if (ippStsNoErr != ippicviFilterSobelHorizSecondGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize))
|
||||||
|
return false;
|
||||||
buffer.allocate(bufSize);
|
buffer.allocate(bufSize);
|
||||||
|
|
||||||
ippicviFilterSobelHorizSecondBorder_8u16s_C1R((const Ipp8u*)src.data, (int)src.step,
|
if (ippStsNoErr != ippicviFilterSobelHorizSecondBorder_32f_C1R((const Ipp32f*)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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(src.type() == CV_32F && dst.type() == CV_32F)
|
|
||||||
{
|
|
||||||
if((dx == 1) && (dy == 0))
|
|
||||||
{
|
|
||||||
ippicviFilterSobelNegVertGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize), &bufSize);
|
|
||||||
buffer.allocate(bufSize);
|
|
||||||
|
|
||||||
ippicviFilterSobelNegVertBorder_32f_C1R((const Ipp32f*)src.data, (int)src.step,
|
|
||||||
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
(Ipp32f*)dst.data, (int)dst.step, ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),
|
||||||
ippBorderRepl, 0, (Ipp8u*)(char*)buffer);
|
ippBorderRepl, 0, (Ipp8u*)(char*)buffer))
|
||||||
if(scale != 1)
|
{
|
||||||
ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
return false;
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if((dx == 0) && (dy == 1))
|
|
||||||
{
|
|
||||||
ippicviFilterSobelHorizGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
|
||||||
buffer.allocate(bufSize);
|
|
||||||
|
|
||||||
ippicviFilterSobelHorizBorder_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)
|
if(scale != 1)
|
||||||
ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
ippicviMulC_32f_C1R((Ipp32f *)dst.data, (int)dst.step, (Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if((dx == 2) && (dy == 0))
|
|
||||||
{
|
|
||||||
ippicviFilterSobelVertSecondGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
|
||||||
buffer.allocate(bufSize);
|
|
||||||
|
|
||||||
ippicviFilterSobelVertSecondBorder_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)
|
|
||||||
ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if((dx == 0) && (dy == 2))
|
|
||||||
{
|
|
||||||
ippicviFilterSobelHorizSecondGetBufferSize_32f_C1R(ippiSize(src.cols, src.rows), (IppiMaskSize)(ksize*10+ksize),&bufSize);
|
|
||||||
buffer.allocate(bufSize);
|
|
||||||
|
|
||||||
ippicviFilterSobelHorizSecondBorder_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)
|
|
||||||
ippicviMulC_32f_C1IR((Ipp32f)scale, (Ipp32f *)dst.data, (int)dst.step, ippiSize(dst.cols*dst.channels(), dst.rows));
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -405,7 +414,6 @@ static bool IPPDeriv(const Mat& src, Mat& dst, int ddepth, int dx, int dy, int k
|
|||||||
|
|
||||||
if(ksize <= 0)
|
if(ksize <= 0)
|
||||||
return IPPDerivScharr(src, dst, ddepth, dx, dy, scale);
|
return IPPDerivScharr(src, dst, ddepth, dx, dy, scale);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -436,7 +444,7 @@ void cv::Sobel( InputArray _src, OutputArray _dst, int ddepth, int dx, int dy,
|
|||||||
if(dx < 3 && dy < 3 && cn == 1 && borderType == BORDER_REPLICATE)
|
if(dx < 3 && dy < 3 && cn == 1 && borderType == BORDER_REPLICATE)
|
||||||
{
|
{
|
||||||
Mat src = _src.getMat(), dst = _dst.getMat();
|
Mat src = _src.getMat(), dst = _dst.getMat();
|
||||||
if(IPPDeriv(src, dst, ddepth, dx, dy, ksize,scale))
|
if (IPPDeriv(src, dst, ddepth, dx, dy, ksize,scale))
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user