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

1. 方案簡介

? ? ? ?自學習:在識別前對物體圖片進行模型學習,訓練完成后通過算法分類得出圖像的模型ID。

? ? ? ?方案設計邏輯流程圖,方案代碼分為分為兩個業務流程,主體代碼負責抓取、合成圖像,算法代碼負責訓練和檢測功能。

2. 快速上手

2.1 開發環境準備

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

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

cd ~/develop_environment
./run.sh

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-Solution.git

? ?注:

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

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

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

cd EASY-EAI-Toolkit-C-Solution/solu-selfLearning/
./build.sh

? 注:

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

? 注:

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

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

* 若build.sh腳本帶有clear參數,則會把build/目錄和Release/目錄刪除。

2.3 模型獲取

? ? ? ?【百度網盤】

? ? ? ?鏈接:百度網盤 請輸入提取碼

? ? ? ?提取碼:0k7j

? ? ? ?本方案用到模型:classify.model

? ? ? ?直接把模型下載到本地Windows主機,復制。再進入PC端Ubuntu創建存放model目錄:

cd /opt
mkdir model

? ? ? ?然后把模型從本地Windows主機粘貼到PC端Ubuntu中:

2.4 方案部署

? ? ? ?使用下方命令再次回到開發實例目錄

cd /opt/EASY-EAI-Toolkit-C-Solution/solu-selfLearning/

? ? ? ?然后,將EASY-EAI編譯環境的編譯結果部署到板卡中(有兩種方法)。

? ? ? ?方法一:通過執行以下命令手動部署【推薦】

cp Release/solu-* /mnt/userdata/Solu
cp Release/simhei.ttf /mnt/userdata/Solu

? ? ? ?方法二:在編譯時加上編譯參數自動部署

./build.sh cpres

? ? ? ?最后,將準備好的模型部署到板卡中(注意:模型要放到編譯結果的同一目錄中),執行命令如下所示。

cp /opt/model/classify.model /mnt/userdata/Solu

2.5 示例方案運行

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

adb shell

? ? ? ?進入板卡后,定位到例程部署的位置,如下所示:

cd /userdata/Solu

? ? ? ?運行例程命令如下所示:

./solu-selfLearning

2.6 運行效果

? ? ? ?運行打印如下:

? ? ? ?用攝像頭對準訓練物體,雙擊屏幕進行訓練。一個模型訓練5張圖片,總共訓練3個模型:

? ? ? ?訓練完成后進入識別模式:

2.7 開機啟動

? ? ? ?首先進入板卡環境,執行以下命令,在板卡上創建一個給本例程使用的應用目錄:myapp

cd /userdata/apps/
mkdir myapp

? ? ? ?然后回到開發環境中,通過使用“2.4方案部署”類似的操作方法,把本例程所需要的全部文件,包含:編譯結果,配置文件,模型等。部署到剛剛新建的myapp目錄中。

? ? ? ?最后在板卡上創建一個run.sh腳本來管控用戶所有需要的應用即可,《入門指南/應用程序開機自啟動》會詳細描述run.sh腳本該如何編寫。

3. 代碼解析

? ? ? ?方案主邏輯代碼位于:EASY-EAI-Toolkit-C-Solution/ solu-selfLearning/src/main.cpp代碼實現主要通過調用我司的easyeai-api庫快速實現自學習圖像分類功能,代碼主體分為主線程,算法分析子線程和按鍵模型訓練回調。

3.1 組件庫組成

?????? 要實現自學習圖像分類功能,需要使用到easyeai-api庫的以下組件。

?????? 模組信息如下所示。

組件頭文件以及庫路徑描述
系統操作組件easyeai-api/common_api/system_opt提供線程操作函數
攝像頭組件easyeai-api/peripheral_api/camera提供攝像頭操作函數
顯示屏組件easyeai-api/peripheral_api/display提供顯示屏操作函數
自學習組件easyeai-api/algorithm_api/self_learning提供自學習操作函數
中文字庫組件easyeai-api/common_api/font_engine提供中文顯示操作函數
觸摸屏組件easyeai-api/peripheral_api/touchscreen提供觸摸屏操作函數

