cornerMinEigenVal
This commit is contained in:
parent
d87457a025
commit
b2f851af06
@ -12,7 +12,7 @@
|
|||||||
//
|
//
|
||||||
// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
|
// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
|
||||||
// Copyright (C) 2009, Willow Garage Inc., all rights reserved.
|
// Copyright (C) 2009, Willow Garage Inc., all rights reserved.
|
||||||
// Copyright (C) 2014, Itseez Inc., all rights reserved.
|
// Copyright (C) 2014-2015, Itseez Inc., all rights reserved.
|
||||||
// Third party copyrights are property of their respective owners.
|
// Third party copyrights are property of their respective owners.
|
||||||
//
|
//
|
||||||
// Redistribution and use in source and binary forms, with or without modification,
|
// Redistribution and use in source and binary forms, with or without modification,
|
||||||
@ -271,6 +271,8 @@ cornerEigenValsVecs( const Mat& src, Mat& eigenv, int block_size,
|
|||||||
#ifdef HAVE_TEGRA_OPTIMIZATION
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
if (tegra::cornerEigenValsVecs(src, eigenv, block_size, aperture_size, op_type, k, borderType))
|
if (tegra::cornerEigenValsVecs(src, eigenv, block_size, aperture_size, op_type, k, borderType))
|
||||||
return;
|
return;
|
||||||
|
#elif CV_SSE2
|
||||||
|
bool haveSSE2 = checkHardwareSupport(CV_CPU_SSE2);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int depth = src.depth();
|
int depth = src.depth();
|
||||||
@ -319,6 +321,33 @@ cornerEigenValsVecs( const Mat& src, Mat& eigenv, int block_size,
|
|||||||
|
|
||||||
vst3q_f32(cov_data + j * 3, v_dst);
|
vst3q_f32(cov_data + j * 3, v_dst);
|
||||||
}
|
}
|
||||||
|
#elif CV_SSE2
|
||||||
|
if (haveSSE2)
|
||||||
|
{
|
||||||
|
for( ; j <= size.width - 8; j += 8 )
|
||||||
|
{
|
||||||
|
__m128 v_dx_0 = _mm_loadu_ps(dxdata + j);
|
||||||
|
__m128 v_dx_1 = _mm_loadu_ps(dxdata + j + 4);
|
||||||
|
__m128 v_dy_0 = _mm_loadu_ps(dydata + j);
|
||||||
|
__m128 v_dy_1 = _mm_loadu_ps(dydata + j + 4);
|
||||||
|
|
||||||
|
__m128 v_dx2_0 = _mm_mul_ps(v_dx_0, v_dx_0);
|
||||||
|
__m128 v_dxy_0 = _mm_mul_ps(v_dx_0, v_dy_0);
|
||||||
|
__m128 v_dy2_0 = _mm_mul_ps(v_dy_0, v_dy_0);
|
||||||
|
__m128 v_dx2_1 = _mm_mul_ps(v_dx_1, v_dx_1);
|
||||||
|
__m128 v_dxy_1 = _mm_mul_ps(v_dx_1, v_dy_1);
|
||||||
|
__m128 v_dy2_1 = _mm_mul_ps(v_dy_1, v_dy_1);
|
||||||
|
|
||||||
|
_mm_interleave_ps(v_dx2_0, v_dx2_1, v_dxy_0, v_dxy_1, v_dy2_0, v_dy2_1);
|
||||||
|
|
||||||
|
_mm_storeu_ps(cov_data + j * 3, v_dx2_0);
|
||||||
|
_mm_storeu_ps(cov_data + j * 3 + 4, v_dx2_1);
|
||||||
|
_mm_storeu_ps(cov_data + j * 3 + 8, v_dxy_0);
|
||||||
|
_mm_storeu_ps(cov_data + j * 3 + 12, v_dxy_1);
|
||||||
|
_mm_storeu_ps(cov_data + j * 3 + 16, v_dy2_0);
|
||||||
|
_mm_storeu_ps(cov_data + j * 3 + 20, v_dy2_1);
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for( ; j < size.width; j++ )
|
for( ; j < size.width; j++ )
|
||||||
|
@ -736,8 +736,6 @@ struct ColumnSum<int, int> :
|
|||||||
bool haveScale = scale != 1;
|
bool haveScale = scale != 1;
|
||||||
double _scale = scale;
|
double _scale = scale;
|
||||||
|
|
||||||
printf("bgfbffbbfg\n");
|
|
||||||
|
|
||||||
#if CV_SSE2
|
#if CV_SSE2
|
||||||
bool haveSSE2 = checkHardwareSupport(CV_CPU_SSE2);
|
bool haveSSE2 = checkHardwareSupport(CV_CPU_SSE2);
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user