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

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

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

3天內不再提示

基于RK3576開發板的車輛檢測算法

ljx2016 ? 來源:ljx2016 ? 作者:ljx2016 ? 2025-05-08 17:34 ? 次閱讀

1. 車輛檢測簡介

車輛檢測是一種基于深度學習的對人進行檢測定位的目標檢測,能廣泛的用于園區管理、交通分析等多種場景,是違停識別、堵車識別、車流統計等多種算法的基石算法。

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

人臉檢測算法 [email protected]
CAR 0.78029

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

算法種類 運行效率
car_detect 59ms

2. 快速上手

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

2.1 開源碼工程下載

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

cd ~/nfsroot
mkdir GitHub
cd GitHub

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

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

注:

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

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

2.2 開發環境搭建

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

wKgZO2gcggSAOhnyAAC554P6NFE769.png

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

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

2.3 例程編譯

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

cd EASY-EAI-Toolkit-3576/Demos/algorithm-car/
./build.sh
wKgZO2gcggWAeKe0AAFiUfLuGRE883.png

2.4 模型部署

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

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

wKgZPGgcggWAWEslAAAiLZHq5UQ005.png

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

wKgZO2gcggWAKXJ-AABQ04vutMg294.png

2.5 例程運行及效果

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

cd Release/
./test-car_detect car_detect.model test.jpg

運行例程命令如下所示:

wKgZPGgcggWADFN6AAJc5VZEGWw876.png

結果圖片如下所示:

wKgZO2gcggaAFW1jAArEmnWvoiI696.jpg

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

3. 車輛檢測API說明

3.1 引用方式

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

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

3.2 車輛檢測初始化函數

車輛檢測初始化函數原型如下所示。

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

具體介紹如下所示。

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

3.3 車輛檢測運行函數

車輛檢測運行函數car_detect_run原型如下所示。

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

具體介紹如下所示。

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

3.4 車輛檢測釋放函數

車輛檢測釋放函數原型如下所示。

 int car_detect_release(rknn_context ctx)

具體介紹如下所示。

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

4. 車輛檢測算法例程

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

wKgZPGgcggaAUlNBAAAaSqVD4zc372.png

參考例程如下所示。

#include 
#include 
#include 
#include "car_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;
	car_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); 

	car_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/10);

	/* 算法結果在圖像中畫出并保存 */
	// 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);	

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

	return 0;
}

審核編輯 黃宇

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

    關注

    25

    文章

    5421

    瀏覽量

    101125
  • 目標檢測
    +關注

    關注

    0

    文章

    221

    瀏覽量

    15852
  • 深度學習
    +關注

    關注

    73

    文章

    5549

    瀏覽量

    122343
  • rk3576
    +關注

    關注

    1

    文章

    121

    瀏覽量

    494
收藏 人收藏

    評論

    相關推薦
    熱點推薦

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

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

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

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

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

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

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

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

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

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

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

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

    【米爾RK3576開發板評測】+項目名稱【米爾RK3576開發板評測】一個視頻和你共同認識一下米爾RK3576開發板

    學習框架,能夠處理復雜的AI算法,提高監控效率,降低誤報率。 1、DC_M576_V01是定昌最新研發的RK3576開發板,面向大算力邊緣計算,工業Alot邊緣AI物聯,HMI人機交互上位機,AI
    發表于 12-18 20:50

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

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

    新品體驗 | RK3576開發板

    RK3399、RK3566、RK3568、RK3588、RK3576等型號的核心與評估
    的頭像 發表于 11-01 08:08 ?1607次閱讀
    新品體驗 | <b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>

    米爾RK3576開發板特惠活動!

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

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

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

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

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

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

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

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

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

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

    展示了RK3576開發板的人員檢測算法例程及API說明
    的頭像 發表于 05-07 17:33 ?91次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的人員<b class='flag-5'>檢測算法</b>
    主站蜘蛛池模板: 久久精品免看国产 | 中文天堂最新版资源新版天堂资源 | 亚洲一区二区三区高清 | 黄色小视频免费看 | 狠狠干天天色 | 男女交性视频播放视频视频 | 91人成网站色www免费 | xxxx 欧美| 你懂的在线观看网站 | avtt香蕉 | 欧美xxxxx精品 | 88av免费 | 久操视频在线 | 久草在线资源网 | 三级网站在线播放 | 国产女主播在线播放一区二区 | 狠狠插天天干 | 2019天天干夜夜操 | 中文字幕一二三区乱码老 | 午夜韩国理论片在线播放 | 欧洲综合网 | 六月婷婷视频 | 中文字幕在线看视频一区二区三区 | 91精品啪国产在线观看免费牛牛 | 日韩一区二区三区在线 | 美女一级毛片免费观看 | 天堂电影在线 | 色婷婷婷丁香亚洲综合不卡 | 一区不卡视频 | 2020国产v亚洲v天堂高清 | 91视频精品 | 黄色片日本网站 | 日本免费精品视频 | 欧美日本一道免费一区三区 | 伊人久久大香线蕉观看 | 又黑又长黑人欧美三级 | 日本19xxxxxxxxx69| 色综合狠狠 | 一区二区不卡视频在线观看 | 午夜看片网址 | 国产精品一久久香蕉产线看 |