?????? 這些組件通過CMakeLists.txt編譯進工程,具體請看后續章節。

3.2 邏輯框圖

?????? 項目的整體邏輯框圖如下所示。

3.3 主線程

?????? 主線程處理的業務有:

  • 初始化外設;
  • 創建算法分析子線程;
  • 創建觸摸屏回調函數
  • 抓圖發送給到子線程;
  • 抓圖、顯示;

?????? 本處附上主要的邏輯功能代碼,其他輔助的、校驗型的代碼先忽略。

? ? ? ?組件初始化操作如下,本處調用RGB攝像頭。

// 1.打開攝像頭
ret = rgbcamera_init(CAMERA_WIDTH, CAMERA_HEIGHT, 90);
pbuf = NULL;
pbuf = (char *)malloc(IMAGE_SIZE);

?????? 創建線程互斥鎖以及線程,如下所示。

// 2.創建識別線程,以及圖像互斥鎖
pthread_mutex_init(&img_lock, NULL);
CreateNormalThread(detect_thread_entry, &result, &mTid);

?????? 初始化顯示屏,如下所示。

// 3.顯示初始化
ret = disp_init(SCREEN_WIDTH, SCREEN_HEIGHT);

? ? ? ?抓取圖像,調用clone操作。

// 4.(取流 + 顯示)循環
pthread_mutex_lock(&img_lock);
ret = rgbcamera_getframe(pbuf);algorithm_image = Mat(CAMERA_HEIGHT, CAMERA_WIDTH, CV_8UC3, pbuf);
image = algorithm_image.clone();
pthread_mutex_unlock(&img_lock);

?????? 調用顯示圖像,將分析的結果通過result標記出來。

// 寫入文字
char label_text[50];
char label_text2[50];
if(1 == train_flag){/*識別模式*/memset(label_text, 0 , sizeof(label_text));memset(label_text2, 0 , sizeof(label_text2));sprintf(label_text, "訓練結束,開始識別"); sprintf(label_text2, "模型ID:%d",result); 
}else{/*訓練模式*/memset(label_text, 0 , sizeof(label_text));memset(label_text2, 0 , sizeof(label_text2));sprintf(label_text, "模型訓練中,雙擊屏幕開始訓練"); sprintf(label_text2, "模型ID:%d , 訓練次數:%d",mode_data , train_data_cnt); 
}
putText(image.data, image.cols, image.rows, label_text, 30, 30, color);
putText(image.data, image.cols, image.rows, label_text2, 30, 1000, color);
IplImage tmp = IplImage(image);
CvArr* arr = (CvArr*)&tmp;
CvRect rect1 = cvRect(20,300,680,680);
drawDashRect(arr,1,2,&rect1,CV_RGB(253,255,85),2);
disp_commit(image.data, IMAGE_SIZE);

3.4? 觸摸屏回調函數

? ? ? ?觸摸屏回調函數,主要完成以下操作:

  • 判斷有雙擊屏幕事件發生;
  • 延時監測是否圖像緩沖區是否為空;
  • 不為空時,證明主函數已發送圖像數據過來,執行圖像獲取操作;
  • 雙擊屏幕時,將主線程圖像送入算法接口進行模型訓練;

3.5 算法分析子線程

?????? 算法分析子線程,主要完成以下操作:

  • 延時監測是否圖像緩沖區是否為空;
  • 不為空時,證明主函數已發送圖像數據過來,線程執行圖像獲取操作;
  • 調用模型分類分析函數;
  • 記錄模型ID,用于主線程圖像合成操作;

?????? 延時監測是否有圖像,操作如下所示。

if(algorithm_image.empty()) {usleep(5);continue;
}

?????? 獲取圖像操作如下所示。

pthread_mutex_lock(&img_lock);
image = algorithm_image.clone();
pthread_mutex_unlock(&img_lock);

?????? 調用模型分類函數,算法得到的目標結果記錄于*share_para內,如下所示。

// 算法分析
*share_para = self_learning_inference(classify_ctx, image, train_data, train_data_count, k_value);	

4. 開發指南

4.1 示例文件&目錄結構

?????? Solution git倉庫會隨著產品迭代更新,不斷新增解決方案代碼,當前截圖只作參考。

