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

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

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

深度解讀嵌入式視覺的幾個典型應(yīng)用

新機器視覺 ? 來源:博覽Boolan ? 作者:博覽Boolan ? 2021-09-23 16:38 ? 次閱讀

引言

如何做AI視覺應(yīng)用的嵌入式部署分為硬件選型,軟件框架和優(yōu)化的選擇,模型算法的設(shè)計三大板塊。

AI視覺應(yīng)用云端部署VS嵌入式端部署

大家其實對于AI深度學(xué)習(xí)已經(jīng)很熟悉了,我們在服務(wù)器上就可以用GPU或者Tensorflow來做訓(xùn)練,訓(xùn)練完之后要做推理計算。推理最簡單的一個方法就是放在云端,用云端推理的板卡比如NVIDIA的T4或者國產(chǎn)NPU做推理計算。在云端,推理計算是廣泛使用的。百度的API或者Face++等云端API是在前端探測數(shù)據(jù),把視頻圖像傳回云端,云端做完處理返回結(jié)果,這就是云端的部署。

嵌入式部署其實和云端部署很相似,只不過是在最后把模型發(fā)送到了嵌入式設(shè)備上(手機無人機),那它是在手機和無人機上來做推理計算,這就是我們認為嵌入式部署的AI使用模型情況。

1.1

嵌入式視覺典型應(yīng)用

列舉幾個典型的嵌入式視覺應(yīng)用。

第一個是輔助駕駛或者自動駕駛,在駕駛的車上會有AI處理加速的模塊,應(yīng)用了AI算法。在這種場景下做AI的嵌入式部署主要是為了環(huán)境的感知、目標(biāo)的檢測追蹤或者在無人機上可能會做視覺或激光的SLAM,為了在嵌入式端實現(xiàn)高實時性。

第二個是手機的美顏和AR。預(yù)覽和編輯操作都是在手機本地完成的,它其實是完成了更好的交互性,給用戶的體驗性更好。從另一方面對于手機APP公司來說,是更加節(jié)省成本的,比如你編輯一段視頻,這里的AR操作返回給服務(wù)器來做,成本是很高的。

第三個是邊緣智能化盒子,優(yōu)勢是兼容了已有的攝像頭。在安防場景和智能社區(qū)里已有很多傳統(tǒng)的攝像頭,但使用邊緣智能化盒子,能夠處理多路且兼容已有攝像頭,從節(jié)省成本上來說也是一個好的選擇。

嵌入式AI硬件選型

2.1

Intel CPU或NVIDIA GPU

嵌入式AI的硬件是怎么選型的?

第一個常見的類型是工控機,用X86的CPU加上NVIDIA的GPU,這種好處就是生態(tài)分層成熟。如果是純CPU的應(yīng)用,深度學(xué)習(xí)一類的應(yīng)用算力可能會偏弱。

第二個是NVIDIA的TX2和Nano系列,NVIDIA對于嵌入式的AI有專門的這種SoC的芯片,也出了很多板卡,相對成本低,算力也比服務(wù)器低。GPU支持了FP16和FP32的精度,對于嵌入式部署是很有幫助的,意味著模型精度和服務(wù)器上訓(xùn)練的精度幾乎能保持一致。

服務(wù)器都是用32位做訓(xùn)練,如果說其他的NPU轉(zhuǎn)換成Int8的話,必然會造成精度的損失。唯一的弱點就是主CPU偏弱,就只是ARM Cortex-A57的四核或多核。如果放在無人機上使用,無人機應(yīng)用很多是很復(fù)雜的,不是深度學(xué)習(xí)或GPU就能加速的,這里用ARM Cortex-A57可能就會存在問題。這實際上是NVIDIA的嵌入式系列面臨的一些挑戰(zhàn),主要是要評估組合性能是不是好。

2.2

AMD APU

目前AMD的處理器用的偏少。它的CPU比較好,能夠?qū)?biāo)到i7主屏比較高的CPU ,GPU也不錯,比TX2的性能要提高2倍,整體性能還可以,也可以利用X86上面的生態(tài),存在的問題是它的編程需要OpenCL,這比CUDA要弱,就是它存在深度學(xué)習(xí)的部署門檻。另外就是它這款盒子的功耗偏高,比NVIADA的TX2或Nano高一倍,但性能加強了。利用AMD的APU盒子放在駕校車上是比較好用的。

2.3

主流嵌入式AI開發(fā)板

