91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于RV1126開發板的人臉識別算法開發

ljx2016 ? 來源:ljx2016 ? 作者:ljx2016 ? 2025-04-14 11:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 人臉識別簡介

人臉識別,是基于人的臉部特征信息進行身份識別的一種生物識別技術。用攝像機或攝像頭采集含有人臉的圖像或視頻流,并自動在圖像中檢測和跟蹤人臉,進而對檢測到的人臉進行臉部識別的一系列相關技術,通常也叫做人像識別、面部識別。

人臉識別系統主要包括四個組成部分,分別為:人臉圖像采集及檢測、人臉圖像預處理、人臉圖像特征提取以及匹配與識別,本實例也包括這幾個流程。

本人臉識別算法在數據集表現如下所示:

人臉識別算法 performance
LFW 99.8
IJB-C 97.16

wKgZO2f8fbCAdPkjAADqockrEZ4123.png

基于EASY-EAI-Nano硬件主板的運行效率:

算法種類 運行效率
face_detect 35ms
face_recognition 32ms

2. 快速上手

2.1 開發環境準備

如果您初次閱讀此文檔,請閱讀《入門指南/開發環境準備/Easy-Eai編譯環境準備與更新》,并按照其相關的操作,進行編譯環境的部署

在PC端Ubuntu系統中執行run腳本,進入EASY-EAI編譯環境,具體如下所示。

cd ~/develop_environment
./run.sh
wKgZPGf8fbGAFjz7AACbrHAYX20295.png

2.2 源碼下載以及例程編譯

在EASY-EAI編譯環境下創建存放源碼倉庫的管理目錄:

cd /opt
mkdir EASY-EAI-Toolkit
cd EASY-EAI-Toolkit

通過git工具,在管理目錄內克隆遠程倉庫

git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-C-Demo.git

wKgZPGf8fbGAFhuoAADL06HcVzc595.png

注:

* 此處可能會因網絡原因造成卡頓,請耐心等待。

* 如果實在要在gitHub網頁上下載,也要把整個倉庫下載下來,不能單獨下載本實例對應的目錄。

進入到對應的例程目錄執行編譯操作,具體命令如下所示:

cd EASY-EAI-Toolkit-C-Demo/algorithm-face_recognition/
./build.sh cpres

注:

* 若build.sh腳本帶有cpres參數,則會把Release/目錄下的所有資源都拷貝到開發板上。

* 若build.sh腳本不帶任何參數,則僅會拷貝demo編譯出來的可執行文件。

* 由于依賴庫部署在板卡上,因此交叉編譯過程中必須保持adb連接。

wKgZPGf8fbGALSrXAAGIaPTJHO0351.png

2.3 模型部署

要完成算法Demo的執行,需要先下載人臉檢測算法模型

百度網盤鏈接為:https://pan.baidu.com/s/1cxnx1T0ldJvoqkyTk1RmUg (提取碼:0b6h )。

wKgZO2f8fbGATqy8AAAfveoTfYQ840.png

也要下載人臉識別算法模型。

百度網盤鏈接為:https://pan.baidu.com/s/1L6ip8D13-kyo2i8il9ru6A (提取碼:56xm )。

wKgZPGf8fbGAMQ24AAAlGtmaR1c795.png

然后需要把下載的人臉檢測算法模型和人臉識別算法模型復制粘貼到Release/目錄:

wKgZO2f8fbKANgg8AAC3tXy7Cbc730.png

再通過下方命令將模型署到板卡中,如下所示。

