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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

10行代碼輕松在ZYNQ MP上實(shí)現(xiàn)圖像識(shí)別的步驟

FPGA技術(shù)江湖 ? 來(lái)源:XILINX開(kāi)發(fā)者社區(qū) ? 2023-07-04 09:20 ? 次閱讀

簡(jiǎn)介

Xilinx Vitis-AI 是用于 Xilinx 硬件平臺(tái)上的 AI 推理的開(kāi)發(fā)堆棧。它由優(yōu)化的 IP、工具、庫(kù)、模型和示例設(shè)計(jì)組成。

簡(jiǎn)單來(lái)說(shuō),它主要包含:

AI推理加速器IP,即DPU;

支持將AI模型優(yōu)化 (Optimizer)、量化 (Quantizer)、最后編譯 (Compiler) 成DPU運(yùn)行指令集的整套工具;

支撐模型運(yùn)行的運(yùn)行時(shí)庫(kù)(Vitis-AI runtime, Vitis-AI library);

d4593826-19f1-11ee-962d-dac502259ad0.png

本案例中,我們將使用 Xilinx Kria KV260開(kāi)發(fā)板(包含ZynqMP器件)為目標(biāo)運(yùn)行設(shè)備。

本文使用的Vitis-AI 版本為1.4, 使用的platform基于Vitis/Vivado 2020.2。為了方便快速部署,我們直接使用官方發(fā)布的Linux系統(tǒng)啟動(dòng)鏡像, 并且使用Vitis-AI library為編程接口。

準(zhǔn)備工作

開(kāi)始工作前我們需要先搭建好運(yùn)行環(huán)境,包括設(shè)置host端(X86機(jī)器)的交叉編譯環(huán)境,以及 target端(KV260)的啟動(dòng)鏡像燒寫(xiě)。

本文的主要目的是闡述 Vitis-AI Library 的使用,故運(yùn)行環(huán)境的搭建不做過(guò)多介紹,可以完全參考以下鏈接中的步驟

“Step1: Setup cross-compiler”

“Step2: Setup the Target”

注意因?yàn)镵V260 的Vitis-AI 1.4 platform基于Vitis/Vivado 2020.2, 配置交叉編譯環(huán)境使用的腳本為host_cross_compiler_setup_2020.2.sh

因?yàn)槲覀兪褂霉俜絾?dòng)鏡像,Step2中標(biāo)注為“Optional”的步驟我們都可以省略。

當(dāng)KV260成功啟動(dòng),我們會(huì)在console中看到如下提示符:

root@xilinx-k26-starterkit-2020_2:~#

程序編譯

可通過(guò)如下方式獲得本案例中的代碼,

主要用到的文件為classification.cpp和Makefile。另外幾個(gè)Jpeg文件可用于后續(xù)測(cè)試輸入。

安裝準(zhǔn)備工作章節(jié)中配置好交叉編譯環(huán)境后,切換到源碼目錄中直接運(yùn)行make。make完成后文件夾中會(huì)生成執(zhí)行文件“classification”。

運(yùn)行演示

KV260 連接好串口,從SD卡啟動(dòng)運(yùn)行(記得提前把執(zhí)行文件和測(cè)試圖片拷貝到SD下),

切換到執(zhí)行文件和測(cè)試圖片目錄下,運(yùn)行 ./classification.JPEG

分類結(jié)果如下:

d4981e4c-19f1-11ee-962d-dac502259ad0.png

圖片原圖:

d528de00-19f1-11ee-962d-dac502259ad0.png

代碼分析

Vitis-AI包含了兩組編程接口:VART (Vitis-AI Runtime) 比較底層,提供更大的自由度;Vitis-AI library屬于高層次API,構(gòu)建于 VART 之上,通過(guò)封裝許多高效、高質(zhì)量的神經(jīng)網(wǎng)絡(luò),提供更易于使用的統(tǒng)一接口。

Vitis-AI Library的組成如下圖,包含 base libraries, model libraries, library test samples, application demos幾個(gè)部分:

base libraries提供底層接口;

model libraries是重要的部分,提供了主流模型(classification, detection, segmentation…) 的調(diào)用方法;

library test samples和application demos主要提供library的使用示例;

d57df43a-19f1-11ee-962d-dac502259ad0.png