大家也知道具備NPU的SoC芯片其實是越來越多的,之前是以加速卡的形式來存在,比如一個USB的NPU加速棒插在已有設(shè)備上。如果你是做嵌入式的部署,不要選擇這種分離式的USB加速設(shè)備,因為它穩(wěn)定性較差,另外數(shù)據(jù)傳輸比較麻煩。盡量選擇集成在一起的帶NPU的SoC,這是第一選擇。目前帶NPU的SoC也是越來越多的,廠商也越來越多。在華為芯片被禁之前,市面上主要的選擇都是華為系列,大概有四款帶NPU的,從低端的0.5T-1T算力,2T-4T算力都有覆蓋。它的好處是成本相比較低,比NVIDIA的同樣算力成本要低很多;第二個是它的ISP挑的比較好。下面的都是可以替換華為系列的,可以選擇瑞芯微的RK3399、RK1808、RK3588或者全志等。

目前的NPU基本都是8bit量化,在8bit量化下模型精度是如何保證的,工具鏈的成熟度是一個問題,除此之外就是算力的選擇。如果說想替換華為芯片,要求其他選型是性能超過2T算力,ISP不錯,性價比不錯的SoC選擇目前是比較少的,至少在去年底來看還沒有。

第三塊常見的開發(fā)板工作是用FPGA來做AI計算,主要用在工業(yè)場景下,實時性更好。比如在野外、工業(yè)級的無人機或者研究所機構(gòu)會要求國產(chǎn)FPGA達到毫秒級左右的實時性。這部分的FPGA基本上是要自研AI的加速軟核。圖中是我們自研的一個AI加速軟核,它已經(jīng)支持了很多常見的FPGA,AI加速軟盒基本上結(jié)構(gòu)都是這樣。

這部分IP是一個軟核的IP,部署在FPGA資源上,核心部分有一個計算陣列,完成卷積操作。

如果NPU公司卷積只做一個3x3,就意味著這NPU是用不了的,雖然核心部分加速的很快,但是其他部分必須也是搬到NPU上才能整體的做嵌入式的部署和加速,所以就會需要有相應(yīng)的部署模塊緩沖數(shù)據(jù)。

數(shù)據(jù)搬運需要把它從內(nèi)存搬運到芯片的緩存上,控制邏輯相當(dāng)于發(fā)指令的,控制調(diào)度、計算部件是怎么執(zhí)行的,基本上NPU都是這幾個部件組成的,具體的差別是在于并行度的方式不同,可能加了不同的加速部件來得到更好的性能。對于NPU來說第一個要考查是卷積性能到底怎么樣,第二個算子是不是能支持的更多,支持的算子更多意味著在CPU端所跑的算子相對少一些而且支持的模型更多。

這個是我們實際用FPGA做了一些項目,做無人機,檢測情況和可見光的處理,都是比較常用的。

IoT級別的AI操作,我舉的例子是法國的一家叫Greenwave公司,做的是無人機的一個自主的飛行控制。在性能方面差很多,基本上只能做到每秒18幀的處理速度,計算在100M Hz的功耗頻率和6.5fps下整體的功耗是40mW,是非常低的功耗了。IoT級別還會使用在做智能門鈴的場景下,以前的門鈴只是用紅外線檢查是否有人過來,這個準(zhǔn)確度不高。如果是加一個智能喚醒模塊在門鈴上,就可以提高判斷的準(zhǔn)確性,這是IoT級別的智能識別圖像。

嵌入式AI軟件性能優(yōu)化

3.1

前向推理框架

實際上在軟件的推理框架上已經(jīng)有非常多的選擇了,有NVIDIA的TensorRT,Tensorflow lite,騰訊的NCNN,TNN,阿里MNN等等。圖中是Tensorflow lite整體的圖,從訓(xùn)練后的Tensorflow lite的網(wǎng)絡(luò)模型中間會有一個轉(zhuǎn)換步驟,轉(zhuǎn)換到Tensorflow lite支持的網(wǎng)絡(luò)結(jié)構(gòu),然后再嵌入到手機APP里。

前后推理框架的核心觀點有五個。第一個是設(shè)備管理,比如現(xiàn)在的嵌入式SoC有GPU或者NPU,推理框架能支持這些設(shè)備。第二個是模型管理,單模型和多模型是不同的管理方式。第三個是內(nèi)存管理和儲存格式,要考慮是以優(yōu)化內(nèi)存占用優(yōu)先還是以性能優(yōu)先。第四個是層級融合,Barch Norm層可以和卷積層合并,當(dāng)算子層中之間融合的越多,節(jié)省仿存的操作來發(fā)揮更多的效率。第五個是實現(xiàn)方法選擇,這塊需要框架要來處理,根據(jù)不同的輸入特性來選擇不同的實現(xiàn)算子優(yōu)化的方法,來達到最高的效率。

