资讯专栏INFORMATION COLUMN

虹软人脸识别 - ArcFace SDK介绍及使用注意事项

eternalshallow / 2644人阅读

摘要:引擎的多线程使用单个引擎的同一功能模块中的算法功能函数不支持多线程调用,且调用过程中不能进行销毁。若需多线程调用,需要创建多个引擎。

很多朋友在开发人脸识别系统的时候,会遇到各种各样的问题,现在我们以安卓平台使用虹软的免费离线人脸识别SDK开发为例,给大家介绍一下如何开发一个带有图片的人脸检测、视频画面的人脸属性检测、人脸注册识别等功能的人脸识别系统。

一、获取SDK 1.进入ArcFace2.0的申请地址

https://ai.arcsoft.com.cn/product/arcface.html

2.填写信息申请并提交

申请通过后即可下载SDK,查看APP_ID和SDK_KEY


二、SDK功能介绍

虹软ArcFace 2.0 Android SDK包含人脸检测、年龄信息检测、性别信息检测、人脸三维角度检测、活体检测、人脸特征提取、人脸特征比对功能。SDK还支持静态图模式的检测方式和视频流模式的检测方式。



三、使用SDK 1. 工程配置

将jar文件和so文件放到对应目录,并将jar添加至工程依赖


2. 激活引擎
FaceEngine faceEngine = new FaceEngine();

//激活方法首次调用有网络和文件操作,后续只有文件操作,建议不要放在主线程中进行

int activeCode = faceEngine.active(SettingsActivity.this, Constants.APP_ID, Constants.SDK_KEY);

if (activeCode == ErrorInfo.MOK || activeCode == ErrorInfo.MERR_ASF_ALREADY_ACTIVATED) {

    //激活成功或者已激活过的情况

}else{

    //激活失败的情况

}
3. 初始化引擎,推荐在启动时执行
faceEngine = new FaceEngine();

int afCode = faceEngine.init(context.getApplicationContext(), FaceEngine.ASF_DETECT_MODE_VIDEO, FaceEngine.ASF_OP_0_HIGHER_EXT,

        16, 10, FaceEngine.ASF_FACE_RECOGNITION | FaceEngine.ASF_FACE_DETECT | FaceEngine.ASF_FACE3DANGLE|....);

if (afCode != ErrorInfo.MOK) {

    //初始化成功

}else{

    //初始化失败

}
4. 人脸检测
List faceInfoList = new ArrayList<>();

int code = faceEngine.detectFaces(nv21, width, height, FaceEngine.CP_PAF_NV21, faceInfoList);

if (code == ErrorInfo.MOK && faceInfoList.size() >0) {

    //人脸检测成功并且检测到了人脸的情况

}else{

    //人脸检测失败或未检测到人脸的情况

}
5. 特征提取
FaceFeature faceFeature = new FaceFeature();

int code = faceEngine.extractFaceFeature(nv21, width, height, FaceEngine.CP_PAF_NV21, faceInfo, faceFeature);

if (code == ErrorInfo.MOK) {

    //特征提取成功

}else{

    //特征提取失败,可根据code查看原因

}
6. 特征比对
public void compareFace(FaceFeature faceFeature1,FaceFeature faceFeature2){

    FaceSimilar faceSimilar = new FaceSimilar();

    int code = faceEngine.compareFaceFeature(faceFeature1, faceFeature2, faceSimilar);

    if (code == ErrorInfo.MOK){

        //比对成功,可查看faceSimilar中的相似度

    }else{

        //比对失败,可根据code查看原因

    }

}
7. 活体、人脸三维角度、年龄、性别检测
int faceProcessCode = faceEngine.process(nv21, width, height, FaceEngine.CP_PAF_NV21, faceInfoList, FaceEngine.ASF_AGE | FaceEngine.ASF_GENDER | FaceEngine.ASF_FACE3DANGLE | FaceEngine.ASF_LIVENESS);

