added support of CV_8U & CV_TM_CCORR into gpu::matchTemplate
This commit is contained in:
@@ -86,15 +86,6 @@ namespace
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
template <>
|
|
||||||
void matchTemplate<CV_8U, CV_TM_SQDIFF>(const GpuMat& image, const GpuMat& templ, GpuMat& result)
|
|
||||||
{
|
|
||||||
result.create(image.rows - templ.rows + 1, image.cols - templ.cols + 1, CV_32F);
|
|
||||||
imgproc::matchTemplateNaive_8U_SQDIFF(image, templ, result);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
void matchTemplate<CV_32F, CV_TM_SQDIFF>(const GpuMat& image, const GpuMat& templ, GpuMat& result)
|
void matchTemplate<CV_32F, CV_TM_SQDIFF>(const GpuMat& image, const GpuMat& templ, GpuMat& result)
|
||||||
{
|
{
|
||||||
@@ -242,6 +233,24 @@ namespace
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
template <>
|
||||||
|
void matchTemplate<CV_8U, CV_TM_SQDIFF>(const GpuMat& image, const GpuMat& templ, GpuMat& result)
|
||||||
|
{
|
||||||
|
result.create(image.rows - templ.rows + 1, image.cols - templ.cols + 1, CV_32F);
|
||||||
|
imgproc::matchTemplateNaive_8U_SQDIFF(image, templ, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template <>
|
||||||
|
void matchTemplate<CV_8U, CV_TM_CCORR>(const GpuMat& image, const GpuMat& templ, GpuMat& result)
|
||||||
|
{
|
||||||
|
GpuMat imagef, templf;
|
||||||
|
image.convertTo(imagef, CV_32F);
|
||||||
|
templ.convertTo(templf, CV_32F);
|
||||||
|
matchTemplate<CV_32F, CV_TM_SQDIFF>(imagef, templf, result);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -252,7 +261,8 @@ void cv::gpu::matchTemplate(const GpuMat& image, const GpuMat& templ, GpuMat& re
|
|||||||
|
|
||||||
typedef void (*Caller)(const GpuMat&, const GpuMat&, GpuMat&);
|
typedef void (*Caller)(const GpuMat&, const GpuMat&, GpuMat&);
|
||||||
|
|
||||||
static const Caller callers8U[] = { ::matchTemplate<CV_8U, CV_TM_SQDIFF>, 0, 0, 0, 0, 0 };
|
static const Caller callers8U[] = { ::matchTemplate<CV_8U, CV_TM_SQDIFF>, 0,
|
||||||
|
::matchTemplate<CV_8U, CV_TM_CCORR>, 0, 0, 0 };
|
||||||
static const Caller callers32F[] = { ::matchTemplate<CV_32F, CV_TM_SQDIFF>, 0,
|
static const Caller callers32F[] = { ::matchTemplate<CV_32F, CV_TM_SQDIFF>, 0,
|
||||||
::matchTemplate<CV_32F, CV_TM_CCORR>, 0, 0, 0 };
|
::matchTemplate<CV_32F, CV_TM_CCORR>, 0, 0, 0 };
|
||||||
|
|
||||||
|
@@ -87,6 +87,16 @@ struct CV_GpuMatchTemplateTest: CvTest
|
|||||||
F(cout << "gpu_block: " << clock() - t << endl;)
|
F(cout << "gpu_block: " << clock() - t << endl;)
|
||||||
if (!check(dst_gold, Mat(dst), 5 * h * w * 1e-5f)) return;
|
if (!check(dst_gold, Mat(dst), 5 * h * w * 1e-5f)) return;
|
||||||
|
|
||||||
|
gen(image, n, m, CV_8U);
|
||||||
|
gen(templ, h, w, CV_8U);
|
||||||
|
F(t = clock();)
|
||||||
|
matchTemplate(image, templ, dst_gold, CV_TM_CCORR);
|
||||||
|
F(cout << "cpu:" << clock() - t << endl;)
|
||||||
|
F(t = clock();)
|
||||||
|
gpu::matchTemplate(gpu::GpuMat(image), gpu::GpuMat(templ), dst, CV_TM_CCORR);
|
||||||
|
F(cout << "gpu_block: " << clock() - t << endl;)
|
||||||
|
if (!check(dst_gold, Mat(dst), 5 * h * w * 1e-5f)) return;
|
||||||
|
|
||||||
gen(image, n, m, CV_32F);
|
gen(image, n, m, CV_32F);
|
||||||
gen(templ, h, w, CV_32F);
|
gen(templ, h, w, CV_32F);
|
||||||
F(t = clock();)
|
F(t = clock();)
|
||||||
|
Reference in New Issue
Block a user