Merge pull request #6999 from tomoaki0705:featureCmakeFp16
This commit is contained in:
commit
f2e9588c93
@ -193,10 +193,6 @@ enum CpuFeatures {
|
|||||||
# endif
|
# endif
|
||||||
# define CV_POPCNT 1
|
# define CV_POPCNT 1
|
||||||
# endif
|
# endif
|
||||||
# if defined HAVE_FP16 && (defined __F16C__ || (defined _MSC_VER && _MSC_VER >= 1700))
|
|
||||||
# include <immintrin.h>
|
|
||||||
# define CV_FP16 1
|
|
||||||
# endif
|
|
||||||
# if defined __AVX__ || (defined _MSC_VER && _MSC_VER >= 1600 && 0)
|
# if defined __AVX__ || (defined _MSC_VER && _MSC_VER >= 1600 && 0)
|
||||||
// MS Visual Studio 2010 (2012?) has no macro pre-defined to identify the use of /arch:AVX
|
// MS Visual Studio 2010 (2012?) has no macro pre-defined to identify the use of /arch:AVX
|
||||||
// See: http://connect.microsoft.com/VisualStudio/feedback/details/605858/arch-avx-should-define-a-predefined-macro-in-x64-and-set-a-unique-value-for-m-ix86-fp-in-win32
|
// See: http://connect.microsoft.com/VisualStudio/feedback/details/605858/arch-avx-should-define-a-predefined-macro-in-x64-and-set-a-unique-value-for-m-ix86-fp-in-win32
|
||||||
@ -231,10 +227,6 @@ enum CpuFeatures {
|
|||||||
# include <arm_neon.h>
|
# include <arm_neon.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined HAVE_FP16 && defined __GNUC__
|
|
||||||
# define CV_FP16 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined __GNUC__ && defined __arm__ && (defined __ARM_PCS_VFP || defined __ARM_VFPV3__ || defined __ARM_NEON__) && !defined __SOFTFP__
|
#if defined __GNUC__ && defined __arm__ && (defined __ARM_PCS_VFP || defined __ARM_VFPV3__ || defined __ARM_NEON__) && !defined __SOFTFP__
|
||||||
# define CV_VFP 1
|
# define CV_VFP 1
|
||||||
#endif
|
#endif
|
||||||
@ -265,9 +257,6 @@ enum CpuFeatures {
|
|||||||
#ifndef CV_SSE4_2
|
#ifndef CV_SSE4_2
|
||||||
# define CV_SSE4_2 0
|
# define CV_SSE4_2 0
|
||||||
#endif
|
#endif
|
||||||
#ifndef CV_FP16
|
|
||||||
# define CV_FP16 0
|
|
||||||
#endif
|
|
||||||
#ifndef CV_AVX
|
#ifndef CV_AVX
|
||||||
# define CV_AVX 0
|
# define CV_AVX 0
|
||||||
#endif
|
#endif
|
||||||
|
@ -71,6 +71,17 @@
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined HAVE_FP16 && (defined __F16C__ || (defined _MSC_VER && _MSC_VER >= 1700))
|
||||||
|
# include <immintrin.h>
|
||||||
|
# define CV_FP16 1
|
||||||
|
#elif defined HAVE_FP16 && defined __GNUC__
|
||||||
|
# define CV_FP16 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CV_FP16
|
||||||
|
# define CV_FP16 0
|
||||||
|
#endif
|
||||||
|
|
||||||
//! @cond IGNORED
|
//! @cond IGNORED
|
||||||
|
|
||||||
namespace cv
|
namespace cv
|
||||||
|
@ -4568,7 +4568,7 @@ cvtScaleHalf_<float, short>( const float* src, size_t sstep, short* dst, size_t
|
|||||||
sstep /= sizeof(src[0]);
|
sstep /= sizeof(src[0]);
|
||||||
dstep /= sizeof(dst[0]);
|
dstep /= sizeof(dst[0]);
|
||||||
|
|
||||||
if( checkHardwareSupport(CV_FP16) )
|
if( checkHardwareSupport(CV_CPU_FP16) )
|
||||||
{
|
{
|
||||||
for( ; size.height--; src += sstep, dst += dstep )
|
for( ; size.height--; src += sstep, dst += dstep )
|
||||||
{
|
{
|
||||||
@ -4622,7 +4622,7 @@ cvtScaleHalf_<short, float>( const short* src, size_t sstep, float* dst, size_t
|
|||||||
sstep /= sizeof(src[0]);
|
sstep /= sizeof(src[0]);
|
||||||
dstep /= sizeof(dst[0]);
|
dstep /= sizeof(dst[0]);
|
||||||
|
|
||||||
if( checkHardwareSupport(CV_FP16) )
|
if( checkHardwareSupport(CV_CPU_FP16) )
|
||||||
{
|
{
|
||||||
for( ; size.height--; src += sstep, dst += dstep )
|
for( ; size.height--; src += sstep, dst += dstep )
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user