Merge remote-tracking branch 'refs/remotes/upstream/master'
This commit is contained in:
commit
f148f23382
@ -161,7 +161,7 @@ OCV_OPTION(WITH_MSMF "Build VideoIO with Media Foundation support" OFF
|
|||||||
OCV_OPTION(WITH_XIMEA "Include XIMEA cameras support" OFF IF (NOT ANDROID) )
|
OCV_OPTION(WITH_XIMEA "Include XIMEA cameras support" OFF IF (NOT ANDROID) )
|
||||||
OCV_OPTION(WITH_XINE "Include Xine support (GPL)" OFF IF (UNIX AND NOT APPLE AND NOT ANDROID) )
|
OCV_OPTION(WITH_XINE "Include Xine support (GPL)" OFF IF (UNIX AND NOT APPLE AND NOT ANDROID) )
|
||||||
OCV_OPTION(WITH_CLP "Include Clp support (EPL)" OFF)
|
OCV_OPTION(WITH_CLP "Include Clp support (EPL)" OFF)
|
||||||
OCV_OPTION(WITH_OPENCL "Include OpenCL Runtime support" ON IF (NOT IOS) )
|
OCV_OPTION(WITH_OPENCL "Include OpenCL Runtime support" NOT ANDROID IF (NOT IOS) )
|
||||||
OCV_OPTION(WITH_OPENCL_SVM "Include OpenCL Shared Virtual Memory support" OFF ) # experimental
|
OCV_OPTION(WITH_OPENCL_SVM "Include OpenCL Shared Virtual Memory support" OFF ) # experimental
|
||||||
OCV_OPTION(WITH_OPENCLAMDFFT "Include AMD OpenCL FFT library support" ON IF (NOT ANDROID AND NOT IOS) )
|
OCV_OPTION(WITH_OPENCLAMDFFT "Include AMD OpenCL FFT library support" ON IF (NOT ANDROID AND NOT IOS) )
|
||||||
OCV_OPTION(WITH_OPENCLAMDBLAS "Include AMD OpenCL BLAS library support" ON IF (NOT ANDROID AND NOT IOS) )
|
OCV_OPTION(WITH_OPENCLAMDBLAS "Include AMD OpenCL BLAS library support" ON IF (NOT ANDROID AND NOT IOS) )
|
||||||
|
@ -35,5 +35,5 @@ if(INSTALL_CREATE_DISTRIB)
|
|||||||
install(TARGETS ${the_target} RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} CONFIGURATIONS Release COMPONENT dev)
|
install(TARGETS ${the_target} RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} CONFIGURATIONS Release COMPONENT dev)
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
install(TARGETS ${the_target} RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} COMPONENT dev)
|
install(TARGETS ${the_target} OPTIONAL RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} COMPONENT dev)
|
||||||
endif()
|
endif()
|
||||||
|
@ -35,5 +35,5 @@ if(INSTALL_CREATE_DISTRIB)
|
|||||||
install(TARGETS ${the_target} RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} CONFIGURATIONS Release COMPONENT dev)
|
install(TARGETS ${the_target} RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} CONFIGURATIONS Release COMPONENT dev)
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
install(TARGETS ${the_target} RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} COMPONENT dev)
|
install(TARGETS ${the_target} OPTIONAL RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} COMPONENT dev)
|
||||||
endif()
|
endif()
|
||||||
|
@ -37,6 +37,7 @@ ocv_list_reverse(OpenCV_EXTRA_COMPONENTS)
|
|||||||
#build the list of components
|
#build the list of components
|
||||||
set(OpenCV_LIB_COMPONENTS_ "")
|
set(OpenCV_LIB_COMPONENTS_ "")
|
||||||
foreach(CVLib ${OpenCV_LIB_COMPONENTS})
|
foreach(CVLib ${OpenCV_LIB_COMPONENTS})
|
||||||
|
if (TARGET ${CVLib})
|
||||||
get_target_property(libpath ${CVLib} LOCATION_${CMAKE_BUILD_TYPE})
|
get_target_property(libpath ${CVLib} LOCATION_${CMAKE_BUILD_TYPE})
|
||||||
get_filename_component(libname "${libpath}" NAME)
|
get_filename_component(libname "${libpath}" NAME)
|
||||||
|
|
||||||
@ -52,6 +53,7 @@ foreach(CVLib ${OpenCV_LIB_COMPONENTS})
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(OpenCV_LIB_COMPONENTS_ "${OpenCV_LIB_COMPONENTS_} \${exec_prefix}/${installDir}/${libname}")
|
set(OpenCV_LIB_COMPONENTS_ "${OpenCV_LIB_COMPONENTS_} \${exec_prefix}/${installDir}/${libname}")
|
||||||
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
# add extra dependencies required for OpenCV
|
# add extra dependencies required for OpenCV
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
# OPENCV_MODULE_${the_module}_PRIVATE_REQ_DEPS
|
# OPENCV_MODULE_${the_module}_PRIVATE_REQ_DEPS
|
||||||
# OPENCV_MODULE_${the_module}_PRIVATE_OPT_DEPS
|
# OPENCV_MODULE_${the_module}_PRIVATE_OPT_DEPS
|
||||||
# OPENCV_MODULE_${the_module}_IS_PART_OF_WORLD
|
# OPENCV_MODULE_${the_module}_IS_PART_OF_WORLD
|
||||||
|
# OPENCV_MODULE_${the_module}_CUDA_OBJECTS - compiled CUDA objects list
|
||||||
|
# OPENCV_MODULE_${the_module}_CHILDREN - list of submodules for compound modules
|
||||||
# HAVE_${the_module} - for fast check of module availability
|
# HAVE_${the_module} - for fast check of module availability
|
||||||
|
|
||||||
# To control the setup of the module you could also set:
|
# To control the setup of the module you could also set:
|
||||||
@ -26,6 +28,7 @@
|
|||||||
# OPENCV_MODULE_TYPE - STATIC|SHARED - set to force override global settings for current module
|
# OPENCV_MODULE_TYPE - STATIC|SHARED - set to force override global settings for current module
|
||||||
# OPENCV_MODULE_IS_PART_OF_WORLD - ON|OFF (default ON) - should the module be added to the opencv_world?
|
# OPENCV_MODULE_IS_PART_OF_WORLD - ON|OFF (default ON) - should the module be added to the opencv_world?
|
||||||
# BUILD_${the_module}_INIT - ON|OFF (default ON) - initial value for BUILD_${the_module}
|
# BUILD_${the_module}_INIT - ON|OFF (default ON) - initial value for BUILD_${the_module}
|
||||||
|
# OPENCV_MODULE_CHILDREN - list of submodules
|
||||||
|
|
||||||
# The verbose template for OpenCV module:
|
# The verbose template for OpenCV module:
|
||||||
#
|
#
|
||||||
@ -158,13 +161,9 @@ macro(ocv_add_module _name)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# add self to the world dependencies
|
# add self to the world dependencies
|
||||||
# add to world only extra modules (ON) or only main modules (OFF)
|
if((NOT DEFINED OPENCV_MODULE_IS_PART_OF_WORLD
|
||||||
set(__expected_extra 0)
|
AND NOT OPENCV_MODULE_${the_module}_CLASS STREQUAL "BINDINGS"
|
||||||
if (OPENCV_EXTRA_WORLD)
|
AND NOT OPENCV_PROCESSING_EXTRA_MODULES)
|
||||||
set(__expected_extra 1)
|
|
||||||
endif()
|
|
||||||
if((NOT DEFINED OPENCV_MODULE_IS_PART_OF_WORLD AND NOT OPENCV_MODULE_${the_module}_CLASS STREQUAL "BINDINGS"
|
|
||||||
AND __expected_extra EQUAL OPENCV_PROCESSING_EXTRA_MODULES)
|
|
||||||
OR OPENCV_MODULE_IS_PART_OF_WORLD
|
OR OPENCV_MODULE_IS_PART_OF_WORLD
|
||||||
)
|
)
|
||||||
set(OPENCV_MODULE_${the_module}_IS_PART_OF_WORLD ON CACHE INTERNAL "")
|
set(OPENCV_MODULE_${the_module}_IS_PART_OF_WORLD ON CACHE INTERNAL "")
|
||||||
@ -179,7 +178,8 @@ macro(ocv_add_module _name)
|
|||||||
set(OPENCV_MODULES_DISABLED_USER ${OPENCV_MODULES_DISABLED_USER} "${the_module}" CACHE INTERNAL "List of OpenCV modules explicitly disabled by user")
|
set(OPENCV_MODULES_DISABLED_USER ${OPENCV_MODULES_DISABLED_USER} "${the_module}" CACHE INTERNAL "List of OpenCV modules explicitly disabled by user")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# TODO: add submodules if any
|
# add submodules if any
|
||||||
|
set(OPENCV_MODULE_${the_module}_CHILDREN "${OPENCV_MODULE_CHILDREN}" CACHE INTERNAL "List of ${the_module} submodules")
|
||||||
|
|
||||||
# stop processing of current file
|
# stop processing of current file
|
||||||
return()
|
return()
|
||||||
@ -306,27 +306,42 @@ endfunction()
|
|||||||
# sort modules by dependencies
|
# sort modules by dependencies
|
||||||
function(__ocv_sort_modules_by_deps __lst)
|
function(__ocv_sort_modules_by_deps __lst)
|
||||||
ocv_list_sort(${__lst})
|
ocv_list_sort(${__lst})
|
||||||
set(${__lst}_ORDERED ${${__lst}} CACHE INTERNAL "")
|
set(input ${${__lst}})
|
||||||
set(__result "")
|
set(result "")
|
||||||
foreach (m ${${__lst}})
|
while(input)
|
||||||
list(LENGTH __result __lastindex)
|
list(LENGTH input length_before)
|
||||||
set(__index ${__lastindex})
|
foreach (m ${input})
|
||||||
foreach (__d ${__result})
|
# check if module is in the result already
|
||||||
set(__deps "${OPENCV_MODULE_${__d}_DEPS}")
|
if (NOT ";${result};" MATCHES ";${m};")
|
||||||
if(";${__deps};" MATCHES ";${m};")
|
# scan through module dependencies...
|
||||||
list(FIND __result "${__d}" __i)
|
set(unresolved_deps_found FALSE)
|
||||||
if(__i LESS "${__index}")
|
foreach (d ${OPENCV_MODULE_${m}_CHILDREN} ${OPENCV_MODULE_${m}_DEPS})
|
||||||
set(__index "${__i}")
|
# ... which are not already in the result and are enabled
|
||||||
|
if ((NOT ";${result};" MATCHES ";${d};") AND HAVE_${d})
|
||||||
|
set(unresolved_deps_found TRUE)
|
||||||
|
break()
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
# chek if all dependencies for this module has been resolved
|
||||||
|
if (NOT unresolved_deps_found)
|
||||||
|
list(APPEND result ${m})
|
||||||
|
list(REMOVE_ITEM input ${m})
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
if(__index STREQUAL __lastindex)
|
list(LENGTH input length_after)
|
||||||
list(APPEND __result "${m}")
|
# check for infinite loop or unresolved dependencies
|
||||||
else()
|
if (NOT length_after LESS length_before)
|
||||||
list(INSERT __result ${__index} "${m}")
|
message(WARNING "Unresolved dependencies or loop in dependency graph (${length_after})\n"
|
||||||
|
"Processed ${__lst}: ${${__lst}}\n"
|
||||||
|
"Good modules: ${result}\n"
|
||||||
|
"Bad modules: ${input}"
|
||||||
|
)
|
||||||
|
list(APPEND result ${input})
|
||||||
|
break()
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endwhile()
|
||||||
set(${__lst} "${__result}" PARENT_SCOPE)
|
set(${__lst} "${result}" PARENT_SCOPE)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
# resolve dependensies
|
# resolve dependensies
|
||||||
@ -645,13 +660,43 @@ macro(_ocv_create_module)
|
|||||||
get_native_precompiled_header(${the_module} precomp.hpp)
|
get_native_precompiled_header(${the_module} precomp.hpp)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(sub_objs "")
|
||||||
|
set(sub_links "")
|
||||||
|
set(cuda_objs "")
|
||||||
|
if (OPENCV_MODULE_${the_module}_CHILDREN)
|
||||||
|
status("Complex module ${the_module}")
|
||||||
|
foreach (m ${OPENCV_MODULE_${the_module}_CHILDREN})
|
||||||
|
if (BUILD_${m} AND TARGET ${m}_object) # ambigous?
|
||||||
|
get_target_property(_sub_links ${m} LINK_LIBRARIES)
|
||||||
|
list(APPEND sub_objs $<TARGET_OBJECTS:${m}_object>)
|
||||||
|
list(APPEND sub_links ${_sub_links})
|
||||||
|
status(" + ${m}")
|
||||||
|
else()
|
||||||
|
status(" - ${m}")
|
||||||
|
endif()
|
||||||
|
list(APPEND cuda_objs ${OPENCV_MODULE_${m}_CUDA_OBJECTS})
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
ocv_add_library(${the_module} ${OPENCV_MODULE_TYPE} ${OPENCV_MODULE_${the_module}_HEADERS} ${OPENCV_MODULE_${the_module}_SOURCES}
|
ocv_add_library(${the_module} ${OPENCV_MODULE_TYPE} ${OPENCV_MODULE_${the_module}_HEADERS} ${OPENCV_MODULE_${the_module}_SOURCES}
|
||||||
"${OPENCV_CONFIG_FILE_INCLUDE_DIR}/cvconfig.h" "${OPENCV_CONFIG_FILE_INCLUDE_DIR}/opencv2/opencv_modules.hpp"
|
"${OPENCV_CONFIG_FILE_INCLUDE_DIR}/cvconfig.h" "${OPENCV_CONFIG_FILE_INCLUDE_DIR}/opencv2/opencv_modules.hpp"
|
||||||
${${the_module}_pch})
|
${${the_module}_pch} ${sub_objs})
|
||||||
if(NOT the_module STREQUAL opencv_ts)
|
|
||||||
set_target_properties(${the_module} PROPERTIES COMPILE_DEFINITIONS OPENCV_NOSTL)
|
if (cuda_objs)
|
||||||
|
target_link_libraries(${the_module} ${cuda_objs})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# TODO: is it needed?
|
||||||
|
if (sub_links)
|
||||||
|
ocv_list_filterout(sub_links "^opencv_")
|
||||||
|
ocv_list_unique(sub_links)
|
||||||
|
target_link_libraries(${the_module} ${sub_links})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
unset(sub_objs)
|
||||||
|
unset(sub_links)
|
||||||
|
unset(cuda_objs)
|
||||||
|
|
||||||
ocv_target_link_libraries(${the_module} ${OPENCV_MODULE_${the_module}_DEPS_TO_LINK})
|
ocv_target_link_libraries(${the_module} ${OPENCV_MODULE_${the_module}_DEPS_TO_LINK})
|
||||||
ocv_target_link_libraries(${the_module} LINK_INTERFACE_LIBRARIES ${OPENCV_MODULE_${the_module}_DEPS_TO_LINK})
|
ocv_target_link_libraries(${the_module} LINK_INTERFACE_LIBRARIES ${OPENCV_MODULE_${the_module}_DEPS_TO_LINK})
|
||||||
ocv_target_link_libraries(${the_module} ${OPENCV_MODULE_${the_module}_DEPS_EXT} ${OPENCV_LINKER_LIBS} ${IPP_LIBS} ${ARGN})
|
ocv_target_link_libraries(${the_module} ${OPENCV_MODULE_${the_module}_DEPS_EXT} ${OPENCV_LINKER_LIBS} ${IPP_LIBS} ${ARGN})
|
||||||
@ -686,6 +731,7 @@ macro(_ocv_create_module)
|
|||||||
|
|
||||||
if((NOT DEFINED OPENCV_MODULE_TYPE AND BUILD_SHARED_LIBS)
|
if((NOT DEFINED OPENCV_MODULE_TYPE AND BUILD_SHARED_LIBS)
|
||||||
OR (DEFINED OPENCV_MODULE_TYPE AND OPENCV_MODULE_TYPE STREQUAL SHARED))
|
OR (DEFINED OPENCV_MODULE_TYPE AND OPENCV_MODULE_TYPE STREQUAL SHARED))
|
||||||
|
set_target_properties(${the_module} PROPERTIES COMPILE_DEFINITIONS CVAPI_EXPORTS)
|
||||||
set_target_properties(${the_module} PROPERTIES DEFINE_SYMBOL CVAPI_EXPORTS)
|
set_target_properties(${the_module} PROPERTIES DEFINE_SYMBOL CVAPI_EXPORTS)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -696,22 +742,37 @@ macro(_ocv_create_module)
|
|||||||
set_target_properties(${the_module} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:libc /DEBUG")
|
set_target_properties(${the_module} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:libc /DEBUG")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
ocv_install_target(${the_module} EXPORT OpenCVModules
|
ocv_install_target(${the_module} EXPORT OpenCVModules OPTIONAL
|
||||||
RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} COMPONENT libs
|
RUNTIME DESTINATION ${OPENCV_BIN_INSTALL_PATH} COMPONENT libs
|
||||||
LIBRARY DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT libs
|
LIBRARY DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT libs
|
||||||
ARCHIVE DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT dev
|
ARCHIVE DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT dev
|
||||||
)
|
)
|
||||||
|
|
||||||
|
foreach(m ${OPENCV_MODULE_${the_module}_CHILDREN} ${the_module})
|
||||||
# only "public" headers need to be installed
|
# only "public" headers need to be installed
|
||||||
if(OPENCV_MODULE_${the_module}_HEADERS AND ";${OPENCV_MODULES_PUBLIC};" MATCHES ";${the_module};")
|
if(OPENCV_MODULE_${m}_HEADERS AND ";${OPENCV_MODULES_PUBLIC};" MATCHES ";${m};")
|
||||||
foreach(hdr ${OPENCV_MODULE_${the_module}_HEADERS})
|
foreach(hdr ${OPENCV_MODULE_${m}_HEADERS})
|
||||||
string(REGEX REPLACE "^.*opencv2/" "opencv2/" hdr2 "${hdr}")
|
string(REGEX REPLACE "^.*opencv2/" "opencv2/" hdr2 "${hdr}")
|
||||||
if(NOT hdr2 MATCHES "opencv2/${the_module}/private.*" AND hdr2 MATCHES "^(opencv2/?.*)/[^/]+.h(..)?$" )
|
if(NOT hdr2 MATCHES "opencv2/${m}/private.*" AND hdr2 MATCHES "^(opencv2/?.*)/[^/]+.h(..)?$" )
|
||||||
install(FILES ${hdr} DESTINATION "${OPENCV_INCLUDE_INSTALL_PATH}/${CMAKE_MATCH_1}" COMPONENT dev)
|
install(FILES ${hdr} OPTIONAL DESTINATION "${OPENCV_INCLUDE_INSTALL_PATH}/${CMAKE_MATCH_1}" COMPONENT dev)
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
endif()
|
endif()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
_ocv_add_precompiled_headers(${the_module})
|
_ocv_add_precompiled_headers(${the_module})
|
||||||
|
|
||||||
|
if (TARGET ${the_module}_object)
|
||||||
|
# copy COMPILE_DEFINITIONS
|
||||||
|
get_target_property(main_defs ${the_module} COMPILE_DEFINITIONS)
|
||||||
|
if (main_defs)
|
||||||
|
set_target_properties(${the_module}_object PROPERTIES COMPILE_DEFINITIONS ${main_defs})
|
||||||
|
endif()
|
||||||
|
# use same PCH
|
||||||
|
if (TARGET pch_Generate_${the_module})
|
||||||
|
add_dependencies(${the_module}_object pch_Generate_${the_module} )
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
# opencv precompiled headers macro (can add pch to modules and tests)
|
# opencv precompiled headers macro (can add pch to modules and tests)
|
||||||
|
@ -756,6 +756,9 @@ endfunction()
|
|||||||
function(_ocv_append_target_includes target)
|
function(_ocv_append_target_includes target)
|
||||||
if(DEFINED OCV_TARGET_INCLUDE_DIRS_${target})
|
if(DEFINED OCV_TARGET_INCLUDE_DIRS_${target})
|
||||||
target_include_directories(${target} PRIVATE ${OCV_TARGET_INCLUDE_DIRS_${target}})
|
target_include_directories(${target} PRIVATE ${OCV_TARGET_INCLUDE_DIRS_${target}})
|
||||||
|
if (TARGET ${target}_object)
|
||||||
|
target_include_directories(${target}_object PRIVATE ${OCV_TARGET_INCLUDE_DIRS_${target}})
|
||||||
|
endif()
|
||||||
unset(OCV_TARGET_INCLUDE_DIRS_${target} CACHE)
|
unset(OCV_TARGET_INCLUDE_DIRS_${target} CACHE)
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
@ -780,8 +783,29 @@ function(ocv_add_library target)
|
|||||||
ocv_include_directories(${CUDA_INCLUDE_DIRS})
|
ocv_include_directories(${CUDA_INCLUDE_DIRS})
|
||||||
ocv_cuda_compile(cuda_objs ${lib_cuda_srcs} ${lib_cuda_hdrs})
|
ocv_cuda_compile(cuda_objs ${lib_cuda_srcs} ${lib_cuda_hdrs})
|
||||||
endif()
|
endif()
|
||||||
|
set(OPENCV_MODULE_${target}_CUDA_OBJECTS ${cuda_objs} CACHE INTERNAL "Compiled CUDA object files")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_library(${target} ${ARGN} ${cuda_objs})
|
add_library(${target} ${ARGN} ${cuda_objs})
|
||||||
|
|
||||||
|
# Add OBJECT library to use in compound modules
|
||||||
|
if (NOT OPENCV_MODULE_${target}_CHILDREN
|
||||||
|
AND NOT OPENCV_MODULE_${target}_CLASS STREQUAL "BINDINGS"
|
||||||
|
AND NOT ${target} STREQUAL "opencv_ts"
|
||||||
|
)
|
||||||
|
set(sources ${ARGN})
|
||||||
|
ocv_list_filterout(sources "\\\\.(cl|inc)$")
|
||||||
|
add_library(${target}_object OBJECT ${sources})
|
||||||
|
set_target_properties(${target}_object PROPERTIES
|
||||||
|
EXCLUDE_FROM_ALL True
|
||||||
|
EXCLUDE_FROM_DEFAULT_BUILD True
|
||||||
|
POSITION_INDEPENDENT_CODE True
|
||||||
|
)
|
||||||
|
if (ENABLE_SOLUTION_FOLDERS)
|
||||||
|
set_target_properties(${target}_object PROPERTIES FOLDER "object_libraries")
|
||||||
|
endif()
|
||||||
|
unset(sources)
|
||||||
|
endif()
|
||||||
|
|
||||||
_ocv_append_target_includes(${target})
|
_ocv_append_target_includes(${target})
|
||||||
endfunction()
|
endfunction()
|
||||||
|
@ -38,7 +38,7 @@ endif(HAVE_DOC_GENERATOR)
|
|||||||
|
|
||||||
if(BUILD_DOCS AND DOXYGEN_FOUND)
|
if(BUILD_DOCS AND DOXYGEN_FOUND)
|
||||||
# not documented modules list
|
# not documented modules list
|
||||||
list(APPEND blacklist "ts" "java" "python2" "python3" "world")
|
list(APPEND blacklist "ts" "java" "python2" "python3" "world" "contrib_world")
|
||||||
|
|
||||||
# gathering headers
|
# gathering headers
|
||||||
set(paths_include)
|
set(paths_include)
|
||||||
|
@ -46,7 +46,7 @@ get the following equation:
|
|||||||
|
|
||||||
where:
|
where:
|
||||||
|
|
||||||
\f[f_x = \frac{\partial f}{\partial x} \; ; \; f_y = \frac{\partial f}{\partial x}\f]\f[u = \frac{dx}{dt} \; ; \; v = \frac{dy}{dt}\f]
|
\f[f_x = \frac{\partial f}{\partial x} \; ; \; f_y = \frac{\partial f}{\partial y}\f]\f[u = \frac{dx}{dt} \; ; \; v = \frac{dy}{dt}\f]
|
||||||
|
|
||||||
Above equation is called Optical Flow equation. In it, we can find \f$f_x\f$ and \f$f_y\f$, they are image
|
Above equation is called Optical Flow equation. In it, we can find \f$f_x\f$ and \f$f_y\f$, they are image
|
||||||
gradients. Similarly \f$f_t\f$ is the gradient along time. But \f$(u,v)\f$ is unknown. We cannot solve this
|
gradients. Similarly \f$f_t\f$ is the gradient along time. But \f$(u,v)\f$ is unknown. We cannot solve this
|
||||||
|
@ -146,7 +146,7 @@ Explanation
|
|||||||
int result_cols = img.cols - templ.cols + 1;
|
int result_cols = img.cols - templ.cols + 1;
|
||||||
int result_rows = img.rows - templ.rows + 1;
|
int result_rows = img.rows - templ.rows + 1;
|
||||||
|
|
||||||
result.create( result_cols, result_rows, CV_32FC1 );
|
result.create( result_rows, result_cols, CV_32FC1 );
|
||||||
@endcode
|
@endcode
|
||||||
-# Perform the template matching operation:
|
-# Perform the template matching operation:
|
||||||
@code{.cpp}
|
@code{.cpp}
|
||||||
|
@ -66,7 +66,7 @@ void drawPoints(const std::vector<Point2f> &points, Mat &outImage, int radius =
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void CirclesGridClusterFinder::hierarchicalClustering(const std::vector<Point2f> points, const Size &patternSz, std::vector<Point2f> &patternPoints)
|
void CirclesGridClusterFinder::hierarchicalClustering(const std::vector<Point2f> &points, const Size &patternSz, std::vector<Point2f> &patternPoints)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_TEGRA_OPTIMIZATION
|
#ifdef HAVE_TEGRA_OPTIMIZATION
|
||||||
if(tegra::hierarchicalClustering(points, patternSz, patternPoints))
|
if(tegra::hierarchicalClustering(points, patternSz, patternPoints))
|
||||||
@ -135,7 +135,7 @@ void CirclesGridClusterFinder::hierarchicalClustering(const std::vector<Point2f>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CirclesGridClusterFinder::findGrid(const std::vector<cv::Point2f> points, cv::Size _patternSize, std::vector<Point2f>& centers)
|
void CirclesGridClusterFinder::findGrid(const std::vector<cv::Point2f> &points, cv::Size _patternSize, std::vector<Point2f>& centers)
|
||||||
{
|
{
|
||||||
patternSize = _patternSize;
|
patternSize = _patternSize;
|
||||||
centers.clear();
|
centers.clear();
|
||||||
|
@ -62,10 +62,10 @@ public:
|
|||||||
squareSize = 1.0f;
|
squareSize = 1.0f;
|
||||||
maxRectifiedDistance = (float)(squareSize / 2.0);
|
maxRectifiedDistance = (float)(squareSize / 2.0);
|
||||||
}
|
}
|
||||||
void findGrid(const std::vector<cv::Point2f> points, cv::Size patternSize, std::vector<cv::Point2f>& centers);
|
void findGrid(const std::vector<cv::Point2f> &points, cv::Size patternSize, std::vector<cv::Point2f>& centers);
|
||||||
|
|
||||||
//cluster 2d points by geometric coordinates
|
//cluster 2d points by geometric coordinates
|
||||||
void hierarchicalClustering(const std::vector<cv::Point2f> points, const cv::Size &patternSize, std::vector<cv::Point2f> &patternPoints);
|
void hierarchicalClustering(const std::vector<cv::Point2f> &points, const cv::Size &patternSize, std::vector<cv::Point2f> &patternPoints);
|
||||||
private:
|
private:
|
||||||
void findCorners(const std::vector<cv::Point2f> &hull2f, std::vector<cv::Point2f> &corners);
|
void findCorners(const std::vector<cv::Point2f> &hull2f, std::vector<cv::Point2f> &corners);
|
||||||
void findOutsideCorners(const std::vector<cv::Point2f> &corners, std::vector<cv::Point2f> &outsideCorners);
|
void findOutsideCorners(const std::vector<cv::Point2f> &corners, std::vector<cv::Point2f> &outsideCorners);
|
||||||
|
@ -872,8 +872,8 @@ double cv::fisheye::stereoCalibrate(InputArrayOfArrays objectPoints, InputArrayO
|
|||||||
|
|
||||||
if ((flags & CALIB_FIX_INTRINSIC))
|
if ((flags & CALIB_FIX_INTRINSIC))
|
||||||
{
|
{
|
||||||
internal::CalibrateExtrinsics(objectPoints, imagePoints1, intrinsicLeft, check_cond, thresh_cond, rvecs1, tvecs1);
|
cv::internal::CalibrateExtrinsics(objectPoints, imagePoints1, intrinsicLeft, check_cond, thresh_cond, rvecs1, tvecs1);
|
||||||
internal::CalibrateExtrinsics(objectPoints, imagePoints2, intrinsicRight, check_cond, thresh_cond, rvecs2, tvecs2);
|
cv::internal::CalibrateExtrinsics(objectPoints, imagePoints2, intrinsicRight, check_cond, thresh_cond, rvecs2, tvecs2);
|
||||||
}
|
}
|
||||||
|
|
||||||
intrinsicLeft.isEstimate[0] = flags & CALIB_FIX_INTRINSIC ? 0 : 1;
|
intrinsicLeft.isEstimate[0] = flags & CALIB_FIX_INTRINSIC ? 0 : 1;
|
||||||
@ -918,8 +918,8 @@ double cv::fisheye::stereoCalibrate(InputArrayOfArrays objectPoints, InputArrayO
|
|||||||
om_ref.reshape(3, 1).copyTo(om_list.col(image_idx));
|
om_ref.reshape(3, 1).copyTo(om_list.col(image_idx));
|
||||||
T_ref.reshape(3, 1).copyTo(T_list.col(image_idx));
|
T_ref.reshape(3, 1).copyTo(T_list.col(image_idx));
|
||||||
}
|
}
|
||||||
cv::Vec3d omcur = internal::median3d(om_list);
|
cv::Vec3d omcur = cv::internal::median3d(om_list);
|
||||||
cv::Vec3d Tcur = internal::median3d(T_list);
|
cv::Vec3d Tcur = cv::internal::median3d(T_list);
|
||||||
|
|
||||||
cv::Mat J = cv::Mat::zeros(4 * n_points * n_images, 18 + 6 * (n_images + 1), CV_64FC1),
|
cv::Mat J = cv::Mat::zeros(4 * n_points * n_images, 18 + 6 * (n_images + 1), CV_64FC1),
|
||||||
e = cv::Mat::zeros(4 * n_points * n_images, 1, CV_64FC1), Jkk, ekk;
|
e = cv::Mat::zeros(4 * n_points * n_images, 1, CV_64FC1), Jkk, ekk;
|
||||||
@ -961,7 +961,7 @@ double cv::fisheye::stereoCalibrate(InputArrayOfArrays objectPoints, InputArrayO
|
|||||||
jacobians.col(14).copyTo(Jkk.col(4).rowRange(0, 2 * n_points));
|
jacobians.col(14).copyTo(Jkk.col(4).rowRange(0, 2 * n_points));
|
||||||
|
|
||||||
//right camera jacobian
|
//right camera jacobian
|
||||||
internal::compose_motion(rvec, tvec, omcur, Tcur, omr, Tr, domrdomckk, domrdTckk, domrdom, domrdT, dTrdomckk, dTrdTckk, dTrdom, dTrdT);
|
cv::internal::compose_motion(rvec, tvec, omcur, Tcur, omr, Tr, domrdomckk, domrdTckk, domrdom, domrdT, dTrdomckk, dTrdTckk, dTrdom, dTrdT);
|
||||||
rvec = cv::Mat(rvecs2[image_idx]);
|
rvec = cv::Mat(rvecs2[image_idx]);
|
||||||
tvec = cv::Mat(tvecs2[image_idx]);
|
tvec = cv::Mat(tvecs2[image_idx]);
|
||||||
|
|
||||||
|
@ -817,7 +817,7 @@ Vec<_Tp, n> Matx<_Tp, m, n>::solve(const Vec<_Tp, m>& rhs, int method) const
|
|||||||
template<typename _Tp, int m> static inline
|
template<typename _Tp, int m> static inline
|
||||||
double determinant(const Matx<_Tp, m, m>& a)
|
double determinant(const Matx<_Tp, m, m>& a)
|
||||||
{
|
{
|
||||||
return internal::Matx_DetOp<_Tp, m>()(a);
|
return cv::internal::Matx_DetOp<_Tp, m>()(a);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp, int m, int n> static inline
|
template<typename _Tp, int m, int n> static inline
|
||||||
@ -960,25 +960,25 @@ Vec<_Tp, cn> Vec<_Tp, cn>::mul(const Vec<_Tp, cn>& v) const
|
|||||||
template<> inline
|
template<> inline
|
||||||
Vec<float, 2> Vec<float, 2>::conj() const
|
Vec<float, 2> Vec<float, 2>::conj() const
|
||||||
{
|
{
|
||||||
return internal::conjugate(*this);
|
return cv::internal::conjugate(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> inline
|
template<> inline
|
||||||
Vec<double, 2> Vec<double, 2>::conj() const
|
Vec<double, 2> Vec<double, 2>::conj() const
|
||||||
{
|
{
|
||||||
return internal::conjugate(*this);
|
return cv::internal::conjugate(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> inline
|
template<> inline
|
||||||
Vec<float, 4> Vec<float, 4>::conj() const
|
Vec<float, 4> Vec<float, 4>::conj() const
|
||||||
{
|
{
|
||||||
return internal::conjugate(*this);
|
return cv::internal::conjugate(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> inline
|
template<> inline
|
||||||
Vec<double, 4> Vec<double, 4>::conj() const
|
Vec<double, 4> Vec<double, 4>::conj() const
|
||||||
{
|
{
|
||||||
return internal::conjugate(*this);
|
return cv::internal::conjugate(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp, int cn> inline
|
template<typename _Tp, int cn> inline
|
||||||
|
@ -193,7 +193,7 @@ Matx<_Tp, n, m> Matx<_Tp, m, n>::inv(int method, bool *p_is_ok /*= NULL*/) const
|
|||||||
Matx<_Tp, n, m> b;
|
Matx<_Tp, n, m> b;
|
||||||
bool ok;
|
bool ok;
|
||||||
if( method == DECOMP_LU || method == DECOMP_CHOLESKY )
|
if( method == DECOMP_LU || method == DECOMP_CHOLESKY )
|
||||||
ok = internal::Matx_FastInvOp<_Tp, m>()(*this, b, method);
|
ok = cv::internal::Matx_FastInvOp<_Tp, m>()(*this, b, method);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Mat A(*this, false), B(b, false);
|
Mat A(*this, false), B(b, false);
|
||||||
@ -209,7 +209,7 @@ Matx<_Tp, n, l> Matx<_Tp, m, n>::solve(const Matx<_Tp, m, l>& rhs, int method) c
|
|||||||
Matx<_Tp, n, l> x;
|
Matx<_Tp, n, l> x;
|
||||||
bool ok;
|
bool ok;
|
||||||
if( method == DECOMP_LU || method == DECOMP_CHOLESKY )
|
if( method == DECOMP_LU || method == DECOMP_CHOLESKY )
|
||||||
ok = internal::Matx_FastSolveOp<_Tp, m, l>()(*this, rhs, x, method);
|
ok = cv::internal::Matx_FastSolveOp<_Tp, m, l>()(*this, rhs, x, method);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Mat A(*this, false), B(rhs, false), X(x, false);
|
Mat A(*this, false), B(rhs, false), X(x, false);
|
||||||
|
@ -914,7 +914,7 @@ void write(FileStorage& fs, const Range& r )
|
|||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write( FileStorage& fs, const std::vector<_Tp>& vec )
|
void write( FileStorage& fs, const std::vector<_Tp>& vec )
|
||||||
{
|
{
|
||||||
internal::VecWriterProxy<_Tp, DataType<_Tp>::fmt != 0> w(&fs);
|
cv::internal::VecWriterProxy<_Tp, DataType<_Tp>::fmt != 0> w(&fs);
|
||||||
w(vec);
|
w(vec);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -922,63 +922,63 @@ void write( FileStorage& fs, const std::vector<_Tp>& vec )
|
|||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Point_<_Tp>& pt )
|
void write(FileStorage& fs, const String& name, const Point_<_Tp>& pt )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, pt);
|
write(fs, pt);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Point3_<_Tp>& pt )
|
void write(FileStorage& fs, const String& name, const Point3_<_Tp>& pt )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, pt);
|
write(fs, pt);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Size_<_Tp>& sz )
|
void write(FileStorage& fs, const String& name, const Size_<_Tp>& sz )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, sz);
|
write(fs, sz);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Complex<_Tp>& c )
|
void write(FileStorage& fs, const String& name, const Complex<_Tp>& c )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, c);
|
write(fs, c);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Rect_<_Tp>& r )
|
void write(FileStorage& fs, const String& name, const Rect_<_Tp>& r )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, r);
|
write(fs, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp, int cn> static inline
|
template<typename _Tp, int cn> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Vec<_Tp, cn>& v )
|
void write(FileStorage& fs, const String& name, const Vec<_Tp, cn>& v )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, v);
|
write(fs, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write(FileStorage& fs, const String& name, const Scalar_<_Tp>& s )
|
void write(FileStorage& fs, const String& name, const Scalar_<_Tp>& s )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, s);
|
write(fs, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline
|
static inline
|
||||||
void write(FileStorage& fs, const String& name, const Range& r )
|
void write(FileStorage& fs, const String& name, const Range& r )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+FileNode::FLOW);
|
||||||
write(fs, r);
|
write(fs, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void write( FileStorage& fs, const String& name, const std::vector<_Tp>& vec )
|
void write( FileStorage& fs, const String& name, const std::vector<_Tp>& vec )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, name, FileNode::SEQ+(DataType<_Tp>::fmt != 0 ? FileNode::FLOW : 0));
|
cv::internal::WriteStructContext ws(fs, name, FileNode::SEQ+(DataType<_Tp>::fmt != 0 ? FileNode::FLOW : 0));
|
||||||
write(fs, vec);
|
write(fs, vec);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1030,7 +1030,7 @@ void read(const FileNode& node, short& value, short default_value)
|
|||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
void read( FileNodeIterator& it, std::vector<_Tp>& vec, size_t maxCount = (size_t)INT_MAX )
|
void read( FileNodeIterator& it, std::vector<_Tp>& vec, size_t maxCount = (size_t)INT_MAX )
|
||||||
{
|
{
|
||||||
internal::VecReaderProxy<_Tp, DataType<_Tp>::fmt != 0> r(&it);
|
cv::internal::VecReaderProxy<_Tp, DataType<_Tp>::fmt != 0> r(&it);
|
||||||
r(vec, maxCount);
|
r(vec, maxCount);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1101,7 +1101,7 @@ FileNodeIterator& operator >> (FileNodeIterator& it, _Tp& value)
|
|||||||
template<typename _Tp> static inline
|
template<typename _Tp> static inline
|
||||||
FileNodeIterator& operator >> (FileNodeIterator& it, std::vector<_Tp>& vec)
|
FileNodeIterator& operator >> (FileNodeIterator& it, std::vector<_Tp>& vec)
|
||||||
{
|
{
|
||||||
internal::VecReaderProxy<_Tp, DataType<_Tp>::fmt != 0> r(&it);
|
cv::internal::VecReaderProxy<_Tp, DataType<_Tp>::fmt != 0> r(&it);
|
||||||
r(vec, (size_t)INT_MAX);
|
r(vec, (size_t)INT_MAX);
|
||||||
return it;
|
return it;
|
||||||
}
|
}
|
||||||
|
@ -423,7 +423,7 @@ void AlgorithmInfo::write(const Algorithm* algo, FileStorage& fs) const
|
|||||||
cv::write(fs, pname, algo->get<std::vector<Mat> >(pname));
|
cv::write(fs, pname, algo->get<std::vector<Mat> >(pname));
|
||||||
else if( p.type == Param::ALGORITHM )
|
else if( p.type == Param::ALGORITHM )
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, pname, CV_NODE_MAP);
|
cv::internal::WriteStructContext ws(fs, pname, CV_NODE_MAP);
|
||||||
Ptr<Algorithm> nestedAlgo = algo->get<Algorithm>(pname);
|
Ptr<Algorithm> nestedAlgo = algo->get<Algorithm>(pname);
|
||||||
nestedAlgo->write(fs);
|
nestedAlgo->write(fs);
|
||||||
}
|
}
|
||||||
|
@ -136,7 +136,6 @@ namespace cv
|
|||||||
dprintf(("d first time\n"));print_matrix(d);
|
dprintf(("d first time\n"));print_matrix(d);
|
||||||
dprintf(("r\n"));print_matrix(r);
|
dprintf(("r\n"));print_matrix(r);
|
||||||
|
|
||||||
double beta=0;
|
|
||||||
for(int count=0;count<_termcrit.maxCount;count++){
|
for(int count=0;count<_termcrit.maxCount;count++){
|
||||||
minimizeOnTheLine(_Function,proxy_x,d,minimizeOnTheLine_buf1,minimizeOnTheLine_buf2);
|
minimizeOnTheLine(_Function,proxy_x,d,minimizeOnTheLine_buf1,minimizeOnTheLine_buf2);
|
||||||
r.copyTo(r_old);
|
r.copyTo(r_old);
|
||||||
@ -147,7 +146,7 @@ namespace cv
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
r_norm_sq=r_norm_sq*r_norm_sq;
|
r_norm_sq=r_norm_sq*r_norm_sq;
|
||||||
beta=MAX(0.0,(r_norm_sq-r.dot(r_old))/r_norm_sq);
|
double beta=MAX(0.0,(r_norm_sq-r.dot(r_old))/r_norm_sq);
|
||||||
d=r+beta*d;
|
d=r+beta*d;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5548,7 +5548,7 @@ void read( const FileNode& node, SparseMat& mat, const SparseMat& default_mat )
|
|||||||
|
|
||||||
void write(FileStorage& fs, const String& objname, const std::vector<KeyPoint>& keypoints)
|
void write(FileStorage& fs, const String& objname, const std::vector<KeyPoint>& keypoints)
|
||||||
{
|
{
|
||||||
internal::WriteStructContext ws(fs, objname, CV_NODE_SEQ + CV_NODE_FLOW);
|
cv::internal::WriteStructContext ws(fs, objname, CV_NODE_SEQ + CV_NODE_FLOW);
|
||||||
|
|
||||||
int i, npoints = (int)keypoints.size();
|
int i, npoints = (int)keypoints.size();
|
||||||
for( i = 0; i < npoints; i++ )
|
for( i = 0; i < npoints; i++ )
|
||||||
|
@ -106,11 +106,11 @@ void cv::cuda::calcNorm(InputArray _src, OutputArray dst, int normType, InputArr
|
|||||||
}
|
}
|
||||||
else if (normType == NORM_L2)
|
else if (normType == NORM_L2)
|
||||||
{
|
{
|
||||||
internal::normL2(src_single_channel, dst, mask, stream);
|
cv::cuda::internal::normL2(src_single_channel, dst, mask, stream);
|
||||||
}
|
}
|
||||||
else // NORM_INF
|
else // NORM_INF
|
||||||
{
|
{
|
||||||
internal::findMaxAbs(src_single_channel, dst, mask, stream);
|
cv::cuda::internal::findMaxAbs(src_single_channel, dst, mask, stream);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,6 +67,7 @@ public:
|
|||||||
areaThreshold = _area_threshold;
|
areaThreshold = _area_threshold;
|
||||||
minMargin = _min_margin;
|
minMargin = _min_margin;
|
||||||
edgeBlurSize = _edge_blur_size;
|
edgeBlurSize = _edge_blur_size;
|
||||||
|
pass2Only = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int delta;
|
int delta;
|
||||||
|
@ -120,5 +120,4 @@ void UIImageToMat(const UIImage* image,
|
|||||||
CGContextDrawImage(contextRef, CGRectMake(0, 0, cols, rows),
|
CGContextDrawImage(contextRef, CGRectMake(0, 0, cols, rows),
|
||||||
image.CGImage);
|
image.CGImage);
|
||||||
CGContextRelease(contextRef);
|
CGContextRelease(contextRef);
|
||||||
CGColorSpaceRelease(colorSpace);
|
|
||||||
}
|
}
|
||||||
|
@ -242,7 +242,7 @@ else(ANDROID)
|
|||||||
else(WIN32)
|
else(WIN32)
|
||||||
set(JAR_INSTALL_DIR share/OpenCV/java)
|
set(JAR_INSTALL_DIR share/OpenCV/java)
|
||||||
endif(WIN32)
|
endif(WIN32)
|
||||||
install(FILES ${JAR_FILE} DESTINATION ${JAR_INSTALL_DIR} COMPONENT java)
|
install(FILES ${JAR_FILE} OPTIONAL DESTINATION ${JAR_INSTALL_DIR} COMPONENT java)
|
||||||
endif(ANDROID)
|
endif(ANDROID)
|
||||||
|
|
||||||
# step 5: build native part
|
# step 5: build native part
|
||||||
@ -253,7 +253,6 @@ string(REPLACE "-fvisibility=hidden" "" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
|
|||||||
ocv_add_library(${the_module} SHARED ${handwrittren_h_sources} ${handwrittren_cpp_sources} ${generated_cpp_sources}
|
ocv_add_library(${the_module} SHARED ${handwrittren_h_sources} ${handwrittren_cpp_sources} ${generated_cpp_sources}
|
||||||
${copied_files}
|
${copied_files}
|
||||||
"${JAR_FILE}" "${JAR_FILE}.dephelper")
|
"${JAR_FILE}" "${JAR_FILE}.dephelper")
|
||||||
set_target_properties(${the_module} PROPERTIES COMPILE_DEFINITIONS OPENCV_NOSTL)
|
|
||||||
|
|
||||||
if(BUILD_FAT_JAVA_LIB)
|
if(BUILD_FAT_JAVA_LIB)
|
||||||
set(__deps ${OPENCV_MODULE_${the_module}_DEPS} ${OPENCV_MODULES_BUILD})
|
set(__deps ${OPENCV_MODULE_${the_module}_DEPS} ${OPENCV_MODULES_BUILD})
|
||||||
@ -312,16 +311,16 @@ if(ENABLE_SOLUTION_FOLDERS)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ANDROID)
|
if(ANDROID)
|
||||||
ocv_install_target(${the_module} EXPORT OpenCVModules
|
ocv_install_target(${the_module} OPTIONAL EXPORT OpenCVModules
|
||||||
LIBRARY DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT java
|
LIBRARY DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT java
|
||||||
ARCHIVE DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT java)
|
ARCHIVE DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT java)
|
||||||
else()
|
else()
|
||||||
if(NOT INSTALL_CREATE_DISTRIB)
|
if(NOT INSTALL_CREATE_DISTRIB)
|
||||||
ocv_install_target(${the_module} EXPORT OpenCVModules
|
ocv_install_target(${the_module} OPTIONAL EXPORT OpenCVModules
|
||||||
RUNTIME DESTINATION ${JAR_INSTALL_DIR} COMPONENT java
|
RUNTIME DESTINATION ${JAR_INSTALL_DIR} COMPONENT java
|
||||||
LIBRARY DESTINATION ${JAR_INSTALL_DIR} COMPONENT java)
|
LIBRARY DESTINATION ${JAR_INSTALL_DIR} COMPONENT java)
|
||||||
else()
|
else()
|
||||||
ocv_install_target(${the_module} EXPORT OpenCVModules
|
ocv_install_target(${the_module} OPTIONAL EXPORT OpenCVModules
|
||||||
RUNTIME DESTINATION ${JAR_INSTALL_DIR}/${OpenCV_ARCH} COMPONENT java
|
RUNTIME DESTINATION ${JAR_INSTALL_DIR}/${OpenCV_ARCH} COMPONENT java
|
||||||
LIBRARY DESTINATION ${JAR_INSTALL_DIR}/${OpenCV_ARCH} COMPONENT java)
|
LIBRARY DESTINATION ${JAR_INSTALL_DIR}/${OpenCV_ARCH} COMPONENT java)
|
||||||
endif()
|
endif()
|
||||||
|
@ -140,7 +140,6 @@ void runHaarClassifier(
|
|||||||
int dy = i/SUM_BUF_STEP, dx = i - dy*SUM_BUF_STEP;
|
int dy = i/SUM_BUF_STEP, dx = i - dy*SUM_BUF_STEP;
|
||||||
vstore4(vload4(0, psum0 + mad24(dy, sumstep, dx)), 0, ibuf+i);
|
vstore4(vload4(0, psum0 + mad24(dy, sumstep, dx)), 0, ibuf+i);
|
||||||
}
|
}
|
||||||
barrier(CLK_LOCAL_MEM_FENCE);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( lidx == 0 )
|
if( lidx == 0 )
|
||||||
|
@ -20,6 +20,7 @@ ocv_list_filterout(candidate_deps "^opencv_adas$")
|
|||||||
ocv_list_filterout(candidate_deps "^opencv_tracking$")
|
ocv_list_filterout(candidate_deps "^opencv_tracking$")
|
||||||
ocv_list_filterout(candidate_deps "^opencv_bioinspired$")
|
ocv_list_filterout(candidate_deps "^opencv_bioinspired$")
|
||||||
ocv_list_filterout(candidate_deps "^opencv_java$")
|
ocv_list_filterout(candidate_deps "^opencv_java$")
|
||||||
|
ocv_list_filterout(candidate_deps "^opencv_contrib_world$")
|
||||||
|
|
||||||
ocv_add_module(${MODULE_NAME} BINDINGS OPTIONAL ${candidate_deps})
|
ocv_add_module(${MODULE_NAME} BINDINGS OPTIONAL ${candidate_deps})
|
||||||
|
|
||||||
@ -57,7 +58,6 @@ add_custom_command(
|
|||||||
DEPENDS ${opencv_hdrs})
|
DEPENDS ${opencv_hdrs})
|
||||||
|
|
||||||
ocv_add_library(${the_module} SHARED ${PYTHON_SOURCE_DIR}/src2/cv2.cpp ${cv2_generated_hdrs})
|
ocv_add_library(${the_module} SHARED ${PYTHON_SOURCE_DIR}/src2/cv2.cpp ${cv2_generated_hdrs})
|
||||||
set_target_properties(${the_module} PROPERTIES COMPILE_DEFINITIONS OPENCV_NOSTL)
|
|
||||||
|
|
||||||
if(PYTHON_DEBUG_LIBRARIES AND NOT PYTHON_LIBRARIES MATCHES "optimized.*debug")
|
if(PYTHON_DEBUG_LIBRARIES AND NOT PYTHON_LIBRARIES MATCHES "optimized.*debug")
|
||||||
ocv_target_link_libraries(${the_module} debug ${PYTHON_DEBUG_LIBRARIES} optimized ${PYTHON_LIBRARIES})
|
ocv_target_link_libraries(${the_module} debug ${PYTHON_DEBUG_LIBRARIES} optimized ${PYTHON_LIBRARIES})
|
||||||
@ -113,7 +113,7 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT INSTALL_CREATE_DISTRIB)
|
if(NOT INSTALL_CREATE_DISTRIB)
|
||||||
install(TARGETS ${the_module}
|
install(TARGETS ${the_module} OPTIONAL
|
||||||
${PYTHON_INSTALL_CONFIGURATIONS}
|
${PYTHON_INSTALL_CONFIGURATIONS}
|
||||||
RUNTIME DESTINATION ${PYTHON_PACKAGES_PATH} COMPONENT python
|
RUNTIME DESTINATION ${PYTHON_PACKAGES_PATH} COMPONENT python
|
||||||
LIBRARY DESTINATION ${PYTHON_PACKAGES_PATH} COMPONENT python
|
LIBRARY DESTINATION ${PYTHON_PACKAGES_PATH} COMPONENT python
|
||||||
|
@ -544,6 +544,9 @@ Mat MotionEstimatorL1::estimate(InputArray points0, InputArray points1, bool *ok
|
|||||||
|
|
||||||
CV_Assert(motionModel() <= MM_AFFINE && motionModel() != MM_RIGID);
|
CV_Assert(motionModel() <= MM_AFFINE && motionModel() != MM_RIGID);
|
||||||
|
|
||||||
|
if(npoints <= 0)
|
||||||
|
return Mat::eye(3, 3, CV_32F);
|
||||||
|
|
||||||
// prepare LP problem
|
// prepare LP problem
|
||||||
|
|
||||||
const Point2f *points0_ = points0.getMat().ptr<Point2f>();
|
const Point2f *points0_ = points0.getMat().ptr<Point2f>();
|
||||||
|
@ -52,7 +52,6 @@ def build_opencv(srcroot, buildroot, target, arch):
|
|||||||
cmakeargs = ("-GXcode " +
|
cmakeargs = ("-GXcode " +
|
||||||
"-DCMAKE_BUILD_TYPE=Release " +
|
"-DCMAKE_BUILD_TYPE=Release " +
|
||||||
"-DCMAKE_TOOLCHAIN_FILE=%s/platforms/ios/cmake/Toolchains/Toolchain-%s_Xcode.cmake " +
|
"-DCMAKE_TOOLCHAIN_FILE=%s/platforms/ios/cmake/Toolchains/Toolchain-%s_Xcode.cmake " +
|
||||||
"-DBUILD_opencv_world=ON " +
|
|
||||||
"-DCMAKE_C_FLAGS=\"-Wno-implicit-function-declaration\" " +
|
"-DCMAKE_C_FLAGS=\"-Wno-implicit-function-declaration\" " +
|
||||||
"-DCMAKE_INSTALL_PREFIX=install") % (srcroot, target)
|
"-DCMAKE_INSTALL_PREFIX=install") % (srcroot, target)
|
||||||
|
|
||||||
@ -60,7 +59,13 @@ def build_opencv(srcroot, buildroot, target, arch):
|
|||||||
cmakeargs += " -DENABLE_NEON=ON"
|
cmakeargs += " -DENABLE_NEON=ON"
|
||||||
|
|
||||||
if opencv_contrib_path is not None:
|
if opencv_contrib_path is not None:
|
||||||
cmakeargs += " -DOPENCV_EXTRA_MODULES_PATH=%s -DOPENCV_EXTRA_WORLD=ON" % opencv_contrib_path
|
cmakeargs += " -DCMAKE_SKIP_INSTALL_ALL_DEPENDENCY=ON -DOPENCV_EXTRA_MODULES_PATH=%s -DBUILD_opencv_contrib_world=ON" % opencv_contrib_path
|
||||||
|
build_target = "opencv_contrib_world"
|
||||||
|
libname = "libopencv_contrib_world.a"
|
||||||
|
else:
|
||||||
|
cmakeargs += " -DBUILD_opencv_world=ON"
|
||||||
|
build_target = "ALL_BUILD"
|
||||||
|
libname = "libopencv_world.a"
|
||||||
|
|
||||||
# if cmake cache exists, just rerun cmake to update OpenCV.xcodeproj if necessary
|
# if cmake cache exists, just rerun cmake to update OpenCV.xcodeproj if necessary
|
||||||
if os.path.isfile(os.path.join(builddir, "CMakeCache.txt")):
|
if os.path.isfile(os.path.join(builddir, "CMakeCache.txt")):
|
||||||
@ -68,12 +73,12 @@ def build_opencv(srcroot, buildroot, target, arch):
|
|||||||
else:
|
else:
|
||||||
execute("cmake %s %s" % (cmakeargs, srcroot))
|
execute("cmake %s %s" % (cmakeargs, srcroot))
|
||||||
|
|
||||||
for wlib in [builddir + "/modules/world/UninstalledProducts/libopencv_world.a",
|
for wlib in [builddir + "/modules/world/UninstalledProducts/" + libname,
|
||||||
builddir + "/lib/Release/libopencv_world.a"]:
|
builddir + "/lib/Release/" + libname]:
|
||||||
if os.path.isfile(wlib):
|
if os.path.isfile(wlib):
|
||||||
os.remove(wlib)
|
os.remove(wlib)
|
||||||
|
|
||||||
execute("xcodebuild IPHONEOS_DEPLOYMENT_TARGET=6.0 -parallelizeTargets ARCHS=%s -jobs 8 -sdk %s -configuration Release -target ALL_BUILD" % (arch, target.lower()))
|
execute("xcodebuild IPHONEOS_DEPLOYMENT_TARGET=6.0 -parallelizeTargets ARCHS=%s -jobs 8 -sdk %s -configuration Release -target %s" % (arch, target.lower(), build_target))
|
||||||
execute("xcodebuild IPHONEOS_DEPLOYMENT_TARGET=6.0 ARCHS=%s -sdk %s -configuration Release -target install install" % (arch, target.lower()))
|
execute("xcodebuild IPHONEOS_DEPLOYMENT_TARGET=6.0 ARCHS=%s -sdk %s -configuration Release -target install install" % (arch, target.lower()))
|
||||||
os.chdir(currdir)
|
os.chdir(currdir)
|
||||||
|
|
||||||
@ -81,6 +86,7 @@ def put_framework_together(srcroot, dstroot):
|
|||||||
"constructs the framework directory after all the targets are built"
|
"constructs the framework directory after all the targets are built"
|
||||||
|
|
||||||
name = "opencv2" if opencv_contrib_path is None else "opencv2_contrib"
|
name = "opencv2" if opencv_contrib_path is None else "opencv2_contrib"
|
||||||
|
libname = "libopencv_world.a" if opencv_contrib_path is None else "libopencv_contrib_world.a"
|
||||||
|
|
||||||
# find the list of targets (basically, ["iPhoneOS", "iPhoneSimulator"])
|
# find the list of targets (basically, ["iPhoneOS", "iPhoneSimulator"])
|
||||||
targetlist = glob.glob(os.path.join(dstroot, "build", "*"))
|
targetlist = glob.glob(os.path.join(dstroot, "build", "*"))
|
||||||
@ -103,7 +109,7 @@ def put_framework_together(srcroot, dstroot):
|
|||||||
shutil.copytree(tdir0 + "/install/include/opencv2", dstdir + "/Headers")
|
shutil.copytree(tdir0 + "/install/include/opencv2", dstdir + "/Headers")
|
||||||
|
|
||||||
# make universal static lib
|
# make universal static lib
|
||||||
wlist = " ".join(["../build/" + t + "/lib/Release/libopencv_world.a" for t in targetlist])
|
wlist = " ".join(["../build/" + t + "/lib/Release/" + libname for t in targetlist])
|
||||||
execute("lipo -create " + wlist + " -o " + dstdir + "/%s" % name)
|
execute("lipo -create " + wlist + " -o " + dstdir + "/%s" % name)
|
||||||
|
|
||||||
# copy Info.plist
|
# copy Info.plist
|
||||||
|
Loading…
x
Reference in New Issue
Block a user