|
|
|
@ -49,11 +49,11 @@ using namespace cv::cuda; |
|
|
|
|
|
|
|
|
|
void cv::cuda::calcHist(InputArray, OutputArray, Stream&) { throw_no_cuda(); } |
|
|
|
|
|
|
|
|
|
void cv::cuda::equalizeHist(InputArray, OutputArray, InputOutputArray, Stream&) { throw_no_cuda(); } |
|
|
|
|
void cv::cuda::equalizeHist(InputArray, OutputArray, Stream&) { throw_no_cuda(); } |
|
|
|
|
|
|
|
|
|
cv::Ptr<cv::cuda::CLAHE> cv::cuda::createCLAHE(double, cv::Size) { throw_no_cuda(); return cv::Ptr<cv::cuda::CLAHE>(); } |
|
|
|
|
|
|
|
|
|
void cv::cuda::evenLevels(OutputArray, int, int, int) { throw_no_cuda(); } |
|
|
|
|
void cv::cuda::evenLevels(OutputArray, int, int, int, Stream&) { throw_no_cuda(); } |
|
|
|
|
|
|
|
|
|
void cv::cuda::histEven(InputArray, OutputArray, InputOutputArray, int, int, int, Stream&) { throw_no_cuda(); } |
|
|
|
|
void cv::cuda::histEven(InputArray, GpuMat*, InputOutputArray, int*, int*, int*, Stream&) { throw_no_cuda(); } |
|
|
|
@ -93,7 +93,7 @@ namespace hist |
|
|
|
|
void equalizeHist(PtrStepSzb src, PtrStepSzb dst, const int* lut, cudaStream_t stream); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void cv::cuda::equalizeHist(InputArray _src, OutputArray _dst, InputOutputArray _buf, Stream& _stream) |
|
|
|
|
void cv::cuda::equalizeHist(InputArray _src, OutputArray _dst, Stream& _stream) |
|
|
|
|
{ |
|
|
|
|
GpuMat src = _src.getGpuMat(); |
|
|
|
|
|
|
|
|
@ -107,8 +107,8 @@ void cv::cuda::equalizeHist(InputArray _src, OutputArray _dst, InputOutputArray |
|
|
|
|
|
|
|
|
|
size_t bufSize = intBufSize + 2 * 256 * sizeof(int); |
|
|
|
|
|
|
|
|
|
ensureSizeIsEnough(1, static_cast<int>(bufSize), CV_8UC1, _buf); |
|
|
|
|
GpuMat buf = _buf.getGpuMat(); |
|
|
|
|
BufferPool pool(_stream); |
|
|
|
|
GpuMat buf = pool.getBuffer(1, static_cast<int>(bufSize), CV_8UC1); |
|
|
|
|
|
|
|
|
|
GpuMat hist(1, 256, CV_32SC1, buf.data); |
|
|
|
|
GpuMat lut(1, 256, CV_32SC1, buf.data + 256 * sizeof(int)); |
|
|
|
@ -288,7 +288,7 @@ namespace |
|
|
|
|
{ |
|
|
|
|
typedef typename NppHistogramEvenFuncC1<SDEPTH>::src_t src_t; |
|
|
|
|
|
|
|
|
|
static void hist(const GpuMat& src, OutputArray _hist, InputOutputArray _buf, int histSize, int lowerLevel, int upperLevel, cudaStream_t stream) |
|
|
|
|
static void hist(const GpuMat& src, OutputArray _hist, int histSize, int lowerLevel, int upperLevel, Stream& stream) |
|
|
|
|
{ |
|
|
|
|
const int levels = histSize + 1; |
|
|
|
|
|
|
|
|
@ -302,15 +302,15 @@ namespace |
|
|
|
|
int buf_size; |
|
|
|
|
get_buf_size(sz, levels, &buf_size); |
|
|
|
|
|
|
|
|
|
ensureSizeIsEnough(1, buf_size, CV_8UC1, _buf); |
|
|
|
|
GpuMat buf = _buf.getGpuMat(); |
|
|
|
|
BufferPool pool(stream); |
|
|
|
|
GpuMat buf = pool.getBuffer(1, buf_size, CV_8UC1); |
|
|
|
|
|
|
|
|
|
NppStreamHandler h(stream); |
|
|
|
|
|
|
|
|
|
nppSafeCall( func(src.ptr<src_t>(), static_cast<int>(src.step), sz, hist.ptr<Npp32s>(), levels, |
|
|
|
|
lowerLevel, upperLevel, buf.ptr<Npp8u>()) ); |
|
|
|
|
|
|
|
|
|
if (stream == 0) |
|
|
|
|
if (!stream) |
|
|
|
|
cudaSafeCall( cudaDeviceSynchronize() ); |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
@ -319,7 +319,7 @@ namespace |
|
|
|
|
{ |
|
|
|
|
typedef typename NppHistogramEvenFuncC4<SDEPTH>::src_t src_t; |
|
|
|
|
|
|
|
|
|
static void hist(const GpuMat& src, GpuMat hist[4],InputOutputArray _buf, int histSize[4], int lowerLevel[4], int upperLevel[4], cudaStream_t stream) |
|
|
|
|
static void hist(const GpuMat& src, GpuMat hist[4], int histSize[4], int lowerLevel[4], int upperLevel[4], Stream& stream) |
|
|
|
|
{ |
|
|
|
|
int levels[] = {histSize[0] + 1, histSize[1] + 1, histSize[2] + 1, histSize[3] + 1}; |
|
|
|
|
hist[0].create(1, histSize[0], CV_32S); |
|
|
|
@ -336,14 +336,14 @@ namespace |
|
|
|
|
int buf_size; |
|
|
|
|
get_buf_size(sz, levels, &buf_size); |
|
|
|
|
|
|
|
|
|
ensureSizeIsEnough(1, buf_size, CV_8U, _buf); |
|
|
|
|
GpuMat buf = _buf.getGpuMat(); |
|
|
|
|
BufferPool pool(stream); |
|
|
|
|
GpuMat buf = pool.getBuffer(1, buf_size, CV_8UC1); |
|
|
|
|
|
|
|
|
|
NppStreamHandler h(stream); |
|
|
|
|
|
|
|
|
|
nppSafeCall( func(src.ptr<src_t>(), static_cast<int>(src.step), sz, pHist, levels, lowerLevel, upperLevel, buf.ptr<Npp8u>()) ); |
|
|
|
|
|
|
|
|
|
if (stream == 0) |
|
|
|
|
if (!stream) |
|
|
|
|
cudaSafeCall( cudaDeviceSynchronize() ); |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
@ -392,7 +392,7 @@ namespace |
|
|
|
|
typedef typename NppHistogramRangeFuncC1<SDEPTH>::level_t level_t; |
|
|
|
|
enum {LEVEL_TYPE_CODE=NppHistogramRangeFuncC1<SDEPTH>::LEVEL_TYPE_CODE}; |
|
|
|
|
|
|
|
|
|
static void hist(const GpuMat& src, OutputArray _hist, const GpuMat& levels, InputOutputArray _buf, cudaStream_t stream) |
|
|
|
|
static void hist(const GpuMat& src, OutputArray _hist, const GpuMat& levels, Stream& stream) |
|
|
|
|
{ |
|
|
|
|
CV_Assert( levels.type() == LEVEL_TYPE_CODE && levels.rows == 1 ); |
|
|
|
|
|
|
|
|
@ -406,8 +406,8 @@ namespace |
|
|
|
|
int buf_size; |
|
|
|
|
get_buf_size(sz, levels.cols, &buf_size); |
|
|
|
|
|
|
|
|
|
ensureSizeIsEnough(1, buf_size, CV_8U, _buf); |
|
|
|
|
GpuMat buf = _buf.getGpuMat(); |
|
|
|
|
BufferPool pool(stream); |
|
|
|
|
GpuMat buf = pool.getBuffer(1, buf_size, CV_8UC1); |
|
|
|
|
|
|
|
|
|
NppStreamHandler h(stream); |
|
|
|
|
|
|
|
|
@ -424,7 +424,7 @@ namespace |
|
|
|
|
typedef typename NppHistogramRangeFuncC1<SDEPTH>::level_t level_t; |
|
|
|
|
enum {LEVEL_TYPE_CODE=NppHistogramRangeFuncC1<SDEPTH>::LEVEL_TYPE_CODE}; |
|
|
|
|
|
|
|
|
|
static void hist(const GpuMat& src, GpuMat hist[4], const GpuMat levels[4],InputOutputArray _buf, cudaStream_t stream) |
|
|
|
|
static void hist(const GpuMat& src, GpuMat hist[4], const GpuMat levels[4], Stream& stream) |
|
|
|
|
{ |
|
|
|
|
CV_Assert( levels[0].type() == LEVEL_TYPE_CODE && levels[0].rows == 1 ); |
|
|
|
|
CV_Assert( levels[1].type() == LEVEL_TYPE_CODE && levels[1].rows == 1 ); |
|
|
|
@ -447,8 +447,8 @@ namespace |
|
|
|
|
int buf_size; |
|
|
|
|
get_buf_size(sz, nLevels, &buf_size); |
|
|
|
|
|
|
|
|
|
ensureSizeIsEnough(1, buf_size, CV_8U, _buf); |
|
|
|
|
GpuMat buf = _buf.getGpuMat(); |
|
|
|
|
BufferPool pool(stream); |
|
|
|
|
GpuMat buf = pool.getBuffer(1, buf_size, CV_8UC1); |
|
|
|
|
|
|
|
|
|
NppStreamHandler h(stream); |
|
|
|
|
|
|
|
|
@ -460,7 +460,7 @@ namespace |
|
|
|
|
}; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void cv::cuda::evenLevels(OutputArray _levels, int nLevels, int lowerLevel, int upperLevel) |
|
|
|
|
void cv::cuda::evenLevels(OutputArray _levels, int nLevels, int lowerLevel, int upperLevel, Stream& stream) |
|
|
|
|
{ |
|
|
|
|
const int kind = _levels.kind(); |
|
|
|
|
|
|
|
|
@ -475,7 +475,7 @@ void cv::cuda::evenLevels(OutputArray _levels, int nLevels, int lowerLevel, int |
|
|
|
|
nppSafeCall( nppiEvenLevelsHost_32s(host_levels.ptr<Npp32s>(), nLevels, lowerLevel, upperLevel) ); |
|
|
|
|
|
|
|
|
|
if (kind == _InputArray::CUDA_GPU_MAT) |
|
|
|
|
_levels.getGpuMatRef().upload(host_levels); |
|
|
|
|
_levels.getGpuMatRef().upload(host_levels, stream); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
namespace hist |
|
|
|
@ -493,9 +493,9 @@ namespace |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void cv::cuda::histEven(InputArray _src, OutputArray hist, InputOutputArray buf, int histSize, int lowerLevel, int upperLevel, Stream& stream) |
|
|
|
|
void cv::cuda::histEven(InputArray _src, OutputArray hist, int histSize, int lowerLevel, int upperLevel, Stream& stream) |
|
|
|
|
{ |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, OutputArray hist, InputOutputArray buf, int levels, int lowerLevel, int upperLevel, cudaStream_t stream); |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, OutputArray hist, int levels, int lowerLevel, int upperLevel, Stream& stream); |
|
|
|
|
static const hist_t hist_callers[] = |
|
|
|
|
{ |
|
|
|
|
NppHistogramEvenC1<CV_8U , nppiHistogramEven_8u_C1R , nppiHistogramEvenGetBufferSize_8u_C1R >::hist, |
|
|
|
@ -514,12 +514,12 @@ void cv::cuda::histEven(InputArray _src, OutputArray hist, InputOutputArray buf, |
|
|
|
|
|
|
|
|
|
CV_Assert( src.type() == CV_8UC1 || src.type() == CV_16UC1 || src.type() == CV_16SC1 ); |
|
|
|
|
|
|
|
|
|
hist_callers[src.depth()](src, hist, buf, histSize, lowerLevel, upperLevel, StreamAccessor::getStream(stream)); |
|
|
|
|
hist_callers[src.depth()](src, hist, histSize, lowerLevel, upperLevel, stream); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void cv::cuda::histEven(InputArray _src, GpuMat hist[4], InputOutputArray buf, int histSize[4], int lowerLevel[4], int upperLevel[4], Stream& stream) |
|
|
|
|
void cv::cuda::histEven(InputArray _src, GpuMat hist[4], int histSize[4], int lowerLevel[4], int upperLevel[4], Stream& stream) |
|
|
|
|
{ |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, GpuMat hist[4], InputOutputArray buf, int levels[4], int lowerLevel[4], int upperLevel[4], cudaStream_t stream); |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, GpuMat hist[4], int levels[4], int lowerLevel[4], int upperLevel[4], Stream& stream); |
|
|
|
|
static const hist_t hist_callers[] = |
|
|
|
|
{ |
|
|
|
|
NppHistogramEvenC4<CV_8U , nppiHistogramEven_8u_C4R , nppiHistogramEvenGetBufferSize_8u_C4R >::hist, |
|
|
|
@ -532,12 +532,12 @@ void cv::cuda::histEven(InputArray _src, GpuMat hist[4], InputOutputArray buf, i |
|
|
|
|
|
|
|
|
|
CV_Assert( src.type() == CV_8UC4 || src.type() == CV_16UC4 || src.type() == CV_16SC4 ); |
|
|
|
|
|
|
|
|
|
hist_callers[src.depth()](src, hist, buf, histSize, lowerLevel, upperLevel, StreamAccessor::getStream(stream)); |
|
|
|
|
hist_callers[src.depth()](src, hist, histSize, lowerLevel, upperLevel, stream); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void cv::cuda::histRange(InputArray _src, OutputArray hist, InputArray _levels, InputOutputArray buf, Stream& stream) |
|
|
|
|
void cv::cuda::histRange(InputArray _src, OutputArray hist, InputArray _levels, Stream& stream) |
|
|
|
|
{ |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, OutputArray hist, const GpuMat& levels, InputOutputArray buf, cudaStream_t stream); |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, OutputArray hist, const GpuMat& levels, Stream& stream); |
|
|
|
|
static const hist_t hist_callers[] = |
|
|
|
|
{ |
|
|
|
|
NppHistogramRangeC1<CV_8U , nppiHistogramRange_8u_C1R , nppiHistogramRangeGetBufferSize_8u_C1R >::hist, |
|
|
|
@ -553,12 +553,12 @@ void cv::cuda::histRange(InputArray _src, OutputArray hist, InputArray _levels, |
|
|
|
|
|
|
|
|
|
CV_Assert( src.type() == CV_8UC1 || src.type() == CV_16UC1 || src.type() == CV_16SC1 || src.type() == CV_32FC1 ); |
|
|
|
|
|
|
|
|
|
hist_callers[src.depth()](src, hist, levels, buf, StreamAccessor::getStream(stream)); |
|
|
|
|
hist_callers[src.depth()](src, hist, levels, stream); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void cv::cuda::histRange(InputArray _src, GpuMat hist[4], const GpuMat levels[4], InputOutputArray buf, Stream& stream) |
|
|
|
|
void cv::cuda::histRange(InputArray _src, GpuMat hist[4], const GpuMat levels[4], Stream& stream) |
|
|
|
|
{ |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, GpuMat hist[4], const GpuMat levels[4], InputOutputArray buf, cudaStream_t stream); |
|
|
|
|
typedef void (*hist_t)(const GpuMat& src, GpuMat hist[4], const GpuMat levels[4], Stream& stream); |
|
|
|
|
static const hist_t hist_callers[] = |
|
|
|
|
{ |
|
|
|
|
NppHistogramRangeC4<CV_8U , nppiHistogramRange_8u_C4R , nppiHistogramRangeGetBufferSize_8u_C4R >::hist, |
|
|
|
@ -573,7 +573,7 @@ void cv::cuda::histRange(InputArray _src, GpuMat hist[4], const GpuMat levels[4] |
|
|
|
|
|
|
|
|
|
CV_Assert( src.type() == CV_8UC4 || src.type() == CV_16UC4 || src.type() == CV_16SC4 || src.type() == CV_32FC4 ); |
|
|
|
|
|
|
|
|
|
hist_callers[src.depth()](src, hist, levels, buf, StreamAccessor::getStream(stream)); |
|
|
|
|
hist_callers[src.depth()](src, hist, levels, stream); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
#endif /* !defined (HAVE_CUDA) */ |
|
|
|
|