同步操作将从 10km/feature_se 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
(人脸)特征内存搜索引擎(feature search engine),提供高速的人脸特征相似度比对搜索/排序,支持多线程并行搜索,适用于百万级以上人脸库的快速搜索。(C++11实现)
git clone --recursive https://gitee.com/l0km/feature_se.git
# 因为项目中有submodule,克隆代码时必须加上 --recursive 参数
实现在内存中进行大规模特征比对的人脸搜索功能。
人脸搜索引擎的核心是一个允许并发读写的自定义哈希表(参见 hashtable_abstract.h,ICodeManagerCPU.cpp),特征搜索过程是就是对哈希表中的(人脸)特征多线程分段比对排序/合并结果(类似map/reduce)的过程。
大规模人脸搜索的速度最终取决于人脸识别算法提供的比对函数的计算速度和服务器内存读写速度。本库提供的搜索算法将所有的特征加载到内存,完全基于内存比对,最大限度减少了比对函数之外的运行时间开销,基于CASSDK人脸识别算法在500万条记录的环境下,(24核处理器)搜索速度在0.1~0.2秒。
当前项目支持CASSDK人脸识别算法,但是搜索算法本身已经高度抽象,独立于人脸识别算法,如果需要支持其他人脸识别算法,只需要替换对应的特征比对函数即可,参见:
feature_se/feature_compare_cas.h
cmake生成的工程文件可以同时生成动态库(fse_cas),静态库(fse_cas_static)。windows下还提供不依赖msvcrt.dll的MT静态库(fse_cas_static_mt)。
参见cmake脚本:feature_se/CMakeLists.txt
接口描述
标准C接口,参见 feature_se/feature_se.h
feature_se的jni接口动态库实现,提供java访问能力。
jni接口定义参见jni/net_gdface_sdk_fse_FseJniBridge.h
对应的java接口定义参见java.net.gdface.sdk.fse.FseJniBridge.java
要求cmake 3.0以上版本
要求第三方库:CASSDK 8.0.0 人脸识别算法库(商业产品,需要另外购买)
window下编译要求Visual Studio 2015
Windows下命令行编译过程:
rem 清除 build 文件夹
if exist build rmdir build /s/q
mkdir build
cd build
rem 创建VS2015编译环境,只需要执行一次
call "%VS140COMNTOOLS%..\..\vc/vcvarsall" x86_amd64
rem 生成Makefile
cmake -G "NMake Makefiles" ^
-DCMAKE_BUILD_TYPE=RELEASE ^
-DCASSDK_ROOT_DIR=%CASSDK算法SDK安装位置% ^
-DCMAKE_INSTALL_PREFIX=..\release\fse_windows_x86_64 ..
rem 编译并安装到CMAKE_INSTALL_PREFIX指定的位置
nmake install
参见编译脚本:build.bat
可以用 make_msvc_project.bat 创建Visuao Studio 2015工程
linux下编译要求支持c++11的gcc 5.2.0
linux下命令行编译过程:
# 清除 build 文件夹
if [ -d build ]
then
rm -fr build/*
else
mkdir build
fi
pushd build
# 生成release 版 Makefile
cmake -G "Unix Makefiles" -DCMAKE_BUILD_TYPE=RELEASE \
-DCASSDK_ROOT_DIR=${CASSDK算法SDK安装位置} \
-DCMAKE_INSTALL_PREFIX=../release/fse_linux_x86_64 ..
# 编译并安装到CMAKE_INSTALL_PREFIX指定的位置
make install
popd
参见编译脚本 build.sh
cmake查找feature_se库的示例:
# 调用cmake/Modules/FindFse.cmake查找fse依赖库
# 需要在 CMAKE_MODULE_PATH 指定 FindFse.cmake的位置
find_package(Fse REQUIRED)
cmake脚本中引用feature_se库的示例:
# 引用fse_cas动态库
target_link_libraries(test_fse gdface::fse_cas)
# 引用fse_cas静态库
target_link_libraries(test_fse_static gdface::fse_cas_static)
# 引用fse_cas静态库/MT
target_link_libraries(test_fse_static_mt gdface::fse_cas_static_mt)
cmake脚本中引用feature_se库的完整示例参见 test/CMakeLists.txt
创建调用示例的VS2015工程:
mkdir build
cd build
call "%VS140COMNTOOLS%..\..\vc/vcvarsall" x86_amd64
rem 生成64位工程
cmake -G "Visual Studio 14 2015 Win64" ^
-DCASSDK_ROOT_DIR=%CASSDK算法SDK安装位置% ^
-DFSE_ROOT_DIR=..\..\release\fse_windows_x86_64 ..
rem 需要先编译feature_se
rem FSE_ROOT_DIR用于指定 feature_se 安装位置
完整脚本参见 test/make_msvc_project.bat
生成unix Makefile过程参见: test/make_unix_makefile.sh
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。