4.1.1 Solution git倉庫目錄介紹。

?????? Solution工程構成如下所示,由功能組件easyeai-api和各個解決方案構成。

? ? ? ?單個“solu-”開頭的目錄即為一個解決方案案例,代碼內調用“EASY EAI-API”來滿足某一實際應用場景的需求。??????

? ? ? ?功能組件的描述如下所示,easyeai-api是經過高度封裝的易用性組件接口,便于用戶直接調用板卡資源。

功能組件目錄組件子目錄描述
功能組件easyeai-apialgorithm_api算法組件
common_api通用組件
media_api多媒體組件
netProtocol_api網絡協議組件
peripheral_api外設硬件組件

4.1.2 解決方案最基本的目錄構成。

?????? 每個解決方案就是一個獨立的項目,項目內包含部分如下所示,項目使用cmake構建自動編譯部署。

?????? 具體介紹如下所示。

組成部分描述
build.sh編譯腳本,用于管理生成可執行文件后的部署準備工作,用戶可自定義shell命令
CMakeLists.txt工程管理文件,用于組織整個工程結構,指導cmake生成Makefile
include用于存放第三方應用庫、頭文件目錄等
src用于存放實現本方案需求的源代碼
  • 增加已編譯的第三方庫,在include、libs目錄內添加頭文件和庫文件;
  • 增加用戶自定義的功能模塊,推薦在src目錄內增加;

?????? 具體情況如下所示,第三方模塊相關的文件由include/3rd_model/xxx.h、libs/3rd_model/xxx.a。自定義的功能模塊為src/mySrcCode、src/mySrcCode2。

4.2 CMakeLists.txt文件解析

4.2.1 編譯環境配置部分:

? ? ? ?第一部分為配置部分,配置部分如下所示。(獲取當前方案目錄、配置工具鏈、提取方案名稱):

?????? 配置信息如下所示。

配置項描述
CMake要求版本cmake_minimum_required函數指定,要求的最低版本
CMAKE_SYSTEM_NAMEcmake的系統類型,交叉編譯必須
CMAKE_CROSSCOMPILINGcmake是否啟動交叉編譯
cross.camkecamke_host_system_information獲取平臺信息,發現不是armv7l就導入當前平臺的交叉編譯配置。
project項目名由project函數指定

4.2.2 easyeai-api配置部分

?????? 第二部分是引入我司的功能組件庫(針對當前方案進行:配置EASY EAI API頭文件目錄、庫文件目錄以及配置庫鏈接參數):

?????? 配置信息如下所示。

配置項描述
api_inc最終通過target_include_directories函數指定目標包含的頭文件路徑
link_directories由link_directories函數指定easyeai-api庫所在路徑
LINK_LIBRARIES由LINK_LIBRARIES函數指定easyeai-api庫文件

4.2.3 第三方庫配置部分

? ? ? ?第三部分配置第三方的庫(針對當前方案進行:配置第三方頭文件目錄、庫文件目錄、配置第三方庫鏈接參數以及配置源碼目錄):

?????? 配置信息如下所示。

配置項描述
custom_inc自定義變量custom_inc,最終通過target_include_directories函數指定目標包含的頭文件路徑,在源碼include目錄下
link_directories由link_directories函數指定第三方庫所在路徑
custom_libs自定義變量custom_libs,最終通過target_link_libraries函數指定目標引用的庫鏈接參數
aux_source_directory自定義變量dir_srcs,用于添加工程代碼以及自定義的個人代碼

?????? 例如添加個人庫的目錄組成方式如下所示。

? ? ? ? aux_source_directory的修改方式為:

aux_source_directory(./src ./src/mySrcCode ./src/mySrcCode2 dir_srcs)

? ? ? ?或

aux_source_directory(./src dir_srcs)
aux_source_directory(./src/mySrcCode dir_srcs)
aux_source_directory(./src/mySrcCode2 dir_srcs)

4.2.4 本方案配置部分

? ? ? ?第四部分配置項目的編譯信息,內容如下所示:

?????? 配置項如下所示。

