Optimized version of ReduceR functions and one ReduceC function added
Attention! Optimized ReduceC function produced the bug
This commit is contained in:
parent
1767049f30
commit
893f75444d
@ -1977,7 +1977,11 @@ void cv::reduce(InputArray _src, OutputArray _dst, int dim, int op, int dtype)
|
|||||||
if( op == CV_REDUCE_SUM )
|
if( op == CV_REDUCE_SUM )
|
||||||
{
|
{
|
||||||
if(sdepth == CV_8U && ddepth == CV_32S)
|
if(sdepth == CV_8U && ddepth == CV_32S)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceR8uAdd(tegra::reduceR8uAdd);
|
||||||
|
#else
|
||||||
func = reduceR_<uchar,int,OpAdd<int> >;
|
func = reduceR_<uchar,int,OpAdd<int> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_8U && ddepth == CV_32F)
|
else if(sdepth == CV_8U && ddepth == CV_32F)
|
||||||
func = reduceR_<uchar,float,OpAdd<int> >;
|
func = reduceR_<uchar,float,OpAdd<int> >;
|
||||||
else if(sdepth == CV_8U && ddepth == CV_64F)
|
else if(sdepth == CV_8U && ddepth == CV_64F)
|
||||||
@ -1991,7 +1995,11 @@ void cv::reduce(InputArray _src, OutputArray _dst, int dim, int op, int dtype)
|
|||||||
else if(sdepth == CV_16S && ddepth == CV_64F)
|
else if(sdepth == CV_16S && ddepth == CV_64F)
|
||||||
func = reduceR_<short,double,OpAdd<double> >;
|
func = reduceR_<short,double,OpAdd<double> >;
|
||||||
else if(sdepth == CV_32F && ddepth == CV_32F)
|
else if(sdepth == CV_32F && ddepth == CV_32F)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceR32fAdd(tegra::reduceR32fAdd);
|
||||||
|
#else
|
||||||
func = reduceR_<float,float,OpAdd<float> >;
|
func = reduceR_<float,float,OpAdd<float> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_32F && ddepth == CV_64F)
|
else if(sdepth == CV_32F && ddepth == CV_64F)
|
||||||
func = reduceR_<float,double,OpAdd<double> >;
|
func = reduceR_<float,double,OpAdd<double> >;
|
||||||
else if(sdepth == CV_64F && ddepth == CV_64F)
|
else if(sdepth == CV_64F && ddepth == CV_64F)
|
||||||
@ -2000,26 +2008,42 @@ void cv::reduce(InputArray _src, OutputArray _dst, int dim, int op, int dtype)
|
|||||||
else if(op == CV_REDUCE_MAX)
|
else if(op == CV_REDUCE_MAX)
|
||||||
{
|
{
|
||||||
if(sdepth == CV_8U && ddepth == CV_8U)
|
if(sdepth == CV_8U && ddepth == CV_8U)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceR8uMax(tegra::reduceR8uMax);
|
||||||
|
#else
|
||||||
func = reduceR_<uchar, uchar, OpMax<uchar> >;
|
func = reduceR_<uchar, uchar, OpMax<uchar> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_16U && ddepth == CV_16U)
|
else if(sdepth == CV_16U && ddepth == CV_16U)
|
||||||
func = reduceR_<ushort, ushort, OpMax<ushort> >;
|
func = reduceR_<ushort, ushort, OpMax<ushort> >;
|
||||||
else if(sdepth == CV_16S && ddepth == CV_16S)
|
else if(sdepth == CV_16S && ddepth == CV_16S)
|
||||||
func = reduceR_<short, short, OpMax<short> >;
|
func = reduceR_<short, short, OpMax<short> >;
|
||||||
else if(sdepth == CV_32F && ddepth == CV_32F)
|
else if(sdepth == CV_32F && ddepth == CV_32F)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceR32fMax(tegra::reduceR32fMax);
|
||||||
|
#else
|
||||||
func = reduceR_<float, float, OpMax<float> >;
|
func = reduceR_<float, float, OpMax<float> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_64F && ddepth == CV_64F)
|
else if(sdepth == CV_64F && ddepth == CV_64F)
|
||||||
func = reduceR_<double, double, OpMax<double> >;
|
func = reduceR_<double, double, OpMax<double> >;
|
||||||
}
|
}
|
||||||
else if(op == CV_REDUCE_MIN)
|
else if(op == CV_REDUCE_MIN)
|
||||||
{
|
{
|
||||||
if(sdepth == CV_8U && ddepth == CV_8U)
|
if(sdepth == CV_8U && ddepth == CV_8U)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceR8uMin(tegra::reduceR8uMin);
|
||||||
|
#else
|
||||||
func = reduceR_<uchar, uchar, OpMin<uchar> >;
|
func = reduceR_<uchar, uchar, OpMin<uchar> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_16U && ddepth == CV_16U)
|
else if(sdepth == CV_16U && ddepth == CV_16U)
|
||||||
func = reduceR_<ushort, ushort, OpMin<ushort> >;
|
func = reduceR_<ushort, ushort, OpMin<ushort> >;
|
||||||
else if(sdepth == CV_16S && ddepth == CV_16S)
|
else if(sdepth == CV_16S && ddepth == CV_16S)
|
||||||
func = reduceR_<short, short, OpMin<short> >;
|
func = reduceR_<short, short, OpMin<short> >;
|
||||||
else if(sdepth == CV_32F && ddepth == CV_32F)
|
else if(sdepth == CV_32F && ddepth == CV_32F)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceR32fMin(tegra::reduceR32fMin);
|
||||||
|
#else
|
||||||
func = reduceR_<float, float, OpMin<float> >;
|
func = reduceR_<float, float, OpMin<float> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_64F && ddepth == CV_64F)
|
else if(sdepth == CV_64F && ddepth == CV_64F)
|
||||||
func = reduceR_<double, double, OpMin<double> >;
|
func = reduceR_<double, double, OpMin<double> >;
|
||||||
}
|
}
|
||||||
@ -2029,7 +2053,11 @@ void cv::reduce(InputArray _src, OutputArray _dst, int dim, int op, int dtype)
|
|||||||
if(op == CV_REDUCE_SUM)
|
if(op == CV_REDUCE_SUM)
|
||||||
{
|
{
|
||||||
if(sdepth == CV_8U && ddepth == CV_32S)
|
if(sdepth == CV_8U && ddepth == CV_32S)
|
||||||
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
|
func = tegra::getTegraOptimized_reduceC8uAdd(tegra::reduceC8uAdd);
|
||||||
|
#else
|
||||||
func = reduceC_<uchar,int,OpAdd<int> >;
|
func = reduceC_<uchar,int,OpAdd<int> >;
|
||||||
|
#endif
|
||||||
else if(sdepth == CV_8U && ddepth == CV_32F)
|
else if(sdepth == CV_8U && ddepth == CV_32F)
|
||||||
func = reduceC_<uchar,float,OpAdd<int> >;
|
func = reduceC_<uchar,float,OpAdd<int> >;
|
||||||
else if(sdepth == CV_8U && ddepth == CV_64F)
|
else if(sdepth == CV_8U && ddepth == CV_64F)
|
||||||
@ -2085,7 +2113,7 @@ void cv::reduce(InputArray _src, OutputArray _dst, int dim, int op, int dtype)
|
|||||||
|
|
||||||
if( op0 == CV_REDUCE_AVG )
|
if( op0 == CV_REDUCE_AVG )
|
||||||
temp.convertTo(dst, dst.type(), 1./(dim == 0 ? src.rows : src.cols));
|
temp.convertTo(dst, dst.type(), 1./(dim == 0 ? src.rows : src.cols));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////// sort ///////////////////////////////////////////
|
//////////////////////////////////////// sort ///////////////////////////////////////////
|
||||||
|
Loading…
x
Reference in New Issue
Block a user