在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

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

ljx2016 ? 來源:ljx2016 ? 作者:ljx2016 ? 2025-05-07 17:33 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 人員檢測簡介

人員檢測是一種基于深度學習的對人進行檢測定位的目標檢測,能廣泛的用于安防、生產安全等多種場景,是周界入侵檢測、越界識別、聚眾識別、徘徊識別、摔倒識別等多種算法的基石算法。

本人員檢測算法在數據集表現如下所示:

人臉檢測算法 mAP@0.5
PERSON 0.79

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

算法種類 運行效率
PERSON 57ms

2. 快速上手

如果您初次閱讀此文檔,請閱讀:《入門指南/源碼管理及編程介紹/源碼工程管理》,按需管理自己工程源碼(注:此文檔必看,并建議采用【遠程掛載管理】方式,否則有代碼丟失風險!!!)。

2.1 開源碼工程下載

先在PC虛擬機定位到nfs服務目錄,再在目錄中創建存放源碼倉庫的管理目錄:

cd ~/nfsroot
mkdir GitHub
cd GitHub

再通過git工具,在管理目錄內克隆遠程倉庫(需要設備能對外網進行訪問)

git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-3576.git
wKgZO2gbKTCAMnjbAAEsFLEfksY761.png

注:

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

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

2.2 開發環境搭建

通過adb shell進入板卡開發環境,如下圖所示。

wKgZPGgbKTGANeXbAACwg0m3jts560.png

通過以下命令,把nfs目錄掛載上nfs服務器。

mount -t nfs -o nolock : /home/orin-nano/Desktop/nfs/
wKgZO2gbKTGAESwgAADsnHxQWoA651.png

2.3 例程編譯

然后定位到板卡的nfs的掛載目錄(按照實際掛載目錄),進入到對應的例程目錄執行編譯操作,具體命令如下所示:

cd EASY-EAI-Toolkit-3576/Demos/algorithm-person/
./build.sh
wKgZPGgbKTGAevjFAAF_dcyP0QQ203.png

2.4 模型部署

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

百度網盤鏈接為:https://pan.baidu.com/s/1yErZgWhZCuncJBF9z_VRaQ?pwd=1234 (提取碼:1234 )。

wKgZO2gbKTGAWVtOAAA5IaYMprQ478.png

同時需要把下載的人員檢測算法模型復制粘貼到Release/目錄:

wKgZO2gbKTKAGbDXAAC5xqcBuzo884.png

2.5 例程運行及效果

進入開發板Release目錄,執行下方命令,運行示例程序:

cd Release/
./test-person_detect person_detect.model test.jpg
wKgZPGgbKTKAdcchAADF24q7Nxk422.png

結果圖片如下所示:

wKgZO2gbKTKAZnEAAADB_97I2W0312.jpg

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

3. 人員檢測API說明

3.1 引用方式

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

選項 描述
頭文件目錄 easyeai-api/algorithm/person_detect
庫文件目錄 easyeai-api/algorithm/person_detect
庫鏈接參數 -lperson_detect

3.2 人員檢測初始化函數

人員檢測初始化函數原型如下所示。

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

具體介紹如下所示。

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

3.3 人員檢測運行函數

人員檢測運行函數person_detect_run原型如下所示。

int person_detect_run(rknn_context ctx, cv::Mat input_image, person_detect_result_group_t *detect_result_group)

具體介紹如下所示。

函數名:person_detect_run()
頭文件 person_detect.h
輸入參數 ctx: rknn_context句柄
輸入參數 input_image:圖像數據輸入(cv::Mat是Opencv的類型)
輸出參數 output_dets:目標檢測框輸出
返回值 成功返回:0
失敗返回:-1
注意事項

3.4 人員檢測釋放函數

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

 int person_detect_release(rknn_context ctx)

具體介紹如下所示。

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

4. 人員檢測算法例程

例程目錄為Demos/algorithm-person/test-person_detect.cpp,操作流程如下。

wKgZPGgbKTKAPs8JAABJx8bJi1g448.png

參考例程如下所示。

#include 
#include 
#include 
#include"person_detect.h"

using namespace cv;
using namespace std;

