chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

3天內不再提示

基于RV1126開發(fā)板的人員檢測算法開發(fā)

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

掃碼添加小助手

加入工程師交流群

1. 人員檢測簡介

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

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

人員檢測算法 mAP@0.5
COCO 0.79

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

算法種類 運行效率
person_detect 115ms

2. 快速上手

2.1 開發(fā)環(huán)境準備

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

在PC端Ubuntu系統(tǒng)中執(zhí)行run腳本,進入EASY-EAI編譯環(huán)境,具體如下所示。

cd ~/develop_environment ./run.sh

wKgZPGf8o_aADYmZAACbrHAYX20332.png

2.2 源碼下載以及例程編譯

在EASY-EAI編譯環(huán)境下創(chuàng)建存放源碼倉庫的管理目錄:

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

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

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

wKgZO2f8o_aAQFzhAADL06HcVzc065.png

注:

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

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

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

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

注:

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

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

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

wKgZPGf8o_eAE2EoAAGGzh-cnF0710.png

2.3 模型部署

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

百度網盤鏈接為:https://pan.baidu.com/s/1UfQ1QQ2hx0DsbF-ZNdcCAg (提取碼:uer4 )。

wKgZO2f8o_eACQdLAAAb2-lFcXw794.png

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

wKgZPGf8o_eALznlAABnK5P0wD8026.png

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

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

2.4 例程運行

通過按鍵Ctrl+Shift+T創(chuàng)建一個新窗口,執(zhí)行adb shell命令,進入板卡運行環(huán)境。

adb shell

wKgZO2f8o_eAQbWiAACOVQLk9o8246.png

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

cd /userdata/Demo

運行例程命令如下所示:

./test-person-detect

2.5 運行效果

person-detect的Demo執(zhí)行效果如下所示:

wKgZPGf8o_iAL5mbAADeWmEiDr4813.png

再開一個窗口,在PC端Ubuntu環(huán)境通過以下命令可以把圖片拉回來:

adb pull /userdata/Demo/result.jpg .

結果圖片如下所示:

wKgZO2f8o_iAIPHKAAwRl76qb_A659.jpg

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

3. 人員檢測API說明

3.1 引用方式

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

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

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. 人員檢測算法例程

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

wKgZPGf8o_iAd8SFAAAao5TFhic035.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) { /* 參數初始化 */ person_detect_result_group_t detect_result_group; /* 算法模型初始化 */ rknn_context ctx; person_detect_init(&ctx, "./person_detect.model"); /* 算法運行 */ cv::Mat src; src = cv::imread("test.jpg", 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); /* 算法結果在圖像中畫出并保存 */ for (int i = 0; i < detect_result_group.count; i++) { person_detect_result_t *det_result = &(detect_result_group.results[i]); /* if( det_result-?>prop < 0.3 ) { continue; } */ 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; char label_text[50]; memset(label_text, 0 , sizeof(label_text)); sprintf(label_text, "%s %0.2f",det_result->name, det_result->prop); plot_one_box(src, x1, x2, y1, y2, label_text, i%10); } cv::imwrite("result.jpg", src); /* 算法模型空間釋放 */ person_detect_release(ctx); return 0; } 審核編輯 黃宇

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

    關注

    26

    文章

    6398

    瀏覽量

    120472
  • rv1126
    +關注

    關注

    0

    文章

    118

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    替代升級實錘!實測RV1126B,CPU性能吊打RV1126

    RV1126B核心已上市并穩(wěn)定量產供應實測開始,設備使用觸覺智能RV1126核心RV1126B核心
    的頭像 發(fā)表于 12-11 17:13 ?2494次閱讀
    替代升級實錘!實測<b class='flag-5'>RV1126</b>B,CPU性能吊打<b class='flag-5'>RV1126</b>

    RV1126系列選型指南:從RV1126RV1126B,一文看懂升級差異

    2025年7月,瑞芯微正式發(fā)布新一代AI視覺芯片RV1126B。作為其金牌方案商,EASYEAI靈眸科技同步推出搭載該芯片的AIoT核心EAI1126B-Core-T。相較于前代RV1126
    的頭像 發(fā)表于 09-04 10:50 ?5057次閱讀
    <b class='flag-5'>RV1126</b>系列選型指南:從<b class='flag-5'>RV1126</b>到<b class='flag-5'>RV1126</b>B,一文看懂升級差異

    基于RK3576開發(fā)板的人員檢測算法

    展示了RK3576開發(fā)板的人員檢測算法例程及API說明
    的頭像 發(fā)表于 05-07 17:33 ?1006次閱讀
    基于RK3576<b class='flag-5'>開發(fā)板</b><b class='flag-5'>的人員</b><b class='flag-5'>檢測算法</b>

    基于RV1126開發(fā)板實現人臉檢測方案

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

    基于RV1126開發(fā)板實現網絡攝像頭方案

    RV1126開發(fā)板上實現本開發(fā)實例,抓取攝像頭數據、圖像送入編碼器進行編碼壓縮、以及把壓縮后的數據通過RTSP協議發(fā)送出去的簡單核心示例。 若用戶需要通過webServer對圖像進行調整,以及配置攝像頭的一些工作
    的頭像 發(fā)表于 04-21 14:56 ?2224次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發(fā)板</b>實現網絡攝像頭方案

    基于RV1126開發(fā)板實現多路網絡攝像頭取流方案

    RV1126上實現多路網絡攝像頭取流方案
    的頭像 發(fā)表于 04-21 14:39 ?49次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發(fā)板</b>實現多路網絡攝像頭取流方案

    基于RV1126開發(fā)板實現二維碼識別方案

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

    基于RV1126開發(fā)板實現人臉檢測方案

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

    基于RV1126開發(fā)板實現人臉識別方案

    RV1126上實現人臉識別:在圖像中找出人臉,并與數據庫進行比對,得出該人臉對應的身份信息。 方案設計邏輯流程圖,方案代碼分為分為三個業(yè)務流程,主體代碼負責抓取、合成圖像,算法代碼負責人臉識別功能,按鍵監(jiān)聽負責修改數據庫工作狀態(tài)。
    的頭像 發(fā)表于 04-21 13:51 ?11次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發(fā)板</b>實現人臉識別方案

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

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

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

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

    基于RV1126開發(fā)板實現人員檢測方案

    RV1126上實現人員檢測:在圖像中找出人。 方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像,算法代碼負責
    的頭像 發(fā)表于 04-21 10:42 ?1002次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發(fā)板</b>實現<b class='flag-5'>人員</b><b class='flag-5'>檢測</b>方案

    基于RV1126開發(fā)板實現人臉識別方案

    RV1126開發(fā)板上實現人臉識別:在圖像中找出人臉,并與數據庫進行比對,得出該人臉對應的身份信息。 方案設計邏輯流程圖,方案代碼分為分為三個業(yè)務流程,主體代碼負責抓取、合成圖像,算法代碼負責人臉識別功能,按鍵監(jiān)聽
    的頭像 發(fā)表于 04-21 10:24 ?107次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發(fā)板</b>實現人臉識別方案

    基于RV1126開發(fā)板實現人臉檢測方案

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

    基于RV1126開發(fā)板實現安全帽檢測方案

    RV1126開發(fā)板上實現安全帽檢測:在圖像中找出人頭/安全帽。 方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像,算法代碼負責安全帽
    的頭像 發(fā)表于 04-21 09:20 ?993次閱讀
    基于<b class='flag-5'>RV1126</b><b class='flag-5'>開發(fā)板</b>實現安全帽<b class='flag-5'>檢測</b>方案