mirror of
https://github.com/opencv/opencv.git
synced 2025-01-18 14:13:15 +08:00
Merge remote-tracking branch 'upstream/3.4' into merge-3.4
This commit is contained in:
commit
19a4b51371
7
3rdparty/libjpeg/CMakeLists.txt
vendored
7
3rdparty/libjpeg/CMakeLists.txt
vendored
@ -15,13 +15,6 @@ else()
|
|||||||
ocv_list_filterout(lib_srcs jmemnobs.c)
|
ocv_list_filterout(lib_srcs jmemnobs.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WINRT)
|
|
||||||
add_definitions(-DNO_GETENV)
|
|
||||||
get_directory_property( DirDefs COMPILE_DEFINITIONS )
|
|
||||||
message(STATUS "Adding NO_GETENV to compiler definitions for WINRT:")
|
|
||||||
message(STATUS " COMPILE_DEFINITIONS = ${DirDefs}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------------
|
||||||
# Define the library target:
|
# Define the library target:
|
||||||
# ----------------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------------
|
||||||
|
115
CMakeLists.txt
115
CMakeLists.txt
@ -29,40 +29,19 @@ else()
|
|||||||
cmake_minimum_required(VERSION "${MIN_VER_CMAKE}" FATAL_ERROR)
|
cmake_minimum_required(VERSION "${MIN_VER_CMAKE}" FATAL_ERROR)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
option(ENABLE_PIC "Generate position independent code (necessary for shared libraries)" TRUE)
|
#
|
||||||
set(CMAKE_POSITION_INDEPENDENT_CODE ${ENABLE_PIC})
|
# Configure CMake policies
|
||||||
|
#
|
||||||
set(OPENCV_MATHJAX_RELPATH "https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.0" CACHE STRING "URI to a MathJax installation")
|
|
||||||
|
|
||||||
# Following block can break build in case of cross-compiling
|
|
||||||
# but CMAKE_CROSSCOMPILING variable will be set only on project(OpenCV) command
|
|
||||||
# so we will try to detect cross-compiling by the presence of CMAKE_TOOLCHAIN_FILE
|
|
||||||
if(NOT DEFINED CMAKE_INSTALL_PREFIX)
|
|
||||||
if(NOT CMAKE_TOOLCHAIN_FILE)
|
|
||||||
# it _must_ go before project(OpenCV) in order to work
|
|
||||||
if(WIN32)
|
|
||||||
set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Installation Directory")
|
|
||||||
else()
|
|
||||||
set(CMAKE_INSTALL_PREFIX "/usr/local" CACHE PATH "Installation Directory")
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
#Android: set output folder to ${CMAKE_BINARY_DIR}
|
|
||||||
set(LIBRARY_OUTPUT_PATH_ROOT ${CMAKE_BINARY_DIR} CACHE PATH "root for library output, set this to change where android libs are compiled to" )
|
|
||||||
# any cross-compiling
|
|
||||||
set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Installation Directory")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(POLICY CMP0026)
|
if(POLICY CMP0026)
|
||||||
cmake_policy(SET CMP0026 NEW)
|
cmake_policy(SET CMP0026 NEW)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0042)
|
if(POLICY CMP0042)
|
||||||
cmake_policy(SET CMP0042 NEW)
|
cmake_policy(SET CMP0042 NEW) # CMake 3.0+ (2.8.12): MacOS "@rpath" in target's install name
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0046)
|
if(POLICY CMP0046)
|
||||||
cmake_policy(SET CMP0046 NEW)
|
cmake_policy(SET CMP0046 NEW) # warn about non-existed dependencies
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0051)
|
if(POLICY CMP0051)
|
||||||
@ -74,17 +53,21 @@ if(POLICY CMP0054) # CMake 3.1: Only interpret if() arguments as variables or k
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0056)
|
if(POLICY CMP0056)
|
||||||
cmake_policy(SET CMP0056 NEW)
|
cmake_policy(SET CMP0056 NEW) # try_compile(): link flags
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0067)
|
if(POLICY CMP0067)
|
||||||
cmake_policy(SET CMP0067 NEW)
|
cmake_policy(SET CMP0067 NEW) # CMake 3.8: try_compile(): honor language standard variables (like C++11)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0068)
|
if(POLICY CMP0068)
|
||||||
cmake_policy(SET CMP0068 NEW) # CMake 3.9+: `RPATH` settings on macOS do not affect `install_name`.
|
cmake_policy(SET CMP0068 NEW) # CMake 3.9+: `RPATH` settings on macOS do not affect `install_name`.
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Configure OpenCV CMake hooks
|
||||||
|
#
|
||||||
include(cmake/OpenCVUtils.cmake)
|
include(cmake/OpenCVUtils.cmake)
|
||||||
ocv_cmake_reset_hooks()
|
ocv_cmake_reset_hooks()
|
||||||
ocv_check_environment_variables(OPENCV_CMAKE_HOOKS_DIR)
|
ocv_check_environment_variables(OPENCV_CMAKE_HOOKS_DIR)
|
||||||
@ -97,49 +80,46 @@ endif()
|
|||||||
|
|
||||||
ocv_cmake_hook(CMAKE_INIT)
|
ocv_cmake_hook(CMAKE_INIT)
|
||||||
|
|
||||||
# must go before the project command
|
# must go before the project()/enable_language() commands
|
||||||
ocv_update(CMAKE_CONFIGURATION_TYPES "Debug;Release" CACHE STRING "Configs" FORCE)
|
ocv_update(CMAKE_CONFIGURATION_TYPES "Debug;Release" CACHE STRING "Configs" FORCE)
|
||||||
if(DEFINED CMAKE_BUILD_TYPE)
|
if(DEFINED CMAKE_BUILD_TYPE)
|
||||||
set_property( CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS ${CMAKE_CONFIGURATION_TYPES} )
|
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "${CMAKE_CONFIGURATION_TYPES}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
option(ENABLE_PIC "Generate position independent code (necessary for shared libraries)" TRUE)
|
||||||
|
set(CMAKE_POSITION_INDEPENDENT_CODE ${ENABLE_PIC})
|
||||||
|
|
||||||
|
ocv_cmake_hook(PRE_CMAKE_BOOTSTRAP)
|
||||||
|
|
||||||
|
# Bootstap CMake system: setup CMAKE_SYSTEM_NAME and other vars
|
||||||
|
enable_language(CXX C)
|
||||||
|
|
||||||
|
ocv_cmake_hook(POST_CMAKE_BOOTSTRAP)
|
||||||
|
|
||||||
|
if(NOT OPENCV_SKIP_CMAKE_SYSTEM_FILE)
|
||||||
|
include("cmake/platforms/OpenCV-${CMAKE_SYSTEM_NAME}.cmake" OPTIONAL RESULT_VARIABLE "OPENCV_CMAKE_SYSTEM_FILE")
|
||||||
|
if(NOT OPENCV_CMAKE_SYSTEM_FILE)
|
||||||
|
message(STATUS "OpenCV: system-specific configuration file is not found: '${CMAKE_SYSTEM_NAME}'")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) # https://cmake.org/cmake/help/latest/variable/CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT.html
|
||||||
|
if(NOT CMAKE_TOOLCHAIN_FILE)
|
||||||
|
if(WIN32)
|
||||||
|
set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Installation Directory" FORCE)
|
||||||
|
else()
|
||||||
|
set(CMAKE_INSTALL_PREFIX "/usr/local" CACHE PATH "Installation Directory" FORCE)
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
# any cross-compiling
|
||||||
|
set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "Installation Directory" FORCE)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
|
||||||
project(OpenCV CXX C)
|
project(OpenCV CXX C)
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES WindowsPhone OR CMAKE_SYSTEM_NAME MATCHES WindowsStore)
|
|
||||||
set(WINRT TRUE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WINRT OR WINCE)
|
|
||||||
add_definitions(-DNO_GETENV)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(WINRT)
|
|
||||||
add_definitions(-DWINRT)
|
|
||||||
|
|
||||||
# Making definitions available to other configurations and
|
|
||||||
# to filter dependency restrictions at compile time.
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES WindowsPhone)
|
|
||||||
set(WINRT_PHONE TRUE)
|
|
||||||
add_definitions(-DWINRT_PHONE)
|
|
||||||
elseif(CMAKE_SYSTEM_NAME MATCHES WindowsStore)
|
|
||||||
set(WINRT_STORE TRUE)
|
|
||||||
add_definitions(-DWINRT_STORE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_VERSION MATCHES 10)
|
|
||||||
set(WINRT_10 TRUE)
|
|
||||||
add_definitions(-DWINRT_10)
|
|
||||||
elseif(CMAKE_SYSTEM_VERSION MATCHES 8.1)
|
|
||||||
set(WINRT_8_1 TRUE)
|
|
||||||
add_definitions(-DWINRT_8_1)
|
|
||||||
elseif(CMAKE_SYSTEM_VERSION MATCHES 8.0)
|
|
||||||
set(WINRT_8_0 TRUE)
|
|
||||||
add_definitions(-DWINRT_8_0)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(MSVC)
|
if(MSVC)
|
||||||
set(CMAKE_USE_RELATIVE_PATHS ON CACHE INTERNAL "" FORCE)
|
set(CMAKE_USE_RELATIVE_PATHS ON CACHE INTERNAL "" FORCE)
|
||||||
endif()
|
endif()
|
||||||
@ -501,6 +481,7 @@ if(ENABLE_IMPL_COLLECTION)
|
|||||||
add_definitions(-DCV_COLLECT_IMPL_DATA)
|
add_definitions(-DCV_COLLECT_IMPL_DATA)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(OPENCV_MATHJAX_RELPATH "https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.0" CACHE STRING "URI to a MathJax installation")
|
||||||
|
|
||||||
# ----------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------
|
||||||
# Get actual OpenCV version number from sources
|
# Get actual OpenCV version number from sources
|
||||||
@ -647,12 +628,12 @@ endif()
|
|||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
# Postfix of DLLs:
|
# Postfix of DLLs:
|
||||||
set(OPENCV_DLLVERSION "${OPENCV_VERSION_MAJOR}${OPENCV_VERSION_MINOR}${OPENCV_VERSION_PATCH}")
|
ocv_update(OPENCV_DLLVERSION "${OPENCV_VERSION_MAJOR}${OPENCV_VERSION_MINOR}${OPENCV_VERSION_PATCH}")
|
||||||
set(OPENCV_DEBUG_POSTFIX d)
|
ocv_update(OPENCV_DEBUG_POSTFIX d)
|
||||||
else()
|
else()
|
||||||
# Postfix of so's:
|
# Postfix of so's:
|
||||||
set(OPENCV_DLLVERSION "")
|
ocv_update(OPENCV_DLLVERSION "")
|
||||||
set(OPENCV_DEBUG_POSTFIX "")
|
ocv_update(OPENCV_DEBUG_POSTFIX "")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(DEFINED CMAKE_DEBUG_POSTFIX)
|
if(DEFINED CMAKE_DEBUG_POSTFIX)
|
||||||
|
@ -4,16 +4,6 @@ if(NOT MSVC)
|
|||||||
message(FATAL_ERROR "CRT options are available only for MSVC")
|
message(FATAL_ERROR "CRT options are available only for MSVC")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (WINRT)
|
|
||||||
if (CMAKE_SYSTEM_VERSION MATCHES 10)
|
|
||||||
add_definitions(/DWINVER=_WIN32_WINNT_WIN10 /DNTDDI_VERSION=NTDDI_WIN10 /D_WIN32_WINNT=_WIN32_WINNT_WIN10)
|
|
||||||
elseif(CMAKE_SYSTEM_VERSION MATCHES 8.1)
|
|
||||||
add_definitions(/DWINVER=_WIN32_WINNT_WINBLUE /DNTDDI_VERSION=NTDDI_WINBLUE /D_WIN32_WINNT=_WIN32_WINNT_WINBLUE)
|
|
||||||
else()
|
|
||||||
add_definitions(/DWINVER=_WIN32_WINNT_WIN8 /DNTDDI_VERSION=NTDDI_WIN8 /D_WIN32_WINNT=_WIN32_WINNT_WIN8)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Removing LNK4075 warnings for debug WinRT builds
|
# Removing LNK4075 warnings for debug WinRT builds
|
||||||
# "LNK4075: ignoring '/INCREMENTAL' due to '/OPT:ICF' specification"
|
# "LNK4075: ignoring '/INCREMENTAL' due to '/OPT:ICF' specification"
|
||||||
# "LNK4075: ignoring '/INCREMENTAL' due to '/OPT:REF' specification"
|
# "LNK4075: ignoring '/INCREMENTAL' due to '/OPT:REF' specification"
|
||||||
|
@ -285,11 +285,6 @@ if(MSVC)
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Adding additional using directory for WindowsPhone 8.0 to get Windows.winmd properly
|
|
||||||
if(WINRT_PHONE AND WINRT_8_0)
|
|
||||||
set(OPENCV_EXTRA_CXX_FLAGS "${OPENCV_EXTRA_CXX_FLAGS} /AI\$(WindowsSDK_MetadataPath)")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
include(cmake/OpenCVCompilerOptimizations.cmake)
|
include(cmake/OpenCVCompilerOptimizations.cmake)
|
||||||
if(COMMAND ocv_compiler_optimization_options)
|
if(COMMAND ocv_compiler_optimization_options)
|
||||||
ocv_compiler_optimization_options()
|
ocv_compiler_optimization_options()
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
set(MIN_VER_CMAKE 3.5.1)
|
if(NOT DEFINED MIN_VER_CMAKE)
|
||||||
|
set(MIN_VER_CMAKE 3.5.1)
|
||||||
|
endif()
|
||||||
set(MIN_VER_CUDA 6.5)
|
set(MIN_VER_CUDA 6.5)
|
||||||
set(MIN_VER_CUDNN 6)
|
set(MIN_VER_CUDNN 6)
|
||||||
set(MIN_VER_PYTHON2 2.7)
|
set(MIN_VER_PYTHON2 2.7)
|
||||||
|
@ -1206,10 +1206,6 @@ endfunction()
|
|||||||
function(ocv_add_accuracy_tests)
|
function(ocv_add_accuracy_tests)
|
||||||
ocv_debug_message("ocv_add_accuracy_tests(" ${ARGN} ")")
|
ocv_debug_message("ocv_add_accuracy_tests(" ${ARGN} ")")
|
||||||
|
|
||||||
if(WINRT)
|
|
||||||
set(OPENCV_DEBUG_POSTFIX "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(test_path "${CMAKE_CURRENT_LIST_DIR}/test")
|
set(test_path "${CMAKE_CURRENT_LIST_DIR}/test")
|
||||||
if(BUILD_TESTS AND EXISTS "${test_path}")
|
if(BUILD_TESTS AND EXISTS "${test_path}")
|
||||||
__ocv_parse_test_sources(TEST ${ARGN})
|
__ocv_parse_test_sources(TEST ${ARGN})
|
||||||
|
@ -16,7 +16,8 @@ function(ocv_cmake_dump_vars)
|
|||||||
string(TOLOWER "${__variableName}" __variableName_lower)
|
string(TOLOWER "${__variableName}" __variableName_lower)
|
||||||
if((__variableName MATCHES "${regex}" OR __variableName_lower MATCHES "${regex_lower}")
|
if((__variableName MATCHES "${regex}" OR __variableName_lower MATCHES "${regex_lower}")
|
||||||
AND NOT __variableName_lower MATCHES "^__")
|
AND NOT __variableName_lower MATCHES "^__")
|
||||||
set(__VARS "${__VARS}${__variableName}=${${__variableName}}\n")
|
get_property(__value VARIABLE PROPERTY "${__variableName}")
|
||||||
|
set(__VARS "${__VARS}${__variableName}=${__value}\n")
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
if(DUMP_TOFILE)
|
if(DUMP_TOFILE)
|
||||||
|
1
cmake/platforms/OpenCV-Android.cmake
Normal file
1
cmake/platforms/OpenCV-Android.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
# empty
|
1
cmake/platforms/OpenCV-Darwin.cmake
Normal file
1
cmake/platforms/OpenCV-Darwin.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
# empty
|
1
cmake/platforms/OpenCV-Linux.cmake
Normal file
1
cmake/platforms/OpenCV-Linux.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
# empty
|
31
cmake/platforms/OpenCV-WinRT.cmake
Normal file
31
cmake/platforms/OpenCV-WinRT.cmake
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
set(WINRT TRUE)
|
||||||
|
|
||||||
|
add_definitions(-DWINRT -DNO_GETENV)
|
||||||
|
|
||||||
|
# Making definitions available to other configurations and
|
||||||
|
# to filter dependency restrictions at compile time.
|
||||||
|
if(WINDOWS_PHONE)
|
||||||
|
set(WINRT_PHONE TRUE)
|
||||||
|
add_definitions(-DWINRT_PHONE)
|
||||||
|
elseif(WINDOWS_STORE)
|
||||||
|
set(WINRT_STORE TRUE)
|
||||||
|
add_definitions(-DWINRT_STORE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_SYSTEM_VERSION MATCHES 10)
|
||||||
|
set(WINRT_10 TRUE)
|
||||||
|
add_definitions(-DWINRT_10)
|
||||||
|
add_definitions(/DWINVER=_WIN32_WINNT_WIN10 /DNTDDI_VERSION=NTDDI_WIN10 /D_WIN32_WINNT=_WIN32_WINNT_WIN10)
|
||||||
|
elseif(CMAKE_SYSTEM_VERSION MATCHES 8.1)
|
||||||
|
set(WINRT_8_1 TRUE)
|
||||||
|
add_definitions(-DWINRT_8_1)
|
||||||
|
add_definitions(/DWINVER=_WIN32_WINNT_WINBLUE /DNTDDI_VERSION=NTDDI_WINBLUE /D_WIN32_WINNT=_WIN32_WINNT_WINBLUE)
|
||||||
|
elseif(CMAKE_SYSTEM_VERSION MATCHES 8.0)
|
||||||
|
set(WINRT_8_0 TRUE)
|
||||||
|
add_definitions(-DWINRT_8_0)
|
||||||
|
add_definitions(/DWINVER=_WIN32_WINNT_WIN8 /DNTDDI_VERSION=NTDDI_WIN8 /D_WIN32_WINNT=_WIN32_WINNT_WIN8)
|
||||||
|
else()
|
||||||
|
message(STATUS "Unsupported WINRT version (consider upgrading OpenCV): ${CMAKE_SYSTEM_VERSION}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(OPENCV_DEBUG_POSTFIX "")
|
1
cmake/platforms/OpenCV-Windows.cmake
Normal file
1
cmake/platforms/OpenCV-Windows.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
# empty
|
1
cmake/platforms/OpenCV-WindowsCE.cmake
Normal file
1
cmake/platforms/OpenCV-WindowsCE.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
add_definitions(-DNO_GETENV)
|
6
cmake/platforms/OpenCV-WindowsPhone.cmake
Normal file
6
cmake/platforms/OpenCV-WindowsPhone.cmake
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
include("${CMAKE_CURRENT_LIST_DIR}/OpenCV_WinRT.cmake")
|
||||||
|
|
||||||
|
# Adding additional using directory for WindowsPhone 8.0 to get Windows.winmd properly
|
||||||
|
if(WINRT_8_0)
|
||||||
|
set(OPENCV_EXTRA_CXX_FLAGS "${OPENCV_EXTRA_CXX_FLAGS} /AI\$(WindowsSDK_MetadataPath)")
|
||||||
|
endif()
|
1
cmake/platforms/OpenCV-WindowsStore.cmake
Normal file
1
cmake/platforms/OpenCV-WindowsStore.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
include("${CMAKE_CURRENT_LIST_DIR}/OpenCV_WinRT.cmake")
|
1
cmake/platforms/OpenCV-iOS.cmake
Normal file
1
cmake/platforms/OpenCV-iOS.cmake
Normal file
@ -0,0 +1 @@
|
|||||||
|
# empty
|
@ -16,4 +16,4 @@ PERF_TEST(Undistort, InitUndistortMap)
|
|||||||
SANITY_CHECK_NOTHING();
|
SANITY_CHECK_NOTHING();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} // namespace
|
||||||
|
@ -23,7 +23,7 @@ ocv_add_module(core
|
|||||||
|
|
||||||
set(extra_libs "")
|
set(extra_libs "")
|
||||||
|
|
||||||
if(WINRT AND CMAKE_SYSTEM_NAME MATCHES WindowsStore AND CMAKE_SYSTEM_VERSION MATCHES "8.0")
|
if(WINRT AND WINDOWS_STORE AND CMAKE_SYSTEM_VERSION MATCHES "8.0")
|
||||||
list(APPEND extra_libs ole32.lib)
|
list(APPEND extra_libs ole32.lib)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -70,7 +70,14 @@
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined __GNUC__ && defined __arm__ && (defined __ARM_PCS_VFP || defined __ARM_VFPV3__ || defined __ARM_NEON__) && !defined __SOFTFP__ && !defined(__CUDACC__)
|
#if defined __PPC64__ && defined __GNUC__ && defined _ARCH_PWR8 && !defined (__CUDACC__)
|
||||||
|
# include <altivec.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CV_INLINE_ROUND_FLT)
|
||||||
|
// user-specified version
|
||||||
|
// CV_INLINE_ROUND_DBL should be defined too
|
||||||
|
#elif defined __GNUC__ && defined __arm__ && (defined __ARM_PCS_VFP || defined __ARM_VFPV3__ || defined __ARM_NEON__) && !defined __SOFTFP__ && !defined(__CUDACC__)
|
||||||
// 1. general scheme
|
// 1. general scheme
|
||||||
#define ARM_ROUND(_value, _asm_string) \
|
#define ARM_ROUND(_value, _asm_string) \
|
||||||
int res; \
|
int res; \
|
||||||
@ -80,12 +87,55 @@
|
|||||||
return res
|
return res
|
||||||
// 2. version for double
|
// 2. version for double
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
#define ARM_ROUND_DBL(value) ARM_ROUND(value, "vcvtr.s32.f64 %[temp], %[value] \n vmov %[res], %[temp]")
|
#define CV_INLINE_ROUND_DBL(value) ARM_ROUND(value, "vcvtr.s32.f64 %[temp], %[value] \n vmov %[res], %[temp]")
|
||||||
#else
|
#else
|
||||||
#define ARM_ROUND_DBL(value) ARM_ROUND(value, "vcvtr.s32.f64 %[temp], %P[value] \n vmov %[res], %[temp]")
|
#define CV_INLINE_ROUND_DBL(value) ARM_ROUND(value, "vcvtr.s32.f64 %[temp], %P[value] \n vmov %[res], %[temp]")
|
||||||
#endif
|
#endif
|
||||||
// 3. version for float
|
// 3. version for float
|
||||||
#define ARM_ROUND_FLT(value) ARM_ROUND(value, "vcvtr.s32.f32 %[temp], %[value]\n vmov %[res], %[temp]")
|
#define CV_INLINE_ROUND_FLT(value) ARM_ROUND(value, "vcvtr.s32.f32 %[temp], %[value]\n vmov %[res], %[temp]")
|
||||||
|
#elif defined __PPC64__ && defined __GNUC__ && defined _ARCH_PWR8 && !defined (__CUDACC__)
|
||||||
|
// P8 and newer machines can convert fp32/64 to int quickly.
|
||||||
|
#define CV_INLINE_ROUND_DBL(value) \
|
||||||
|
int out; \
|
||||||
|
double temp; \
|
||||||
|
__asm__( "fctiw %[temp],%[in]\n\tmffprwz %[out],%[temp]\n\t" : [out] "=r" (out), [temp] "=d" (temp) : [in] "d" ((double)(value)) : ); \
|
||||||
|
return out;
|
||||||
|
|
||||||
|
// FP32 also works with FP64 routine above
|
||||||
|
#define CV_INLINE_ROUND_FLT(value) CV_INLINE_ROUND_DBL(value)
|
||||||
|
|
||||||
|
#ifdef _ARCH_PWR9
|
||||||
|
#define CV_INLINE_ISINF_DBL(value) return scalar_test_data_class(value, 0x30);
|
||||||
|
#define CV_INLINE_ISNAN_DBL(value) return scalar_test_data_class(value, 0x40);
|
||||||
|
#define CV_INLINE_ISINF_FLT(value) CV_INLINE_ISINF_DBL(value)
|
||||||
|
#define CV_INLINE_ISNAN_FLT(value) CV_INLINE_ISNAN_DBL(value)
|
||||||
|
#endif
|
||||||
|
#elif defined CV_ICC || defined __GNUC__
|
||||||
|
#define CV_INLINE_ROUND_DBL(value) return (int)(lrint(value));
|
||||||
|
#define CV_INLINE_ROUND_FLT(value) return (int)(lrintf(value));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined __PPC64__ && !defined OPENCV_USE_FASTMATH_GCC_BUILTINS
|
||||||
|
/* Let GCC inline C math functions when available. Dedicated hardware is available to
|
||||||
|
round and covert FP values. */
|
||||||
|
#define OPENCV_USE_FASTMATH_GCC_BUILTINS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable GCC builtin math functions if possible, desired, and available.
|
||||||
|
Note, not all math functions inline equally. E.g lrint will not inline
|
||||||
|
without the -fno-math-errno option. */
|
||||||
|
#if defined OPENCV_USE_FASTMATH_GCC_BUILTINS && defined __GNUC__ && !defined __clang__ && !defined (__CUDACC__)
|
||||||
|
#define _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Allow overrides for some functions which may benefit from tuning. Likewise,
|
||||||
|
note that isinf is not used as the return value is signed. */
|
||||||
|
#if defined _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS && !defined CV_INLINE_ISNAN_DBL
|
||||||
|
#define CV_INLINE_ISNAN_DBL(value) return __builtin_isnan(value);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS && !defined CV_INLINE_ISNAN_FLT
|
||||||
|
#define CV_INLINE_ISNAN_FLT(value) return __builtin_isnanf(value);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/** @brief Rounds floating-point number to the nearest integer
|
/** @brief Rounds floating-point number to the nearest integer
|
||||||
@ -108,12 +158,10 @@ cvRound( double value )
|
|||||||
fistp t;
|
fistp t;
|
||||||
}
|
}
|
||||||
return t;
|
return t;
|
||||||
|
#elif defined CV_INLINE_ROUND_DBL
|
||||||
|
CV_INLINE_ROUND_DBL(value);
|
||||||
#elif defined CV_ICC || defined __GNUC__
|
#elif defined CV_ICC || defined __GNUC__
|
||||||
# if defined ARM_ROUND_DBL
|
|
||||||
ARM_ROUND_DBL(value);
|
|
||||||
# else
|
|
||||||
return (int)lrint(value);
|
return (int)lrint(value);
|
||||||
# endif
|
|
||||||
#else
|
#else
|
||||||
/* it's ok if round does not comply with IEEE754 standard;
|
/* it's ok if round does not comply with IEEE754 standard;
|
||||||
the tests should allow +/-1 difference when the tested functions use round */
|
the tests should allow +/-1 difference when the tested functions use round */
|
||||||
@ -131,8 +179,12 @@ cvRound( double value )
|
|||||||
*/
|
*/
|
||||||
CV_INLINE int cvFloor( double value )
|
CV_INLINE int cvFloor( double value )
|
||||||
{
|
{
|
||||||
|
#if defined _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS
|
||||||
|
return __builtin_floor(value);
|
||||||
|
#else
|
||||||
int i = (int)value;
|
int i = (int)value;
|
||||||
return i - (i > value);
|
return i - (i > value);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @brief Rounds floating-point number to the nearest integer not smaller than the original.
|
/** @brief Rounds floating-point number to the nearest integer not smaller than the original.
|
||||||
@ -144,8 +196,12 @@ CV_INLINE int cvFloor( double value )
|
|||||||
*/
|
*/
|
||||||
CV_INLINE int cvCeil( double value )
|
CV_INLINE int cvCeil( double value )
|
||||||
{
|
{
|
||||||
|
#if defined _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS
|
||||||
|
return __builtin_ceil(value);
|
||||||
|
#else
|
||||||
int i = (int)value;
|
int i = (int)value;
|
||||||
return i + (i < value);
|
return i + (i < value);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @brief Determines if the argument is Not A Number.
|
/** @brief Determines if the argument is Not A Number.
|
||||||
@ -156,10 +212,14 @@ CV_INLINE int cvCeil( double value )
|
|||||||
otherwise. */
|
otherwise. */
|
||||||
CV_INLINE int cvIsNaN( double value )
|
CV_INLINE int cvIsNaN( double value )
|
||||||
{
|
{
|
||||||
|
#if defined CV_INLINE_ISNAN_DBL
|
||||||
|
CV_INLINE_ISNAN_DBL(value);
|
||||||
|
#else
|
||||||
Cv64suf ieee754;
|
Cv64suf ieee754;
|
||||||
ieee754.f = value;
|
ieee754.f = value;
|
||||||
return ((unsigned)(ieee754.u >> 32) & 0x7fffffff) +
|
return ((unsigned)(ieee754.u >> 32) & 0x7fffffff) +
|
||||||
((unsigned)ieee754.u != 0) > 0x7ff00000;
|
((unsigned)ieee754.u != 0) > 0x7ff00000;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @brief Determines if the argument is Infinity.
|
/** @brief Determines if the argument is Infinity.
|
||||||
@ -170,10 +230,14 @@ CV_INLINE int cvIsNaN( double value )
|
|||||||
and 0 otherwise. */
|
and 0 otherwise. */
|
||||||
CV_INLINE int cvIsInf( double value )
|
CV_INLINE int cvIsInf( double value )
|
||||||
{
|
{
|
||||||
|
#if defined CV_INLINE_ISINF_DBL
|
||||||
|
CV_INLINE_ISINF_DBL(value);
|
||||||
|
#else
|
||||||
Cv64suf ieee754;
|
Cv64suf ieee754;
|
||||||
ieee754.f = value;
|
ieee754.f = value;
|
||||||
return ((unsigned)(ieee754.u >> 32) & 0x7fffffff) == 0x7ff00000 &&
|
return ((unsigned)(ieee754.u >> 32) & 0x7fffffff) == 0x7ff00000 &&
|
||||||
(unsigned)ieee754.u == 0;
|
(unsigned)ieee754.u == 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
@ -193,12 +257,10 @@ CV_INLINE int cvRound(float value)
|
|||||||
fistp t;
|
fistp t;
|
||||||
}
|
}
|
||||||
return t;
|
return t;
|
||||||
|
#elif defined CV_INLINE_ROUND_FLT
|
||||||
|
CV_INLINE_ROUND_FLT(value);
|
||||||
#elif defined CV_ICC || defined __GNUC__
|
#elif defined CV_ICC || defined __GNUC__
|
||||||
# if defined ARM_ROUND_FLT
|
|
||||||
ARM_ROUND_FLT(value);
|
|
||||||
# else
|
|
||||||
return (int)lrintf(value);
|
return (int)lrintf(value);
|
||||||
# endif
|
|
||||||
#else
|
#else
|
||||||
/* it's ok if round does not comply with IEEE754 standard;
|
/* it's ok if round does not comply with IEEE754 standard;
|
||||||
the tests should allow +/-1 difference when the tested functions use round */
|
the tests should allow +/-1 difference when the tested functions use round */
|
||||||
@ -215,8 +277,12 @@ CV_INLINE int cvRound( int value )
|
|||||||
/** @overload */
|
/** @overload */
|
||||||
CV_INLINE int cvFloor( float value )
|
CV_INLINE int cvFloor( float value )
|
||||||
{
|
{
|
||||||
|
#if defined _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS
|
||||||
|
return __builtin_floorf(value);
|
||||||
|
#else
|
||||||
int i = (int)value;
|
int i = (int)value;
|
||||||
return i - (i > value);
|
return i - (i > value);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @overload */
|
/** @overload */
|
||||||
@ -228,8 +294,12 @@ CV_INLINE int cvFloor( int value )
|
|||||||
/** @overload */
|
/** @overload */
|
||||||
CV_INLINE int cvCeil( float value )
|
CV_INLINE int cvCeil( float value )
|
||||||
{
|
{
|
||||||
|
#if defined _OPENCV_FASTMATH_ENABLE_GCC_MATH_BUILTINS
|
||||||
|
return __builtin_ceilf(value);
|
||||||
|
#else
|
||||||
int i = (int)value;
|
int i = (int)value;
|
||||||
return i + (i < value);
|
return i + (i < value);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @overload */
|
/** @overload */
|
||||||
@ -241,17 +311,25 @@ CV_INLINE int cvCeil( int value )
|
|||||||
/** @overload */
|
/** @overload */
|
||||||
CV_INLINE int cvIsNaN( float value )
|
CV_INLINE int cvIsNaN( float value )
|
||||||
{
|
{
|
||||||
|
#if defined CV_INLINE_ISNAN_FLT
|
||||||
|
CV_INLINE_ISNAN_FLT(value);
|
||||||
|
#else
|
||||||
Cv32suf ieee754;
|
Cv32suf ieee754;
|
||||||
ieee754.f = value;
|
ieee754.f = value;
|
||||||
return (ieee754.u & 0x7fffffff) > 0x7f800000;
|
return (ieee754.u & 0x7fffffff) > 0x7f800000;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @overload */
|
/** @overload */
|
||||||
CV_INLINE int cvIsInf( float value )
|
CV_INLINE int cvIsInf( float value )
|
||||||
{
|
{
|
||||||
|
#if defined CV_INLINE_ISINF_FLT
|
||||||
|
CV_INLINE_ISINF_FLT(value);
|
||||||
|
#else
|
||||||
Cv32suf ieee754;
|
Cv32suf ieee754;
|
||||||
ieee754.f = value;
|
ieee754.f = value;
|
||||||
return (ieee754.u & 0x7fffffff) == 0x7f800000;
|
return (ieee754.u & 0x7fffffff) == 0x7f800000;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // __cplusplus
|
#endif // __cplusplus
|
||||||
|
@ -4,42 +4,52 @@ namespace opencv_test
|
|||||||
{
|
{
|
||||||
using namespace perf;
|
using namespace perf;
|
||||||
|
|
||||||
template <typename T>
|
#define DECL_ROUND_TEST(NAME, OP, EXTRA) \
|
||||||
static void CvRoundMat(const cv::Mat & src, cv::Mat & dst)
|
template <typename T> \
|
||||||
{
|
static void OP ## Mat(const cv::Mat & src, cv::Mat & dst) \
|
||||||
for (int y = 0; y < dst.rows; ++y)
|
{ \
|
||||||
{
|
for (int y = 0; y < dst.rows; ++y) \
|
||||||
const T * sptr = src.ptr<T>(y);
|
{ \
|
||||||
int * dptr = dst.ptr<int>(y);
|
const T * sptr = src.ptr<T>(y); \
|
||||||
|
int * dptr = dst.ptr<int>(y); \
|
||||||
for (int x = 0; x < dst.cols; ++x)
|
\
|
||||||
dptr[x] = cvRound(sptr[x]);
|
for (int x = 0; x < dst.cols; ++x) \
|
||||||
}
|
dptr[x] = OP(sptr[x]) EXTRA; \
|
||||||
}
|
} \
|
||||||
|
} \
|
||||||
PERF_TEST_P(Size_MatType, CvRound_Float,
|
\
|
||||||
testing::Combine(testing::Values(TYPICAL_MAT_SIZES),
|
PERF_TEST_P(Size_MatType, CvRound_Float ## NAME, \
|
||||||
testing::Values(CV_32FC1, CV_64FC1)))
|
testing::Combine(testing::Values(TYPICAL_MAT_SIZES), \
|
||||||
{
|
testing::Values(CV_32FC1, CV_64FC1))) \
|
||||||
Size size = get<0>(GetParam());
|
{ \
|
||||||
int type = get<1>(GetParam()), depth = CV_MAT_DEPTH(type);
|
Size size = get<0>(GetParam()); \
|
||||||
|
int type = get<1>(GetParam()), depth = CV_MAT_DEPTH(type); \
|
||||||
cv::Mat src(size, type), dst(size, CV_32SC1);
|
\
|
||||||
|
cv::Mat src(size, type), dst(size, CV_32SC1); \
|
||||||
declare.in(src, WARMUP_RNG).out(dst);
|
\
|
||||||
|
declare.in(src, WARMUP_RNG).out(dst); \
|
||||||
if (depth == CV_32F)
|
\
|
||||||
{
|
if (depth == CV_32F) \
|
||||||
TEST_CYCLE()
|
{ \
|
||||||
CvRoundMat<float>(src, dst);
|
TEST_CYCLE() \
|
||||||
}
|
OP ## Mat<float>(src, dst); \
|
||||||
else if (depth == CV_64F)
|
} \
|
||||||
{
|
else if (depth == CV_64F) \
|
||||||
TEST_CYCLE()
|
{ \
|
||||||
CvRoundMat<double>(src, dst);
|
TEST_CYCLE() \
|
||||||
|
OP ## Mat<double>(src, dst); \
|
||||||
|
} \
|
||||||
|
\
|
||||||
|
SANITY_CHECK_NOTHING(); \
|
||||||
}
|
}
|
||||||
|
|
||||||
SANITY_CHECK_NOTHING();
|
DECL_ROUND_TEST(,cvRound,)
|
||||||
}
|
DECL_ROUND_TEST(_Ceil,cvCeil,)
|
||||||
|
DECL_ROUND_TEST(_Floor,cvFloor,)
|
||||||
|
|
||||||
|
/* For FP classification tests, try to test them in way which uses
|
||||||
|
branching logic and avoids extra FP logic. */
|
||||||
|
DECL_ROUND_TEST(_NaN,cvIsNaN, ? 1 : 2)
|
||||||
|
DECL_ROUND_TEST(_Inf,cvIsInf, ? 1 : 2)
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
@ -3923,5 +3923,59 @@ TEST(Core_SoftFloat, CvRound)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
static void checkRounding(T in, int outCeil, int outFloor)
|
||||||
|
{
|
||||||
|
EXPECT_EQ(outCeil,cvCeil(in));
|
||||||
|
EXPECT_EQ(outFloor,cvFloor(in));
|
||||||
|
|
||||||
|
/* cvRound is not expected to be IEEE compliant. The implementation
|
||||||
|
should round to one of the above. */
|
||||||
|
EXPECT_TRUE((cvRound(in) == outCeil) || (cvRound(in) == outFloor));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(Core_FastMath, InlineRoundingOps)
|
||||||
|
{
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
double in;
|
||||||
|
int outCeil;
|
||||||
|
int outFloor;
|
||||||
|
} values[] =
|
||||||
|
{
|
||||||
|
// Values are chosen to convert to binary float 32/64 exactly
|
||||||
|
{ 1.0, 1, 1 },
|
||||||
|
{ 1.5, 2, 1 },
|
||||||
|
{ -1.5, -1, -2}
|
||||||
|
};
|
||||||
|
|
||||||
|
for (int i = 0, maxi = sizeof(values) / sizeof(values[0]); i < maxi; i++)
|
||||||
|
{
|
||||||
|
checkRounding<double>(values[i].in, values[i].outCeil, values[i].outFloor);
|
||||||
|
checkRounding<float>((float)values[i].in, values[i].outCeil, values[i].outFloor);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(Core_FastMath, InlineNaN)
|
||||||
|
{
|
||||||
|
EXPECT_EQ( cvIsNaN((float) NAN), 1);
|
||||||
|
EXPECT_EQ( cvIsNaN((float) -NAN), 1);
|
||||||
|
EXPECT_EQ( cvIsNaN(0.0f), 0);
|
||||||
|
EXPECT_EQ( cvIsNaN((double) NAN), 1);
|
||||||
|
EXPECT_EQ( cvIsNaN((double) -NAN), 1);
|
||||||
|
EXPECT_EQ( cvIsNaN(0.0), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(Core_FastMath, InlineIsInf)
|
||||||
|
{
|
||||||
|
// Assume HUGE_VAL is infinity. Strictly speaking, may not always be true.
|
||||||
|
EXPECT_EQ( cvIsInf((float) HUGE_VAL), 1);
|
||||||
|
EXPECT_EQ( cvIsInf((float) -HUGE_VAL), 1);
|
||||||
|
EXPECT_EQ( cvIsInf(0.0f), 0);
|
||||||
|
EXPECT_EQ( cvIsInf((double) HUGE_VAL), 1);
|
||||||
|
EXPECT_EQ( cvIsInf((double) -HUGE_VAL), 1);
|
||||||
|
EXPECT_EQ( cvIsInf(0.0), 0);
|
||||||
|
}
|
||||||
|
|
||||||
}} // namespace
|
}} // namespace
|
||||||
/* End of file. */
|
/* End of file. */
|
||||||
|
@ -1554,6 +1554,9 @@ if( ANDROID_EXPLICIT_CRT_LINK )
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# setup output directories
|
# setup output directories
|
||||||
|
if(NOT DEFINED CMAKE_INSTALL_PREFIX)
|
||||||
|
set(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT 1)
|
||||||
|
endif()
|
||||||
set( CMAKE_INSTALL_PREFIX "${ANDROID_TOOLCHAIN_ROOT}/user" CACHE STRING "path for installing" )
|
set( CMAKE_INSTALL_PREFIX "${ANDROID_TOOLCHAIN_ROOT}/user" CACHE STRING "path for installing" )
|
||||||
|
|
||||||
if( DEFINED LIBRARY_OUTPUT_PATH_ROOT
|
if( DEFINED LIBRARY_OUTPUT_PATH_ROOT
|
||||||
|
Loading…
Reference in New Issue
Block a user