配置項描述
add_executable編譯結果為${CURRENT_FOLDER}指定,即方案目錄名;
編譯的源文件為${dir_srcs}指定;
target_include_directories指定頭文件的名字,由${api_inc}與${custom_inc}指定;
target_link_libraries指定額外的庫,例如opencv的庫等

4.3 build.sh編譯腳本:

4.3.1 路徑定位部分

? ? ? ?第一部分用于提取目錄用于編譯操作,內容如下所示:(進入build.sh腳本所在目錄,并且提取當前目錄絕對路徑,提取當前目錄名稱)

4.3.2 清除編譯部分

? ? ? ?第二部分清除操作,清除目錄為build、Release,內容如下所示:(執行build.sh腳本時,帶入了參數“clear”,則清空編譯輸出)

4.3.3 編譯操作

? ? ? ?第三部分,編譯直接調用cmake,內容如下所示:(重新編譯,成部署目錄,并把資源自動部署進板卡)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/76319.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/76319.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/76319.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

cat命令查看文件行數

在Linux和Unix-like操作系統中,cat命令主要用于查看文件內容,而不是直接用來查看文件行數。如果你想要查看一個文件的行數,可以使用以下幾種方法: 方法1:使用wc命令 wc(word count)命令可以用…

git清理已經刪除的遠程分支

目錄 命令作用 使用場景 示例流程 注意事項 常見問題 git remote update origin --prune git remote update origin --prune 是一個 Git 命令,用于 更新本地遠程跟蹤分支 并 清理(刪除)本地已失效的遠程分支引用。以下是詳細分解&#…

NLP高頻面試題(四十)——什么是 BitFit?

BitFit(Bias-term Fine-tuning)是一種參數高效的微調方法,專注于在預訓練模型中僅調整偏置項(bias term),而將其他參數保持不變。這種方法在自然語言處理領域,尤其是在中小規模數據集上,展現出了與全量微調相媲美的性能,同時顯著減少了計算資源的消耗。 什么是 BitFi…

Java-servlet(完結篇)過濾器亂碼解決與監聽器

Java-servlet(完結篇)過濾器亂碼解決與監聽器 前言一、過濾器亂碼解決二、監聽器1. HttpSessionListener2. ServletContextListener3. ServletRequestListener 三、監聽器的使用場景Java-servlet 結語 前言 在之前的 Java Servlet 學習中,我…

為了避免unboundLocalError和為什么X的值一直不變呢?

## 1.為了避免unboundLocalError 發生unboundLocalError! def generate_integer(level):if level 1:X randint(1,9)return X這里出錯的原因在于,一旦if 后面的條件沒有成立,然后X根本沒出生,然后你去使用它,這是有…

opencv-python基礎

一.opencv-python簡述 其使用Numpy,所有OpenCV數組結構都轉換為Numpy數組,是一個高度優化的數據庫操作庫。 二.環境安裝 pip install -i https://pypi.tuna.tsinghua.edu.cn/simple opencv-python 三.基本概念 - 像素是圖像的基本單元,每個…

ReentrantLock 實現公平鎖和非公平鎖的原理!

🌟我的其他文章也講解的比較有趣😁,如果喜歡博主的講解方式,可以多多支持一下,感謝🤗! 🌟了解 ThreadLocal請看: ThreadLocal有趣講解,小白也能聽懂&#xff…

NLP高頻面試題(四十一)——什么是 IA3 微調?

隨著大型語言模型的廣泛應用,如何高效地將這些模型適配到特定任務中,成為了研究和工程實踐中的重要課題。IA3(Infused Adapter by Adding and Adjusting)微調技術,作為參數高效微調的一種新穎方法,提供了在保持模型性能的同時,顯著減少可訓練參數數量的解決方案。 IA3 …

swift菜鳥教程14(閉包)

一個樸實無華的目錄 今日學習內容:1.Swift 閉包1.1閉包定義1.2閉包實例1.3閉包表達式1.3.1sorted 方法:據您提供的用于排序的閉包函數將已知類型數組中的值進行排序。1.3.2參數名稱縮寫:直接通過$0,$1,$2來順序調用閉包的參數。1.3.3運算符函…

藍橋杯-藍橋幼兒園(Java-并查集)