static Scalar colorArray[10]={
    Scalar(255, 0, 0, 255),
    Scalar(0, 255, 0, 255),
    Scalar(0,0,139,255),
    Scalar(0,100,0,255),
    Scalar(139,139,0,255),
    Scalar(209,206,0,255),
    Scalar(0,127,255,255),
    Scalar(139,61,72,255),
    Scalar(0,255,0,255),
    Scalar(255,0,0,255),
};

int plot_one_box(Mat src, int x1, int x2, int y1, int y2, char *label, char colour)
{
    int tl = round(0.002 * (src.rows + src.cols) / 2) + 1;
    rectangle(src, cv::Point(x1, y1), cv::Point(x2, y2), colorArray[(unsigned char)colour], 3);

    int tf = max(tl -1, 1);

    int base_line = 0;
    cv::Size t_size = getTextSize(label, FONT_HERSHEY_SIMPLEX, (float)tl/3, tf, &base_line);
    int x3 = x1 + t_size.width;
    int y3 = y1 - t_size.height - 3;

    rectangle(src, cv::Point(x1, y1), cv::Point(x3, y3), colorArray[(unsigned char)colour], -1);
    putText(src, label, cv::Point(x1, y1 - 2), FONT_HERSHEY_SIMPLEX, (float)tl/3, cv::Scalar(255, 255, 255, 255), tf, 8);
    return 0;
}

int main(int argc, char **argv)
{
	if (argc != 3)
    {
        printf("%s  n", argv[0]);
        return -1;
    }

    const char *model_path = argv[1];
    const char *image_path = argv[2];

	/* 參數初始化 */
	detect_result_group_t detect_result_group;

	/* 算法模型初始化 */
	rknn_context ctx;
	person_detect_init(&ctx, model_path);

	/* 算法運行 */
	cv::Mat src;
	src = cv::imread(image_path, 1);

	struct timeval start;
	struct timeval end;
	float time_use=0;

	gettimeofday(&start,NULL); 

	person_detect_run(ctx, src, &detect_result_group);

	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);

	/* 算法結果在圖像中畫出并保存 */
	// Draw Objects
	char text[256];
	for (int i = 0; i < detect_result_group.count; i++) 
	{

		detect_result_t* det_result = &(detect_result_group.results[i]);
		if( det_result-?>prop < 0.4)
		{
			continue;
		}

		sprintf(text, "%s %.1f%%", det_result-?>name, det_result->prop * 100);
		printf("%s @ (%d %d %d %d) %fn", det_result->name, det_result->box.left, det_result->box.top,
			   det_result->box.right, det_result->box.bottom, det_result->prop);
		int x1 = det_result->box.left;
		int y1 = det_result->box.top;
		int x2 = det_result->box.right;
		int y2 = det_result->box.bottom;
		/*
		rectangle(src, cv::Point(x1, y1), cv::Point(x2, y2), cv::Scalar(255, 0, 0, 255), 3);
		putText(src, text, cv::Point(x1, y1 + 12), cv::FONT_HERSHEY_SIMPLEX, 0.5, cv::Scalar(0, 0, 0));
		*/
		plot_one_box(src, x1, x2, y1, y2, text, i%10);
	} 

	cv::imwrite("result.jpg", src);	


	/* 算法模型空間釋放 */
	person_detect_release(ctx);

	return 0;
}