3.2

性能評價

看一下這個性能對比的例子,從算子優(yōu)化上其實就可以做到不少的性能提升,在算子上針對卷積算子做了優(yōu)化,在同樣的一個嵌入式的平臺,獲得了一倍的性能提升,硬件是完全相同的,就靠軟件來做。

以目前來說,性能差距已經(jīng)非常低了。圖中數(shù)據(jù)柱狀線代表的是時間,測了很多不同的模型。比如ARM Cortex-A76和ARM Cortex-A55,可以看到差距非常小。

我的結(jié)論是如果AI部署是用ARM的CPU,對于小模型哪個方便用哪個,對于大模型實際上是有NPU存在,可以直接用NPU來做,跟推理框架的成熟度關(guān)系不大。

3.3

NPU的性能優(yōu)化

NPU的部署應(yīng)該怎么做或者NPU的性能優(yōu)化能做什么,現(xiàn)在的NPU公司存在兩類情況,一類是完全封死的狀態(tài),通過Caffe做模型轉(zhuǎn)化,很多算子不支持,要回到CPU來做。

這種情況的轉(zhuǎn)化模型成本很高,遇到一個新的模型需要算法工程師進行手動切分,很少有工具去劃分哪些算子是NPU支持的,轉(zhuǎn)化起來就比較麻煩。另一類是類似GPU編程接口,就是提供一個基礎(chǔ)的加速部件,可以做算子的定制化,好處是網(wǎng)絡(luò)進展較快。當(dāng)出現(xiàn)特殊算子的時候,不用再放回CPU來做,可以在加速卡NPU上做,這是一個比較好的趨勢。

嵌入式AI算法模型

4.1

深度學(xué)習(xí)模型

針對嵌入式AI的深度學(xué)習(xí)模型大概有四塊,包含ARM Soc CPU、lnt8量化、模型剪枝和新的網(wǎng)絡(luò)結(jié)構(gòu)。ARM Soc CPU來跑深度學(xué)習(xí)模型,卷積在10層卷積或以下,就是小模型才能流暢的跑視覺應(yīng)用。

4.2

Int8量化精度

不管是在CPU還是NPU都要跑量化的模型,發(fā)揮著很重要的速度作用。量化的基本原理是如何用定點數(shù)來表示浮點數(shù),或者更高的效率表示浮點數(shù)?;镜墓绞钦麛?shù)值減去零點值得出的值乘以刻度值,得出一個浮點數(shù),簡單的量化就是這樣處理的。

在處理量化的時候需要注意,第一個轉(zhuǎn)化成量化是Per layer量化還是Per Channel量化,Per layer量化代表著輸出的全部用一個量化參數(shù),Per Channel量化代表著每一個Channel都是不同的,量化的系數(shù)也是不同的。目前來說如果想達到Int8量化比較好的精度,要求模型的權(quán)重參數(shù)要做Per Channel量化。Feature map一般都是用Per layer量化,成本相對較低,硬件實現(xiàn)也更容易。

第二個需要注意的是刻度值怎么選擇,一種是支持2的冪,轉(zhuǎn)化的乘法通過定點數(shù)的移位操作當(dāng)成浮點,硬件容易實現(xiàn),但精度值差。另一種就是支持任意浮點數(shù),精度值高。

第三個注意的是對稱量化和非對稱量化,是和零點值相關(guān)的。對稱量化的零點是不能動的,好處是更容易實現(xiàn),壞處是數(shù)據(jù)分布有問題。

第四個注意的是QAT,量化感知的訓(xùn)練。實際上就是把量化數(shù)據(jù)過程加入進去,讓權(quán)重參數(shù)和Feature map的浮點數(shù)來更容易被量化。

最后一個就是有些模型的量化精度是很難做,需要看大家對于量化精度調(diào)點的要求。不同意調(diào)點的就需要做混合來保證精度。

4.3

模型壓縮技術(shù)-剪枝法

模型壓縮有兩種常用的,一種是非結(jié)構(gòu)化的模型壓縮,靈活程度和稀疏度更高,目前的NPU、FPGA或者加速卡沒辦法去識別權(quán)重的零值。結(jié)構(gòu)化的剪枝就是去除Channel或layer,需要識別出哪些是重要的通道,哪些是不重要的。

