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

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

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

3天內不再提示

基于RK3576開發板的火焰檢測算法

ljx2016 ? 來源:6604453 ? 作者:6604453 ? 2025-05-08 10:55 ? 次閱讀

1. 火焰檢測簡介

火焰檢測是一種基于深度學習的對火焰進行檢測定位的目標檢測。基于大規模火焰數據識別訓練,配合攝像頭,實時識別監控區內明火情況立刻發出警報,提醒監控室查看,及時止損。

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

火焰檢測算法 [email protected]
FIRE 0.86

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

算法種類 運行效率
fire_detect 55ms

2. 快速上手

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

2.1 開源碼工程下載

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

cd ~/nfsroot
mkdir GitHub
cd GitHub

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

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

注:

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

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

2.2 開發環境搭建

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

wKgZO2gcHU2AQW9EAAC554P6NFE434.png

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

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

2.3 例程編譯

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

cd EASY-EAI-Toolkit-3576/Demos/algorithm-fire/
./build.sh
wKgZO2gcHU2AJpVzAAFlAZ7tH88484.png

2.4 模型部署

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

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

wKgZPGgcHU6AIwmLAAAjPbA2uKA247.png

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

wKgZO2gcHU6ARnUiAACtcTO602w760.png

2.5 例程運行及效果

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

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

運行例程命令如下所示:

wKgZPGgcHU6AK9M9AABdCqrhlwo004.png

結果圖片如下所示:

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

3. 火焰檢測API說明

3.1 引用方式

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

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

3.2 火焰檢測初始化函數

火焰檢測初始化函數原型如下所示。

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

具體介紹如下所示。

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

3.3 火焰檢測運行函數

火焰檢測運行函數fire_detect_run原型如下所示。

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

具體介紹如下所示。

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

3.4 火焰檢測釋放函數

火焰檢測釋放函數原型如下所示。

int fire_detect_release(rknn_context ctx)

具體介紹如下所示。

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

4. 火焰檢測算法例程

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

wKgZPGgcHU6ARxE5AABLvxpaW-k126.png

參考例程如下所示。

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

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


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

	return 0;
}


審核編輯 黃宇

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

    關注

    25

    文章

    5428

    瀏覽量

    101166
  • rk3576
    +關注

    關注

    1

    文章

    121

    瀏覽量

    496
收藏 人收藏

    評論

    相關推薦
    熱點推薦

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

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

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

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

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

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

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

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

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

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

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

    RK3576開發板展示人臉識別算法例程和API說明
    的頭像 發表于 05-07 16:48 ?838次閱讀
    基于<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開發板特惠活動!

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

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

    本文將介紹基于米爾電子MYD-LR3576開發板(米爾基于瑞芯微RK3576開發板)的人臉疲勞檢測方案測試。米爾基于
    的頭像 發表于 12-20 08:06 ?693次閱讀
    人臉疲勞<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 ?1116次閱讀
    迅為<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 ?159次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的MIPI-DSI使用

    基于RK3576開發板的揚聲器和耳機使用說明

    RK3576開發板的揚聲器和耳機使用說明
    的頭像 發表于 05-06 16:36 ?106次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的揚聲器和耳機使用說明

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

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

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

    展示了RK3576開發板的人員檢測算法例程及API說明
    的頭像 發表于 05-07 17:33 ?112次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的人員<b class='flag-5'>檢測算法</b>
    主站蜘蛛池模板: 亚洲伦理一区二区三区 | 人人搞人人搞 | аbt天堂资源在线官网 | 欧美作爱福利免费观看视频 | 狠狠干夜夜草 | 男人操女人视频免费 | 四虎永久在线精品影院 | 夜夜操夜夜 | 国产三级在线观看播放 | 色老板女色狠xx网 | 国产免费卡1卡2卡 | 久久综合九色婷婷97 | 日本69sex护士xxx | 99婷婷 | 久草丁香| 亚洲成年人影院 | 一区二区三区四区国产精品 | 亚洲爱爱网 | 男子扒开美女尿口做羞羞的事 | 好爽好紧好大的免费视频国产 | 日日摸夜夜爽夜夜爽出水 | 午夜在线观看视频在线播放版 | 九月婷婷亚洲综合在线 | 五月天婷婷精品视频 | 亚洲欧美日韩在线精品2021 | 欧洲乱码专区一区二区三区四区 | 大尺度在线 | 色综合亚洲天天综合网站 | 欧美一级乱理片免费观看 | 午夜寂寞在线一级观看免费 | 天堂中文字幕在线 | 男女一级特黄a大片 | 国产理论最新国产精品视频 | 伊人亚洲 | 久久久久国产精品免费免费 | 中文字幕网资源站永久资源 | 护士一级aaaaaa毛片 | 男男生子大肚play做到生 | 午夜影院404 | 午夜黄网| 四虎www成人影院观看 |