審核編輯 黃宇

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

    關注

    23

    文章

    4704

    瀏覽量

    95047
  • 開發板
    +關注

    關注

    25

    文章

    5613

    瀏覽量

    103448
  • rk3576
    +關注

    關注

    1

    文章

    162

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

    RK3576開發板展示人臉識別算法例程和API說明
    的頭像 發表于 05-07 16:48 ?1879次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b><b class='flag-5'>的人</b>臉識別<b class='flag-5'>算法</b>

    基于RK3576開發板的RTC使用說明

    文章主要展示RK3576開發板的RTC信息和快速上手例程
    的頭像 發表于 05-07 15:04 ?728次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的RTC使用說明

    基于RK3576開發板的PWN使用說明

    RK3576開發板使用PWN教程及Demo
    的頭像 發表于 05-07 14:07 ?1218次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的PWN使用說明

    基于RK3576開發板的TF卡槽使用說明

    RK3576開發板使用TF卡槽
    的頭像 發表于 05-07 09:24 ?659次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的TF卡槽使用說明

    基于RK3576開發板的PCIE固態硬盤使用說明

    RK3576開發板的PICE固態硬盤使用方法
    的頭像 發表于 05-06 17:33 ?1287次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的PCIE固態硬盤使用說明

    基于RK3576開發板的WDT看門狗使用說明

    RK3576開發板的WDT使用說明
    的頭像 發表于 05-06 17:15 ?552次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的WDT看門狗使用說明

    基于RK3576開發板的HDMI-OUT使用說明

    RK3576開發板的HDMI-OUT使用說明
    的頭像 發表于 05-06 16:48 ?260次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的HDMI-OUT使用說明

    基于RK3576開發板的MIPI-DSI使用

    MIPI DSI接口是由MIPI聯盟下的Display工作組指定的DSI(Display Serial Interface)的接口標準。rk3576開發板使用mipi-dsi教程
    的頭像 發表于 05-06 16:11 ?295次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的MIPI-DSI使用

    【米爾RK3576開發板評測】+項目名稱RetinaFace人臉檢測

    的文件。 bash ./build-linux.sh -t rk3576 -a aarch64 -d RetinaFace 四、RK3576運行 4.1、將編譯后的文件上傳至開發板中 4.2、打開文件
    發表于 02-15 13:28

    迅為RK3576開發板Android?多屏顯示

    迅為RK3576開發板Android?多屏顯示
    的頭像 發表于 01-16 16:58 ?931次閱讀
    迅為<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>Android?多屏顯示

    迅為RK3576開發板核心與底板接口硬件介紹

    迅為RK3576開發板核心與底板接口硬件介紹
    的頭像 發表于 01-14 15:15 ?1397次閱讀
    迅為<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>核心<b class='flag-5'>板</b>與底板接口硬件介紹

    人臉疲勞檢測應用-米爾基于RK3576核心/開發板

    本文將介紹基于米爾電子MYD-LR3576開發板(米爾基于瑞芯微RK3576開發板的人臉疲勞檢測
    的頭像 發表于 12-20 08:06 ?832次閱讀
    人臉疲勞<b class='flag-5'>檢測</b>應用-米爾基于<b class='flag-5'>RK3576</b>核心<b class='flag-5'>板</b>/<b class='flag-5'>開發板</b>

    敬請期待 | 迅為RK3576開發板即將發布

    敬請期待 | 迅為RK3576開發板即將發布
    的頭像 發表于 11-22 15:13 ?588次閱讀
    敬請期待 | 迅為<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>即將發布

    米爾RK3576開發板特惠活動!

    近日,米爾電子發布基于瑞芯微RK3576核心開發板RK3576作為國產熱門處理器,其高性能數據處理能力、領先的AI智能分析、強大的擴展性與兼容性受到廣大
    的頭像 發表于 11-12 01:00 ?789次閱讀
    米爾<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>特惠活動!

    新品體驗 | RK3576開發板

    RK3399、RK3566、RK3568、RK3588、RK3576等型號的核心與評估
    的頭像 發表于 11-01 08:08 ?1854次閱讀
    新品體驗 | <b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>
    主站蜘蛛池模板: 色综合久久网女同蕾丝边 | 色五月激情小说 | 一级特黄aaa大片29 | 天天干视频在线 | h在线观看网站 | 狠狠色噜噜狠狠狠狠五月婷 | 欧美成人精品一级高清片 | 男女视频免费 | 欧美一区二区三区在线 | 操妞网| 亚洲不卡视频在线 | 乱码中文字幕人成在线 | 亚洲一级免费视频 | 美女免费视频一区二区三区 | 天天操狠狠操 | 国产免费人人看大香伊 | 三级精品视频在线播放 | 婷婷丁香久久 | 激情玖玖 | 天天综合久久久网 | 91在线电影| 欧美亚洲专区 | 国产亚洲高清在线精品不卡 | 赛罗奥特曼银河帝国普通话免费版 | 神马三级我不卡 | 成人免费视频一区 | 欧美激情一欧美吧 | 34pao强力打造免费永久视频 | 深爱激情五月网 | 国产精品视频一区二区三区 | 美女扒开尿口给男人桶 | 中文字幕一区在线观看 | xxx86日本人 xxxxbbbb欧美 | 99久久免费精品国产免费高清 | 国产主播一区二区 | 色综合美国色农夫网 | 在线欧美视频免费观看国产 | 亚洲a免费 | 国产狂喷冒白浆免费视频 | 都市激情亚洲 | 欧美日韩一区二区三区视频 |