I am trying to compute HOG functions for a block only. I investigated the hog.cpp specified in the opencv/module/gpu/src/ section. Below is the code that I change to a computer for block functions only.
void cv::gpu::HOGDescriptor::getDescriptors(const GpuMat& img, Size win_stride, GpuMat& descriptors, int descr_format) { CV_Assert(win_stride.width % block_stride.width == 0 && win_stride.height % block_stride.height == 0); computeBlockHistograms(img); // give block back /* const size_t block_hist_size = getBlockHistogramSize(); Size blocks_per_win = numPartsWithin(win_size, block_size, block_stride); Size wins_per_img = numPartsWithin(img.size(), win_size, win_stride); descriptors.create(wins_per_img.area(), static_cast<int>(blocks_per_win.area() * block_hist_size), CV_32F); */ switch (descr_format) { case DESCR_FORMAT_ROW_BY_ROW: hog::extract_descrs_by_rows(win_size.height, win_size.width, block_stride.height, block_stride.width, win_stride.height, win_stride.width, img.rows, img.cols, block_hists.ptr<float>(), descriptors); break; case DESCR_FORMAT_COL_BY_COL: hog::extract_descrs_by_cols(win_size.height, win_size.width, block_stride.height, block_stride.width, win_stride.height, win_stride.width, img.rows, img.cols, block_hists.ptr<float>(), descriptors); break; default: CV_Error(CV_StsBadArg, "Unknown descriptor format"); } }
Here is the computeBlockHistograms code.
void cv::gpu::HOGDescriptor::computeBlockHistograms(const GpuMat& img) { computeGradient(img, grad, qangle); size_t block_hist_size = getBlockHistogramSize(); Size blocks_per_img = numPartsWithin(img.size(), block_size, block_stride);
EDIT: I enable the getDescriptor function also from hog.cpp
void cv::gpu::HOGDescriptor::getDescriptors(const GpuMat& img, Size win_stride, GpuMat& descriptors, int descr_format) { CV_Assert(win_stride.width % block_stride.width == 0 && win_stride.height % block_stride.height == 0); computeBlockHistograms(img); const size_t block_hist_size = getBlockHistogramSize(); Size blocks_per_win = numPartsWithin(win_size, block_size, block_stride); Size wins_per_img = numPartsWithin(img.size(), win_size, win_stride); descriptors.create(wins_per_img.area(), static_cast<int>(blocks_per_win.area() * block_hist_size), CV_32F); switch (descr_format) { case DESCR_FORMAT_ROW_BY_ROW: hog::extract_descrs_by_rows(win_size.height, win_size.width, block_stride.height, block_stride.width, win_stride.height, win_stride.width, img.rows, img.cols, block_hists.ptr<float>(), descriptors); break; case DESCR_FORMAT_COL_BY_COL: hog::extract_descrs_by_cols(win_size.height, win_size.width, block_stride.height, block_stride.width, win_stride.height, win_stride.width, img.rows, img.cols, block_hists.ptr<float>(), descriptors); break; default: CV_Error(CV_StsBadArg, "Unknown descriptor format"); } }
Can someone help me get the block-only HOG functions. EDITED: I am only interested in calculating the HOG functions for the various window size preservation functions for the cell and blocking them.