當(dāng)剪枝和量化綜合在一起時可能會遇到新的問題。lnt8的量化是進一步的信息壓縮,從浮點到定點再到信息損失;剪枝是去除Channel或layer,也是對信息進行壓縮,當(dāng)兩部分結(jié)合時,有效信息被去除很多,導(dǎo)致精度大幅下降,有可能最后直接崩掉。在實際做的過程中,剪枝和量化需要迭代分開做,這樣才能保證精度。

總結(jié)

整體上在AI的嵌入式應(yīng)用里需要硬件的選型,軟件框架和優(yōu)化的選擇,模型算法的設(shè)計,剪枝和量化的綜合來處理完成,還需要考慮不同的AI部署應(yīng)用有不同的模型需求。

以上,感謝澎峰科技創(chuàng)始人張先軼在2021全球機器學(xué)習(xí)技術(shù)大會上的主題分享。

轉(zhuǎn)載自 | 博覽Boolan

編輯:jq

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

    關(guān)注

    5087

    文章

    19156

    瀏覽量

    306433
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10889

    瀏覽量

    212396
  • AI
    AI
    +關(guān)注

    關(guān)注

    87

    文章

    31273

    瀏覽量

    269637
  • NPU
    NPU
    +關(guān)注

    關(guān)注

    2

    文章

    286

    瀏覽量

    18679

原文標(biāo)題:談?wù)勄度胧揭曈X的幾個典型應(yīng)用

