瑞芯微RV1126B开发板(EASY-EAI-PI2) 人脸识别

📅 2026/7/1 4:20:51
瑞芯微RV1126B开发板(EASY-EAI-PI2) 人脸识别
1. 人脸识别简介人脸识别是基于人的脸部特征信息进行身份识别的一种生物识别技术。用摄像机或摄像头采集含有人脸的图像或视频流并自动在图像中检测和跟踪人脸进而对检测到的人脸进行脸部识别的一系列相关技术通常也叫做人像识别、面部识别。人脸识别系统主要包括四个组成部分分别为人脸图像采集及检测、人脸图像预处理、人脸图像特征提取以及匹配与识别本实例也包括这几个流程。本人脸识别算法在数据集表现如下所示基于EASY-EAI-PI2硬件主板的运行效率2. 快速上手2.1 开发环境准备如果您初次阅读此文档请阅读《入门指南/开发环境准备/Easy-Eai编译环境准备与更新》并按照其相关的操作进行编译环境的部署。在PC端Ubuntu系统中执行run脚本进入EASY-EAI编译环境具体如下所示。cd ~/develop_environment ./run.sh 22042.2 源码下载在EASY-EAI编译环境下创建存放源码仓库的管理目录cd /opt mkdir EASY-EAI-Toolkit cd EASY-EAI-Toolkit通过git工具在管理目录内克隆远程仓库git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-1126B.git注* 此处可能会因网络原因造成卡顿请耐心等待。* 如果实在要在gitHub网页上下载也要把整个仓库下载下来不能单独下载本实例对应的目录。2.3 模型部署要完成算法Demo的执行需要先下载人脸检测算法模型。百度网盘链接为https://pan.baidu.com/s/1nGQCTpD_Bk4byxqILZSWwA?pwd1234 提取码1234 。同时也要下载人脸识别算法模型。百度网盘链接为: https://pan.baidu.com/s/11H6TefuBSZy28E4BTgPIMw?pwd1234 (提取码1234 )。然后需要把下载的人脸检测算法模型和人脸识别算法模型复制粘贴到Release/目录2.4 例程编译进入到对应的例程目录执行编译操作具体命令如下所示cd EASY-EAI-Toolkit-1126B/Demos/algorithm-face_recognition/ ./build.sh cpres注* 由于依赖库部署在板卡上因此交叉编译过程中必须保持/mnt挂载。* 若build.sh脚本带有cpres参数则会把Release/目录下的所有资源都拷贝到开发板上。2.5 例程运行及效果通过串口调试或ssh调试进入板卡后台定位到例程部署的位置如下所示cd /userdata/Demo/algorithm-face_recognition/运行例程命令如下所示sudo ./test-face-recognition 1.jpg 2.jpg运行例程命令如下所示similarity值大于0.4认为是同一个人值越大可能性越高similarity值范围在-1~1之间API的详细说明以及API的调用本例程源码详细信息见下方说明。3. 人脸检测API说明3.1 引用方式为方便客户在本地工程中直接调用我们的EASY EAI api库此处列出工程中需要链接的库以及头文件等方便用户直接添加。3.2 人脸检测初始化函数设置人脸检测初始化函数原型如下所示。int face_detect_init(rknn_context *ctx, const char *path)具体介绍如下所示。3.3 人脸检测运行函数设face_detect_run原型如下所示。int face_detect_run(rknn_context ctx, cv::Mat input_image, std::vectordet result)具体介绍如下所示。3.4 人脸检测释放函数人脸检测释放函数原型如下所示。int face_detect_release(rknn_context ctx)具体介绍如下所示。4. 人脸标准化API说明4.1 引用方式为方便客户在本地工程中直接调用我们的EASY EAI api库此处列出工程中需要链接的库以及头文件等方便用户直接添加。4.2 人脸标准化函数设置人脸标准化函数原型如下所示。cv::Mat face_alignment(cv::Mat img, cv::Point2f* points)具体介绍如下所示。5. 人脸识别API说明5.1 引用方式为方便客户在本地工程中直接调用我们的EASY EAI api库此处列出工程中需要链接的库以及头文件等方便用户直接添加。5.2 人脸识别初始化函数设置人脸识别初始化函数原型如下所示。int face_recognition_init(rknn_context *ctx, const char * path)具体介绍如下所示。5.3 人脸识别运行函数设face_recognition_run原型如下所示。int face_recognition_run(rknn_context ctx, cv::Mat *face_image, float (*feature)[512])具体介绍如下所示。5.4 人脸识别特征比对函数设face_recognition_comparison原型如下所示。float face_recognition_comparison(float *feature_1, float *feature_2, int output_len)具体介绍如下所示。5.5 人脸识别释放函数人脸识别释放函数原型如下所示。int face_recognition_release(rknn_context ctx)具体介绍如下所示。6. 人脸识别算法例程例程目录为Demos/algorithm-face_recognition/test-face-recognition.cpp操作流程如下。参考例程如下所示。#include opencv2/opencv.hpp #include stdio.h #include unistd.h #include sys/time.h #include sys/stat.h #include sys/syscall.h #include face_detect.h #include face_alignment.h #include face_recognition.h using namespace cv; int main(int argc, char **argv) { rknn_context detect_ctx, recognition_ctx; std::vectordet result1, result2; int ret; struct timeval start; struct timeval end; float time_use0; if( argc ! 3) { printf(./face_recognition_demo xxx.jpg xxx.jpg\n); return -1; } cv::Mat src_1, src_2; src_1 cv::imread(argv[1], 1); src_2 cv::imread(argv[2], 1); /* 人脸检测初始化 */ printf(face detect init!\n); ret face_detect_init(detect_ctx, ./face_detect.model); if( ret 0) { printf(face_detect_init fail! ret%d\n, ret); return -1; } /* 人脸识别初始化 */ printf(face recognition init!\n); ret face_recognition_init(recognition_ctx, ./face_recognition.model); if( ret 0) { printf(face_recognition fail! ret%d\n, ret); return -1; } /* 人脸检测执行 */ face_detect_run(detect_ctx, src_1, result1); face_detect_run(detect_ctx, src_2, result2); Point2f points1[5], points2[5]; for (int j 0; j (int)result1[0].landmarks.size(); j) { points1[j].x (int)result1[0].landmarks[j].x; points1[j].y (int)result1[0].landmarks[j].y; } for (int j 0; j (int)result2[0].landmarks.size(); j) { points2[j].x (int)result2[0].landmarks[j].x; points2[j].y (int)result2[0].landmarks[j].y; } Mat face_algin_1, face_algin_2; face_algin_1 face_alignment(src_1, points1); face_algin_2 face_alignment(src_2, points2); /* 人脸识别执行 */ float feature_1[512], feature_2[512]; gettimeofday(start,NULL); face_recognition_run(recognition_ctx, face_algin_1, feature_1); gettimeofday(end,NULL); time_use(end.tv_sec-start.tv_sec)*1000000(end.tv_usec-start.tv_usec);//微秒 printf(time_use is %f\n,time_use/1000); face_recognition_run(recognition_ctx, face_algin_2, feature_2); float similarity; similarity face_recognition_comparison(feature_1, feature_2, 512); printf(similarity:%f\n, similarity); /* 人脸检测释放 */ face_detect_release(detect_ctx); /* 人脸识别释放 */ face_recognition_release(recognition_ctx); return 0; }