再來(lái)看本例子,如何用簡(jiǎn)單到10行代碼實(shí)現(xiàn)圖片分類:

int main(int argc, char* argv[]) {

std::string image_name = argv[1];

auto image = cv::imread(image_name);

auto network = vitis::create("resnet50");

auto result = network->run(image);

cout << "Classification result:" << endl;

for (const auto &r : result.scores){

cout << result.lookup(r.index) << ": " << r.score << endl;

}

}

源文件中除去include部分,只有10行代碼,代碼中最重要的有兩句,第一句調(diào)用create方法創(chuàng)建了Classification類的一個(gè)實(shí)例,第二句調(diào)用run方法來(lái)運(yùn)行神經(jīng)網(wǎng)絡(luò)獲得推理結(jié)果。

auto network = vitis::create("resnet50");

auto result = network->run(image);

vitis::Classification 是 model libraries 中的一個(gè)基礎(chǔ)類,其作用是進(jìn)行圖片分類,這個(gè)類中包含如下方法:

d59717f8-19f1-11ee-962d-dac502259ad0.png

其中create方法接受一個(gè)模型名稱作為參數(shù),返回一個(gè)Classification類的實(shí)例。在安裝了Vitis-AI Library的開(kāi)發(fā)板上,已經(jīng)訓(xùn)練編譯好的模型文件放在開(kāi)發(fā)板的/usr/share/vitis_ai_library/models/目錄下,Vitis-AI Library會(huì)通過(guò)傳遞給create方法的模型名稱來(lái)調(diào)用這些模型文件,比如我們用到的resnet50模型文件位置如下,

d5cecb80-19f1-11ee-962d-dac502259ad0.png

如果用戶訓(xùn)練并編譯好了自己的模型,也可以把自己的模型文件放到對(duì)應(yīng)位置來(lái)使用。

run方法接受一個(gè)/一組圖片作為輸入,輸出這個(gè)/這些圖片的分類結(jié)果。其工作簡(jiǎn)單來(lái)說(shuō)就是把模型文件和圖片數(shù)據(jù)傳送給DPU, DPU運(yùn)行并輸出推理結(jié)果,CPU再讀回結(jié)果。

再看下添加了注釋的代碼片段,整個(gè)過(guò)程實(shí)際上非常簡(jiǎn)單明了。

int main(int argc, char* argv[]) {

std::string image_name = argv[1];

auto image = cv::imread(image_name); // 讀入圖片

auto network = vitis::create("resnet50"); // 用resnet50模型創(chuàng)建Classification類實(shí)例

auto result = network->run(image); //運(yùn)行模型

cout << "Classification result:" << endl;

for (const auto &r : result.scores){

cout << result.lookup(r.index) << ": " << r.score << endl; //輸出模型運(yùn)行結(jié)果

}

}

除了Classification基礎(chǔ)類, Vitis-AI Library包含了非常多的常用機(jī)器學(xué)習(xí)任務(wù)(classification, detection, segmentation…)的基礎(chǔ)類。這些類的使用方法基本一致,

首先通過(guò)create方法創(chuàng)建基礎(chǔ)類的實(shí)例,

通過(guò)getInputWidth()/getInputHeight()來(lái)獲取模型需要的圖片尺寸,

resize圖片,

運(yùn)行run方法來(lái)運(yùn)行網(wǎng)絡(luò)獲得輸出。

總結(jié)

通過(guò)這個(gè)例子,我們看到通過(guò)Vitis-AI工具,可以大大縮減模型到部署之間的距離。Vitis-AI包含了常用模型的Model-Zoo, 提供簡(jiǎn)單易用的編程接口,甚至可以讓不熟悉機(jī)器學(xué)習(xí)或者FPGA的軟件開(kāi)發(fā)者都可以在極短的時(shí)間內(nèi)在FPGA/SoC器件上部署神經(jīng)網(wǎng)絡(luò)應(yīng)用。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 神經(jīng)網(wǎng)絡(luò)

    關(guān)注

    42

    文章

    4777

    瀏覽量

    100973
  • SD卡
    +關(guān)注

    關(guān)注

    2

    文章

    566

    瀏覽量

    64008
  • DPU
    DPU
    +關(guān)注

    關(guān)注

    0

    文章

    365

    瀏覽量

    24218
  • Zynq
    +關(guān)注

    關(guān)注

    10

    文章

    610

    瀏覽量

    47231