文章出處:【微信號:vision263com,微信公眾號:新機器視覺】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    嵌入式主板的概述與發(fā)展

    隨著科技的迅猛發(fā)展,嵌入式系統(tǒng)在現(xiàn)代電子產(chǎn)品中扮演著越來越重要的角色。嵌入式主板作為嵌入式系統(tǒng)的核心組件之一,承擔(dān)著控制、處理和通訊等多種功能。本文將對嵌入式主板的基本概念、構(gòu)成部分、
    的頭像 發(fā)表于 01-13 16:30 ?175次閱讀
    <b class='flag-5'>嵌入式</b>主板的概述與發(fā)展

    嵌入式系統(tǒng)開發(fā)與硬件的關(guān)系 嵌入式系統(tǒng)開發(fā)常見問題解決

    系統(tǒng)開發(fā)與硬件關(guān)系的幾個關(guān)鍵點: 硬件依賴性 :嵌入式系統(tǒng)的軟件必須能夠在特定的硬件上運行,這包括處理器、內(nèi)存、輸入/輸出接口等。軟件必須能夠充分利用硬件的特性,同時繞過其限制。 資源限制 :嵌入式系統(tǒng)通常具有有限
    的頭像 發(fā)表于 12-09 09:38 ?349次閱讀

    什么是嵌入式?一文讀懂嵌入式主板

    在現(xiàn)代科技浪潮中,嵌入式技術(shù)已成為支撐各種智能設(shè)備和系統(tǒng)運行的核心力量。那么,究竟什么是嵌入式?嵌入式系統(tǒng),顧名思義,是將計算機的硬件和軟件嵌入到某種設(shè)備或系統(tǒng)中,以實現(xiàn)特定功能的計算
    的頭像 發(fā)表于 10-16 10:14 ?1271次閱讀

    ARMxy嵌入式計算機在機器視覺中的卓越表現(xiàn)

    嵌入式視覺是指在嵌入式系統(tǒng)中使用計算機視覺技術(shù),與經(jīng)常所說的機器視覺系統(tǒng)的區(qū)別在于嵌入式
    的頭像 發(fā)表于 10-10 14:47 ?279次閱讀
    ARMxy<b class='flag-5'>嵌入式</b>計算機在機器<b class='flag-5'>視覺</b>中的卓越表現(xiàn)

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統(tǒng)的核心組件,是一種用于控制和數(shù)據(jù)處理的計算機硬件,其設(shè)計旨在嵌入特定設(shè)備中執(zhí)行專門任務(wù)。嵌入式主板如同是設(shè)備的“大腦”,主要功能是根據(jù)需要管理和控制設(shè)備
    的頭像 發(fā)表于 09-30 10:05 ?679次閱讀

    為何嵌入式控制器首選ARMxy?深度解析

    嵌入式ARM控制器是一種基于ARM架構(gòu)的嵌入式系統(tǒng)控制器,廣泛應(yīng)用于各種嵌入式系統(tǒng)中,包括工業(yè)物聯(lián)網(wǎng)關(guān)、邊緣計算網(wǎng)關(guān)、智慧城市、智能設(shè)備、工業(yè)自動化等領(lǐng)域。嵌入式ARM控制器具有高性能
    的頭像 發(fā)表于 09-21 10:09 ?340次閱讀
    為何<b class='flag-5'>嵌入式</b>控制器首選ARMxy?<b class='flag-5'>深度</b>解析

    嵌入式linux開發(fā)的基本步驟有哪些?

    之前,首先需要選擇合適的硬件平臺。硬件選擇需要考慮以下幾個方面: 1.1 處理器 嵌入式Linux開發(fā)需要一個處理器,常見的處理器有ARM、MIPS、PowerPC等。選擇處理器時,需要考慮處理器的性能、功耗、成本等因素。 1.2 存儲器
    的頭像 發(fā)表于 09-02 09:11 ?559次閱讀

    ARMxy ARM嵌入式計算機搭載 1 TOPS NPU支持深度學(xué)習(xí)

    ARMxy ARM嵌入式計算機BL410系列內(nèi)置了1TOPS算力 NPU,它每秒可以執(zhí)行高達一萬億次的浮點運算,這為復(fù)雜的圖像處理和深度學(xué)習(xí)任務(wù)提供了充足的計算資源。在產(chǎn)品缺陷檢測領(lǐng)域,ARMxy ARM嵌入式計算機具備的這一算
    的頭像 發(fā)表于 08-20 11:53 ?392次閱讀
    ARMxy ARM<b class='flag-5'>嵌入式</b>計算機搭載 1 TOPS NPU支持<b class='flag-5'>深度</b>學(xué)習(xí)

    機器視覺嵌入式中的應(yīng)用

    機器視覺嵌入式系統(tǒng)中的應(yīng)用是一個廣泛而深入的話題,涉及到許多不同的領(lǐng)域和技術(shù)。 機器視覺嵌入式系統(tǒng)中的應(yīng)用 1. 引言 機器視覺是一種模
    的頭像 發(fā)表于 07-16 10:30 ?563次閱讀

    深度學(xué)習(xí)算法在嵌入式平臺上的部署

    隨著人工智能技術(shù)的飛速發(fā)展,深度學(xué)習(xí)算法在各個領(lǐng)域的應(yīng)用日益廣泛。然而,將深度學(xué)習(xí)算法部署到資源受限的嵌入式平臺上,仍然是一個具有挑戰(zhàn)性的任務(wù)。本文將從嵌入式平臺的特點、
    的頭像 發(fā)表于 07-15 10:03 ?1557次閱讀

    嵌入式技術(shù)領(lǐng)域的視覺、安全與AI應(yīng)用

    本次2024年度德國版嵌入式世界展的大獎評選共收到全球百余家企業(yè)的申請,經(jīng)由評審團嚴(yán)格篩選,最終選出三項候選提名,并于會場進行了隆重的頒獎儀式。其中,嵌入式視覺、安全與安防、人工智能等應(yīng)用領(lǐng)域備受矚目。
    的頭像 發(fā)表于 04-29 11:20 ?388次閱讀

    深度詳解嵌入式系統(tǒng)專用輕量級框架設(shè)計

    MR 框架是專為嵌入式系統(tǒng)設(shè)計的輕量級框架。充分考慮了嵌入式系統(tǒng)在資源和性能方面的需求。通過提供標(biāo)準(zhǔn)化的設(shè)備管理接口,極大簡化了嵌入式應(yīng)用開發(fā)的難度,幫助開發(fā)者快速構(gòu)建嵌入式應(yīng)用程序。
    發(fā)表于 04-27 02:32 ?1019次閱讀
    <b class='flag-5'>深度</b>詳解<b class='flag-5'>嵌入式</b>系統(tǒng)專用輕量級框架設(shè)計

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術(shù)集成到嵌入式系統(tǒng)中的一種解決方案。嵌入式系統(tǒng)是一種為特定應(yīng)用而設(shè)計的計算機系統(tǒng),它通常包括處理器、內(nèi)存、外設(shè)接口等組件,并且被嵌入到更大的設(shè)備或系統(tǒng)中,
    的頭像 發(fā)表于 03-15 14:29 ?1310次閱讀

    fpga是嵌入式

    FPGA(現(xiàn)場可編程門陣列)不是嵌入式系統(tǒng),但FPGA在嵌入式系統(tǒng)中有著重要的應(yīng)用。
    的頭像 發(fā)表于 03-14 17:19 ?2411次閱讀

    嵌入式軟件設(shè)計的原則分享

    嵌入式軟件開發(fā)如果具有更好的閱讀性、擴展性以及維護性,就需要考慮很多因素。今天給大家分享幾個嵌入式軟件設(shè)計的原則。
    發(fā)表于 02-25 10:54 ?719次閱讀
    <b class='flag-5'>嵌入式</b>軟件設(shè)計的原則分享