cp ./Release/*.model /mnt/userdata/Demo

2.4 例程運行

通過按鍵Ctrl+Shift+T創建一個新窗口,執行adb shell命令,進入板卡運行環境。

adb shell

wKgZPGf8fbKAXDZPAACOVQLk9o8405.png

進入板卡后,定位到例程上傳的位置,如下所示:

cd /userdata/Demo

運行例程命令如下所示:

./test-face-recognition 1.jpg 2.jpg

2.5 運行效果

face-recognition的Demo執行效果如下所示,一般相似度大于0.4視為同一個人:

wKgZO2f8fbKAc1_RAACQvQh_-6Q180.png

API的詳細說明,以及API的調用(本例程源碼),詳細信息見下方說明。

3. 人臉檢測API說明

3.1 引用方式

為方便客戶在本地工程中直接調用我們的EASY EAI api庫,此處列出工程中需要鏈接的庫以及頭文件等,方便用戶直接添加。

選項 描述
頭文件目錄 easyeai-api/algorithm_api/face_detect
庫文件目錄 easyeai-api/algorithm_api/face_detect
庫鏈接參數 -lpthread -lface_detect -lrknn_api

3.2 人臉檢測初始化函數

設置人臉檢測初始化函數原型如下所示。

 int face_detect_init(rknn_context *ctx, const char *path)

具體介紹如下所示。

函數名: face_detect_init()
頭文件 face_detect.h
輸入參數 ctx:rknn_context句柄
path:算法模型的路徑
返回值 成功返回:0
失敗返回:-1
注意事項

3.3 人臉檢測運行函數

設face_detect_run原型如下所示。

int face_detect_run(rknn_context ctx, cv::Mat &input_image, std::vector &result)

具體介紹如下所示。

函數名: face_detect_run ()
頭文件 face_detect.h
輸入參數
ctx: rknn_context句柄
input_image:Opencv Mat格式圖像
result:人臉檢測的結果輸出
返回值 成功返回:0
失敗返回:-1
注意事項

3.4 人臉檢測釋放函數

人臉檢測釋放函數原型如下所示。

 int face_detect_release(rknn_context ctx)

具體介紹如下所示。

函數名: face_detect_release ()
頭文件 face_detect.h
輸入參數
ctx: rknn_context句柄
返回值 成功返回:0
失敗返回:-1
注意事項

4. 人臉標準化API說明

4.1 引用方式

為方便客戶在本地工程中直接調用我們的EASY EAI api庫,此處列出工程中需要鏈接的庫以及頭文件等,方便用戶直接添加。

選項 描述
頭文件目錄 easyeai-api/algorithm_api/face_alignment
庫文件目錄 easyeai-api/algorithm_api/face_alignment
庫鏈接參數 -lpthread -lface_alignment -lrknn_api

4.2 人臉標準化函數

設置人臉標準化函數原型如下所示。

 cv::Mat face_alignment(cv::Mat img, cv::Point2f* points)

具體介紹如下所示。

函數名:face_alignment()
頭文件 face_alignment.h
輸入參數 img: opencv圖像輸入
points: Point2f人臉關鍵點輸入
返回值 成功返回:112*112*3的人臉標準化圖像
注意事項 輸入圖片和人臉關鍵點坐標,輸出標準化的人臉頭像

5. 人臉識別API說明

5.1 引用方式

為方便客戶在本地工程中直接調用我們的EASY EAI api庫,此處列出工程中需要鏈接的庫以及頭文件等,方便用戶直接添加。

選項 描述
頭文件目錄 easyeai-api/algorithm_api/face_recognition
庫文件目錄 easyeai-api/algorithm_api/face_recognition
庫鏈接參數 -lpthread -lface_recognition -lrknn_api

5.2 人臉識別初始化函數

設置人臉識別初始化函數原型如下所示。

 int face_recognition_init(rknn_context *ctx, const char * path)

具體介紹如下所示。

函數名: face_recognition_init()
頭文件 face_recognition.h
輸入參數 ctx:rknn_context句柄
path:算法模型的路徑
返回值 成功返回:0
失敗返回:-1
注意事項

5.3 人臉識別運行函數

設face_detect_run原型如下所示。

int face_recognition_run(rknn_context ctx, cv::Mat *face_image, float (*feature)[512])

具體介紹如下所示。

函數名: face_recognition_run ()
頭文件 face_recognition.h
輸入參數
ctx: rknn_context句柄
face_image:圖像數據輸入(cv::Mat是Opencv的類型)
feature:算法輸出的人臉特征碼
返回值 成功返回:0
失敗返回:-1
注意事項

5.4 人臉識別特征比對函數

設face_detect_run原型如下所示。

float face_recognition_comparison(float *feature_1, float *feature_2, int output_len)

具體介紹如下所示。

函數名: face_recognition_comparison ()
頭文件 face_recognition.h
輸入參數 feature_1: 人臉特征碼1
feature_2:人臉特征碼2
返回值 成功返回:人臉識別相似度
注意事項 一般相似度大于0.4可以似為同一個人

5.5 人臉識別釋放函數

人臉識別釋放函數原型如下所示。

 int face_recognition_release(rknn_context ctx)

具體介紹如下所示。

函數名: face_recognition_release ()
頭文件 face_recognition.h
輸入參數
ctx: rknn_context句柄
返回值 成功返回:0
失敗返回:-1
注意事項

6. 人臉識別算法例程

例程目錄為Toolkit-C-Demo/algorithm-face_recognition/test-face-recognition.cpp,操作流程如下。

wKgZPGf8fbKAAm6gAAA4J8Jgxs8389.png

參考例程如下所示。

#include 
#include 
#include 
#include 
#include 
#include 
#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::vector result1, result2;
	int ret;
	struct timeval start;
	struct timeval end;
	float time_use=0;

	if( argc != 3)
	{
		printf("./face_recognition_demo xxx.jpg xxx.jpgn");
		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=%dn", 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=%dn", 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 %fn",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:%fn", similarity);	

	/* 人臉檢測釋放 */
	face_detect_release(detect_ctx);

	/* 人臉識別釋放 */
	face_recognition_release(recognition_ctx);

	return 0;
}

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 人臉識別算法

    關注

    0

    文章

    11

    瀏覽量

    2830
  • rv1126
    +關注

    關注

    0

    文章

    108

    瀏覽量

    3544
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    基于RV1126開發板實現人臉檢測方案

    RV1126開發板上實現人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。 方案設計邏輯流程圖,方案代碼分為分
    的頭像 發表于 04-21 17:59 ?476次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b>檢測方案

    基于RV1126開發板實現二維碼識別方案

    RV1126開發板上實現方案設計邏輯流程圖,方案代碼分為兩個業務流程,主體代碼負責抓取、合成圖像,算法代碼負責二維碼識別功能。
    的頭像 發表于 04-21 14:25 ?54次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現二維碼<b class='flag-5'>識別</b>方案

    基于RV1126開發板實現人臉檢測方案

    RV1126開發板上實現人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。 方案設計邏輯流程圖,方案代碼分為分
    的頭像 發表于 04-21 14:00 ?13次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b>檢測方案

    基于RV1126開發板實現人臉識別方案

    RV1126上實現人臉識別:在圖像中找出人臉,并與數據庫進行比對,得出該人臉對應的身份信息。 方案設計邏輯流程圖,方案代碼分
    的頭像 發表于 04-21 13:51 ?11次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>方案

    基于RV1126開發板實現自學習圖像分類方案

    RV1126開發板上實現自學習:在識別前對物體圖片進行模型學習,訓練完成后通過算法分類得出圖像的模型ID。 方案設計邏輯流程圖,方案代碼分為分為兩個業務流程,主體代碼負
    的頭像 發表于 04-21 13:37 ?11次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現自學習圖像分類方案

    基于RV1126開發板實現人臉識別方案

    RV1126開發板上實現人臉識別:在圖像中找出人臉,并與數據庫進行比對,得出該人臉對應的身份信
    的頭像 發表于 04-21 10:24 ?107次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>方案

    基于RV1126開發板實現人臉檢測方案

    RV1126開發板上實現人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。 方案設計邏輯流程圖,方案代碼分為分
    的頭像 發表于 04-21 10:21 ?99次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b>檢測方案

    基于RV1126開發板實現駕駛員行為檢測方案

    RV1126開發板上實現駕駛員行為檢測:通過圖像識別出這幾種行為:打電話、抽煙、疲勞駕駛。
    的頭像 發表于 04-18 17:47 ?354次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現駕駛員行為檢測方案

    基于RV1126開發板實現人臉識別方案

    RV1126開發板實現人臉識別:在圖像中找出人臉,并與數據庫進行比對,得出該人臉對應的身份信息
    的頭像 發表于 04-18 16:55 ?83次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>方案

    基于RV1126開發板實現人臉檢測方案

    RV1126上實現人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。方案設計邏輯流程圖,方案代碼分為分為兩個業務流程,主體代碼負責抓取、合成圖像,
    的頭像 發表于 04-18 16:47 ?277次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>實現<b class='flag-5'>人臉</b>檢測方案

    基于RV1126開發板的按鍵測試方法與例程

    RV1126開發板的按鍵測試方法與例程詳細描述
    的頭像 發表于 04-15 17:03 ?356次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b>的按鍵測試方法與例程

    基于RV1126開發板的人員檢測算法開發

    RV1126開發人員檢測AI算法組件
    的頭像 發表于 04-14 13:56 ?313次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b><b class='flag-5'>的人</b>員檢測<b class='flag-5'>算法</b><b class='flag-5'>開發</b>

    基于RV1126開發板的人臉檢測算法開發

    RV1126開發人臉檢測算法組件
    的頭像 發表于 04-14 10:19 ?330次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發板</b><b class='flag-5'>的人臉</b>檢測<b class='flag-5'>算法</b><b class='flag-5'>開發</b>

    RV1126 實現人臉檢測方案

    基于RV1126開發板實現人臉檢測方案,充分體現了電子方面的實踐經驗和目標檢測技術。
    的頭像 發表于 04-14 09:25 ?266次閱讀
    <b class='flag-5'>RV1126</b> 實現<b class='flag-5'>人臉</b>檢測方案

    RV1126 實現人臉識別門禁系統解決方案

    RV1126實現人臉識別門禁系統解決方案
    的頭像 發表于 04-10 15:17 ?448次閱讀
    <b class='flag-5'>RV1126</b> 實現<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>門禁系統解決方案
    主站蜘蛛池模板: 福利视频一区二区 | 久热中文字幕在线精品免费 | 国产精品一区在线观看你懂的 | 夜夜夜夜操 | 国产深夜福利在线观看网站 | 深夜一级毛片 | 国产成人精品本亚洲 | 午夜欧美精品久久久久久久 | 久久国产高清视频 | 天天综合网天天综合色不卡 | 人人干人人做 | 国产成 人 综合 亚洲网 | 男人的天堂免费网站 | 人人搞人人爽 | 久草视频在线免费看 | 天天射天天摸 | 中文字幕天天躁夜夜狠狠综合 | 濑亚美莉iptd619在线观看 | 永久免费看片 | 国产农村一级特黄α真人毛片 | 欧美一级做一a做片性视频 欧美一级做一级做片性十三 | 五月婷婷视频在线观看 | 美女被猛男躁免费视频网站 | 插吧插吧综合网 | 亚洲综合国产一区二区三区 | 女人张开腿让男人桶免费网站 | 久草一本 | 欧美一级特黄高清免费 | 午夜欧美 | 特黄一级黄色片 | 我不卡老子影院午夜伦我不卡四虎 | 国产深夜福利在线观看网站 | 黄色大片a级 | 亚洲男人的天堂久久香蕉 | 福利天堂 | 亚洲va久久久噜噜噜久久 | 天天天天天天干 | 完全免费在线视频 | 91精品国产免费久久久久久青草 | 国产免费一区二区三区香蕉精 | 鲁久久|