并查集的核心思想 并查集主要由兩個操作構成: Find:查找某個元素所在集合的根節點。并查集的特點是,每個元素都指向它自己的父節點,根節點的父節點指向它自己。查找過程中可以通過路徑壓縮來加速后續的查找操作,即將路…

ruby內置全局變量

以下是 Ruby 中常見的 內置全局變量 及其用途的詳細說明。這些變量以 $ 開頭,由 Ruby 解釋器自動管理,用于訪問系統狀態、異常、輸入輸出等核心信息。 一、異常處理相關 全局變量說明示例$!當前作用域最后拋出的異常對象(等同于 rescue >…

tcp轉串口

windows 在 Windows 系統上,可以使用以下成熟的串口轉 TCP 工具: HW VSP3 (HW Virtual Serial Port) 提供串口到 TCP/IP 的映射功能。支持虛擬串口和網絡通信。下載地址:HW Group com0com com2tcp 開源工具,支持虛擬串口和 TCP…

HTML視頻和音頻

<video>元素 <video>元素用于在HTML文檔中嵌入視頻內容。 <video controls><source src"movie.mp4" type"video/mp4"><source src"movie.ogg" type"video/ogg">您的瀏覽器不支持 HTML5 video 標簽。 …

DeepSeek:重構辦公效率的AI新范式

目錄 一、效率躍遷的三重引擎 二、效率提升的量級突破 三、智能辦公的范式轉移 四、未來辦公的效率奇點 當企業主面對堆積如山的文件審批、跨時區協作的溝通損耗、重復機械的數據整理時&#xff0c;是否想過這些場景正在吞噬團隊的生產力&#xff1f;據麥肯錫研究顯示&…

redis 延遲雙刪

Redis延遲雙刪是一種用于解決緩存與數據庫數據一致性問題的策略&#xff0c;通常在高并發場景下使用。以下是其核心內容&#xff1a; 1. 問題背景 當更新數據庫時&#xff0c;如果未及時刪除或更新緩存&#xff0c;可能導致后續讀請求仍從緩存中讀取舊數據&#xff0c;造成數…

Python設計模式:策略模式

1. 什么是策略模式 策略模式&#xff08;Strategy Pattern&#xff09;是一種行為型設計模式&#xff0c;它定義了一系列算法&#xff0c;將每個算法封裝起來&#xff0c;并使它們可以互換。策略模式使得算法的變化獨立于使用算法的客戶。換句話說&#xff0c;策略模式允許在運…

SpringBoot集成Ollama本地模型

SpringBoot集成Ollama本地模型 目錄 項目準備創建Ollama服務客戶端創建控制器配置應用屬性創建前端界面添加靜態資源支持完整項目結構啟動應用高級功能擴展部署注意事項性能優化 1. 項目準備 創建一個SpringBoot項目&#xff0c;可以使用Spring Initializr或IDE創建添加必要…

ResNet改進(19):基于PyTorch的ResNet改進方案詳解:Mish激活+SPP模塊+MixUp數據增強

1. 前言 ResNet作為深度學習領域里程碑式的網絡架構,在圖像分類等計算機視覺任務中表現出色。然而,隨著研究的深入和技術的發展,原始的ResNet架構仍有改進空間。本文將詳細介紹一種基于PyTorch的ResNet改進方案,該方案融合了Mish激活函數、SPP模塊和MixUp數據增強等先進技…

leetcode68.左右文本對齊

思路源自 leetcode-字符串篇 68題 文本左右對齊 難度高的模擬類型題目&#xff0c;關鍵點在于事先知道有多少單詞要放在本行并且還要知道本行是不是最后一行&#xff08;最后一行需要全部單空格右對齊&#xff0c;不是最后一行就空格均攤&#xff09;&#xff0c;非最后一行的空…

深入理解 Spring 的 MethodParameter 類

MethodParameter 是 Spring 框架中一個非常重要的類&#xff0c;它封裝了方法參數&#xff08;或返回類型&#xff09;的元數據信息。這個類在 Spring MVC、AOP、數據綁定等多個模塊中都有廣泛應用。 核心功能 MethodParameter 主要提供以下功能&#xff1a; 獲取參數類型信息…