if (faceProcessCode != ErrorInfo.MOK){

    //失败的情况

}else{

    //process成功,可获取结果

    List ageInfoList = new ArrayList<>();

    List genderInfoList = new ArrayList<>();

    List face3DAngleList = new ArrayList<>();

    List faceLivenessInfoList = new ArrayList<>();

    int ageCode = faceEngine.getAge(ageInfoList);

    int genderCode = faceEngine.getGender(genderInfoList);

    int face3DAngleCode = faceEngine.getFace3DAngle(face3DAngleList);

    int livenessCode = faceEngine.getLiveness(faceLivenessInfoList);

    //错误码校验,判断是否全部成功

    if ((ageCode | genderCode | face3DAngleCode | livenessCode) != ErrorInfo.MOK) {

        return;

    }else{

        //全部检测成功,可从ageInfoList ,genderInfoList ,face3DAngleList ,faceLivenessInfoList 中获取检测结果

    }

}
8. 销毁引擎,推荐在退出时执行
if (faceEngine != null) {

  int faceEngineCode = faceEngine.unInit();

  Log.i(TAG, "unInitEngine: " + faceEngineCode);

}


四、注意事项 1.检测模式的选择

引擎的初始化中需要传入检测模式( 视频流模式图片模式 ),除了识别功能模块(extractFaceFeaturecompareFaceFeature)的其他功能都是有检测模式区分的,对于人脸检测、年龄检测、性别检测、人脸三维角度、活体检测,使用视频流模式处理速度更快。但是视频流模式的活体检测比较特殊:虽然处理后马上能获取结果,但是一段视频流的首帧传入后返回的值为未知,在一段时间后开始拿到的值才是真正的算法结果。

2.引擎的多线程使用

单个引擎的同一功能模块中的算法功能函数不支持多线程调用,且调用过程中不能进行销毁。若需多线程调用,需要创建多个引擎。

举几个例子:

线程1进行人脸检测(detectFaces)可以线程2同时进行特征解析(extractFaceFeature)

线程1进行人脸检测(detectFaces)不可以线程2同时进行人脸检测(detectFaces)

线程1进行特征解析(extractFaceFeature)不可以线程2同时进行销毁(unInit)

3.运行时报java.lang.UnsatisfiedLinkError

java.lang.UnsatisfiedLinkError是很常见的jni相关错误,若出现该错误,原因一般有以下几种:

Android工程目录下动态库文件目录下相关动态库不全或动态库文件目录下有多个ABI子目录,但是子目录中的文件列表不同

详细介绍:
首先,应用安装到设备时,只有该设备的CPU架构支持的最优so库才会被拷贝到本地lib中。例如某个工程的本地库目录中,armeabi-v7下包含四个动态库文件:a.so,b.so,c.so,d.soarm64-v8a下包含两个动态库文件:c.so,d.so。某台设备支持arm64-v8aarm64-v8a优于armeabi-v7,于是在安装时只拷贝了arm64-v8a目录下的so文件,加载c.so,d.so时并没有问题,但是在加载a.sob.so时,由于arm64-v8a目录下无这些文件,就会报java.lang.UnsatisfiedLinkError
以下是动态库文件存放的一些可能情况:

解决方案:
如果未在build.gradle中重新指定动态库的目录,那么动态库的默认路径将是:projectName->moduleName->src->main->jniLibs。
确保动态库目录下的armeabi-v7a目录或兼容armeabi-v7a的目录包含ArcFace 2.0 Android SDK相关的动态库文件,且每个ABI目录下的文件名称列表相同。

动态库文件虽然成功加载,但是找不到对应的native方法

详细介绍:
例如在com.arcsoft.Test类中有一个方法定义为:
private native int add(int a,int b)
而在编写C++代码时对应的内容为:
extern "C" JNIEXPORT jint JNICALL Java_com_arcsoft_Test_add(JNIEnv *env, jobject, jint a, jint b, jint c)
native定义的方法多了一个参数,对应的Java方法将是private native int add(int a, int b, int c),两者的方法签名不一致,因此在Java中调用add时将找不到native对应的方法。