原文標(biāo)題:10行代碼輕松在ZYNQ MP上實(shí)現(xiàn)圖像識(shí)別

文章出處:【微信號(hào):HXSLH1010101010,微信公眾號(hào):FPGA技術(shù)江湖】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何用10代碼輕松ZYNQ MP實(shí)現(xiàn)圖像識(shí)別

    Vitis-AI工具,如何僅僅使用10代碼,就能在ZYNQ MP器件上部署深度學(xué)習(xí)模型實(shí)現(xiàn)
    的頭像 發(fā)表于 10-09 10:47 ?4685次閱讀
    如何用<b class='flag-5'>10</b><b class='flag-5'>行</b><b class='flag-5'>代碼</b><b class='flag-5'>輕松</b><b class='flag-5'>在</b><b class='flag-5'>ZYNQ</b> <b class='flag-5'>MP</b><b class='flag-5'>上</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>圖像識(shí)別</b>

    使用Python卷積神經(jīng)網(wǎng)絡(luò)(CNN)進(jìn)行圖像識(shí)別的基本步驟

    Python 卷積神經(jīng)網(wǎng)絡(luò)(CNN)圖像識(shí)別領(lǐng)域具有廣泛的應(yīng)用。通過(guò)使用卷積神經(jīng)網(wǎng)絡(luò),我們可以讓計(jì)算機(jī)從圖像中學(xué)習(xí)特征,從而實(shí)現(xiàn)對(duì)圖像的分
    的頭像 發(fā)表于 11-20 11:20 ?6402次閱讀

    【瑞芯微RK1808計(jì)算棒試用申請(qǐng)】圖像識(shí)別以及芯片評(píng)測(cè)

    棒完成計(jì)算后把數(shù)據(jù)送回PC4,擁有PC開(kāi)發(fā)界面經(jīng)驗(yàn),有使用python開(kāi)發(fā)PyQt5界面經(jīng)驗(yàn),能工完成PC端數(shù)據(jù)處理,圖像傳送和接收預(yù)計(jì)成果:1,PyQT界面,實(shí)現(xiàn)圖像傳送和接收功能2,計(jì)算棒端數(shù)據(jù)處理
    發(fā)表于 09-18 19:21

    如何構(gòu)建基于圖像識(shí)別的印制線路板精密測(cè)試系統(tǒng)?

    如何構(gòu)建基于圖像識(shí)別的印制線路板精密測(cè)試系統(tǒng)?圖像識(shí)別技術(shù)印刷線路板精密測(cè)試中的應(yīng)用
    發(fā)表于 04-27 06:25

    圖像識(shí)別模組(包括PCB圖、圖像識(shí)別模組源代碼)

    圖像識(shí)別模組電路原理圖、圖像識(shí)別模組PCB圖、圖像識(shí)別模組源代碼、圖像識(shí)別模組用戶使用手冊(cè)
    發(fā)表于 01-02 19:14 ?121次下載

    FPGA平臺(tái)實(shí)現(xiàn)基于遺傳算法的圖像識(shí)別的研究

    FPGA平臺(tái)實(shí)現(xiàn)基于遺傳算法的圖像識(shí)別的研究
    發(fā)表于 08-29 15:02 ?11次下載

    實(shí)驗(yàn)python進(jìn)行圖像識(shí)別的示例代碼資料免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是實(shí)驗(yàn)python進(jìn)行圖像識(shí)別的示例代碼資料免費(fèi)下載。
    發(fā)表于 06-14 08:00 ?3次下載

    使用FPGA平臺(tái)實(shí)現(xiàn)遺傳算法的圖像識(shí)別的研究設(shè)計(jì)說(shuō)明

    利用模板匹配方法,采用基于遺傳算法的圖像識(shí)別技術(shù),完成了對(duì)圖像目標(biāo)識(shí)別的算法驗(yàn)證。在此基礎(chǔ)上進(jìn)行了基于該算法的圖像識(shí)別系統(tǒng)的FPGA實(shí)現(xiàn),并
    發(fā)表于 01-26 15:02 ?13次下載
    使用FPGA平臺(tái)<b class='flag-5'>實(shí)現(xiàn)</b>遺傳算法的<b class='flag-5'>圖像識(shí)別的</b>研究設(shè)計(jì)說(shuō)明

    如何在APT-Pi實(shí)現(xiàn)圖像識(shí)別功能

    不用自己訓(xùn)練模型,也能進(jìn)行 AI 圖像識(shí)別;借助百度云平臺(tái),我們可以 APT-Pi 實(shí)現(xiàn)圖像識(shí)別功能。 創(chuàng)建
    的頭像 發(fā)表于 10-09 15:46 ?1.1w次閱讀
    如何在APT-Pi<b class='flag-5'>上</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>圖像識(shí)別</b>功能

    10代碼輕松ZYNQ MP實(shí)現(xiàn)圖像識(shí)別

    如今各種機(jī)器學(xué)習(xí)框架的普及使得個(gè)人搭建和訓(xùn)練一個(gè)機(jī)器學(xué)習(xí)模型越來(lái)越容易。然而現(xiàn)實(shí)中大量的機(jī)器學(xué)習(xí)模型訓(xùn)練完后需要在邊緣端部署,那么我們看看借助Xilinx Vitis-AI工具,如何僅僅使用10代碼,就能在
    的頭像 發(fā)表于 08-02 08:03 ?2238次閱讀
    <b class='flag-5'>10</b><b class='flag-5'>行</b><b class='flag-5'>代碼</b><b class='flag-5'>輕松</b><b class='flag-5'>在</b><b class='flag-5'>ZYNQ</b> <b class='flag-5'>MP</b><b class='flag-5'>上</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>圖像識(shí)別</b>

    卷積神經(jīng)網(wǎng)絡(luò)用于圖像識(shí)別的原理

    機(jī)器視覺(jué)領(lǐng)域,圖像識(shí)別是指軟件識(shí)別人物、場(chǎng)景、物體、動(dòng)作和圖像寫(xiě)入的能力。為了實(shí)現(xiàn)圖像識(shí)別,計(jì)
    發(fā)表于 08-20 09:56 ?1317次閱讀
    卷積神經(jīng)網(wǎng)絡(luò)用于<b class='flag-5'>圖像識(shí)別的</b>原理

    模擬矩陣圖像識(shí)別中的應(yīng)用

    訊維模擬矩陣圖像識(shí)別中的應(yīng)用主要是通過(guò)構(gòu)建一個(gè)包含多種圖像數(shù)據(jù)的模擬矩陣,來(lái)訓(xùn)練和測(cè)試深度學(xué)習(xí)模型,從而提高圖像識(shí)別的準(zhǔn)確性和效率。
    的頭像 發(fā)表于 09-04 14:17 ?603次閱讀
    模擬矩陣<b class='flag-5'>在</b><b class='flag-5'>圖像識(shí)別</b>中的應(yīng)用

    如何使用Python進(jìn)行圖像識(shí)別的自動(dòng)學(xué)習(xí)自動(dòng)訓(xùn)練?

    如何使用Python進(jìn)行圖像識(shí)別的自動(dòng)學(xué)習(xí)自動(dòng)訓(xùn)練? 使用Python進(jìn)行圖像識(shí)別的自動(dòng)學(xué)習(xí)和自動(dòng)訓(xùn)練需要掌握一些重要的概念和技術(shù)。本文中,我們將介紹如何使用Python中的一些常用庫(kù)和算法來(lái)
    的頭像 發(fā)表于 01-12 16:06 ?617次閱讀

    圖像檢測(cè)和圖像識(shí)別的區(qū)別是什么

    圖像檢測(cè)和圖像識(shí)別是計(jì)算機(jī)視覺(jué)領(lǐng)域的兩個(gè)重要研究方向,它們許多應(yīng)用場(chǎng)景中都有著廣泛的應(yīng)用。盡管它們某些方面有相似之處,但它們之間還是存在一些明顯的區(qū)別。本文將從多個(gè)角度對(duì)
    的頭像 發(fā)表于 07-03 14:41 ?1125次閱讀

    圖像識(shí)別屬于人工智能嗎

    過(guò)程。它涉及到圖像的獲取、預(yù)處理、特征提取、分類和識(shí)別等多個(gè)環(huán)節(jié)。 1.2 重要性 圖像識(shí)別技術(shù)人工智能領(lǐng)域具有重要的地位,它使計(jì)算機(jī)能夠“看”和“理解”
    的頭像 發(fā)表于 07-16 10:44 ?1224次閱讀