解决方案:
一般在使用SDK时候若产生这一问题都是用了不同版本或不同平台下的jar或动态库,为了确保方法签名一致,请确认jar和动态库文件是相同平台相同版本中的文件。

在Java中定义了相关的native方法,但是未加载动态库文件

详细介绍:
例如在com.arcsoft.Test类中有一个方法定义为:
private native int add(int a,int b)
而对应的C++代码中有一个方法为:
extern "C" JNIEXPORT jint JNICALL Java_com_arcsoft_Test_add(JNIEnv *env, jobject, jint a, jint b),但是却一直无法加载,则也可能是没有加载动态库才导致无法找到native方法。

解决方案:
在调用so文件前需要加载动态库,一般在类的一个静态代码块中调用。


参考文档: Android平台开发指南:

https://ai.arcsoft.com.cn/man...

API接口说明

http://ai.arcsoft.com.cn/stat...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/14884.html

相关文章

  • Qt 下的虹软人脸识别SDK使用介绍

    摘要:简介本文主要会对虹软人脸识别在平台下的使用过程做简要介绍,其中包含材料准备环境搭建代码实现三个主要步骤,帮助我们有过程上的参考。 简介 本文主要会对虹软人脸识别SDK在 Qt 平台下的使用过程做简要介绍,其中包含材料准备、环境搭建、代码实现三个主要步骤,帮助我们有过程上的参考。 showImg(https://segmentfault.com/img/bVbj9jQ?w=917&h=3...

    graf 评论0 收藏0
  • 虹软人脸识别ArcFace2.0 Android SDK使用教程

    摘要:一获取进入的申请地址填写信息申请并提交申请通过后即可下载,查看和二功能介绍虹软包含人脸检测年龄信息检测性别信息检测人脸三维角度检测活体检测人脸特征提取人脸特征比对功能。在线程进行人脸检测时不可以在线程同时进行人脸检测。一、获取SDK 1.进入ArcFace2.0的申请地址 https://ai.arcsoft.com.cn/product/arcface.html 2.填写信息申请并提交 申...

    sutaking 评论0 收藏0
  • 虹软人脸识别 - faceIdIR活体检测的介绍

    摘要:双目摄像头检测方案双目摄像头检测流程人脸检测结果信息调整若摄像头和摄像头的成像不一致存在偏移旋转镜像等问题,需要将传递给活体检测的人脸信息人脸框人脸角度进行调整。否则活体检测将无法解析人脸,报错误。 前几天虹软推出了 Android ArcFace 2.2版本的SDK,相比于2.1版本,2.2版本中的变化如下: • VIDEO模式新增faceId(类似于之前文章中提到的track...

    Blackjun 评论0 收藏0
  • 虹软人脸识别SDK - Java服务端的那些事

    摘要:最近有合作公司的项目需要服务端人脸识别的开发,于是就用了公司的人脸识别开发,由于之前对服务端开发介绍的资料比较少,正好这次又做了这个项目,花了几天的开发,这里就简单分享一下个人的见解。 最近有合作公司的项目需要服务端人脸识别的开发,于是就用了公司的人脸识别SDK开发,由于之前对服务端开发介绍的资料比较少,正好这次又做了这个项目,花了几天的开发,这里就简单分享一下个人的见解。 影响性能的...

    AlphaGooo 评论0 收藏0
  • 虹软AI 人脸识别SDK接入 — 参数优化篇

    摘要:引言使用了免费的人脸识别算法,感觉还是很不错的,但是初次接触的话会对一些接口的参数有些疑问的。这里分享一下我对一些参数的验证结果这里以版本为例,基本一样,希望能更好的帮助各位接入虹软的人脸识别算法。 引言 使用了免费的人脸识别算法,感觉还是很不错的,但是初次接触的话会对一些接口的参数有些疑问的。这里分享一下我对一些参数的验证结果(这里以windows版本为例,linux、android...

    yibinnn 评论0 收藏0

发表评论

0条评论

eternalshallow

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<