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

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

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

TinyML,無需重新合成或重新啟動FPGA即可更新

星星科技指導(dǎo)員 ? 來源:microchip ? 作者:microchip ? 2023-05-06 09:44 ? 次閱讀

預(yù)計到本十年末,FPGA 芯片將主導(dǎo)物聯(lián)網(wǎng)端點深度神經(jīng)網(wǎng)絡(luò) (DNN)。它們比微控制器更節(jié)能、更快,并且比ASIC更容易開發(fā)。Infxl與Microchip合作,通過提供兩項技術(shù)優(yōu)勢來加快其采用速度:

1. 從訓(xùn)練數(shù)據(jù)到緊湊的 DNN 的簡單工具 C 語言和 HLS

2. TinyML FPGA實現(xiàn),無需重新合成或重啟即可更新

其中第一個解決了嵌入式開發(fā)人員社區(qū)共同關(guān)注的問題:ML 和 FPGA 工具需要一定程度的專業(yè)知識,而這種專業(yè)知識既昂貴又難以找到。

第二個解決了機器學(xué)習(xí) (ML) 固有的問題:ML 解決方案在一段時間后會過時,需要定期恢復(fù)活力。我們提出了一種 DNN-ON-FPGA 設(shè)計,可確保 DNN 無需重新合成、重新實現(xiàn)或重新啟動 FPGA 即可更新。

通過使用簡單緊湊的ML模型,可以進一步放大FPGA實現(xiàn)的能效和速度優(yōu)勢。Infxl 網(wǎng)絡(luò)就是這樣一種模型(示例代碼 [2])。它使用 8/16 位數(shù)據(jù)路徑在簡單 C 中實現(xiàn)完全連接的 DNN,而無需使用乘法或任何浮點運算。

Infxl 網(wǎng)絡(luò)的一個關(guān)鍵特征是它在網(wǎng)絡(luò)結(jié)構(gòu)/參數(shù)和推理引擎之間保持清晰的分離。我們通過在LSRAM中保留參數(shù)來利用此功能,同時使用LUT和FF實現(xiàn)引擎。這樣,當(dāng)我們需要更新已部署的 Infxl 網(wǎng)絡(luò)時,我們不需要重新合成、重新實現(xiàn)甚至重新啟動 FPGA。我們只需更新LSRAM中的參數(shù),F(xiàn)PGA幾乎立即開始根據(jù)更新的網(wǎng)絡(luò)結(jié)構(gòu)/參數(shù)提供改進的結(jié)果。

開發(fā)過程包括兩個主要步驟:

? 將預(yù)處理的數(shù)據(jù)上傳到 cloud.infxl.com,并將經(jīng)過訓(xùn)練的 Infxl 網(wǎng)絡(luò)下載為即用型 C 代碼。此過程不需要任何 ML 背景。

? 使用Microchip易于使用的SmartHLS編譯器[3],根據(jù)項目的確切要求從C代碼生成HLS。SmartHLS是一個基于Eclipse的IDE,它將C / C++代碼作為輸入,并生成SmartDesign IP組件(Verilog HDL)作為輸出。我們可以在Libero SoC設(shè)計套件[4]中提供的SmartDesign畫布中實例化生成的SmartDesign IP組件,以構(gòu)建FPGA系統(tǒng)。

Infxl net C 代碼包括一個測試平臺和一個通用接口。在將其部署到FPGA中之前,需要進行一些簡單的修改:

? 定義首選互連,例如,用于傳入傳感器數(shù)據(jù)的寄存器或 AXI4 接口。

? 定義用于通信 Infxl 網(wǎng)絡(luò)預(yù)測的類的機制。

? 將 Infxl 網(wǎng)絡(luò)的存儲器類型更改為僅仿真,并定義 C 代碼外部但仍在 FPGA 內(nèi)部的存儲器。

? 在 C 代碼中創(chuàng)建一個頂級函數(shù)以合并 Infxl 網(wǎng)絡(luò)。這將是之后實例化到整個FPGA系統(tǒng)中的IP。

默認的 Infxl net C 代碼通過少量 RAM 將推理引擎連接到輸入和輸出。這是微控制器的典型方法。對于FPGA實現(xiàn),與類似FIFO的接口進行交互會更有效。在默認的 Infxl net C 代碼中添加了額外的小函數(shù)以適應(yīng)這一點。然而,Infxl網(wǎng)絡(luò)的推理引擎的代碼保持不變。

有關(guān)原始 C 代碼和修改后的 C 代碼的比較,請參見下文。

源語言:

poYBAGRVsLaAFc3TAAImoke6FhQ900.png

改 性:

pYYBAGRVsLmAH0rhAAN0Fa46W1A923.png

修改或刪除了 Infxl 網(wǎng)絡(luò)的默認測試平臺功能(copy_inp_vec_to_ram8_head 和 read_op_vec_frm_ram8_tail),并引入了新的函數(shù)net_and_interface。net_and_interface是將使用 SmartHLS 合成的頂級函數(shù)。該函數(shù)copy_inp_vec_to_ram8_head仍然從測試平臺獲取數(shù)據(jù),但是,它使用 FIFO 數(shù)據(jù)類型將數(shù)據(jù)輸出到頂級函數(shù)中。來自FPGA-IP的數(shù)據(jù)使用batch.read()命令讀取。然后,變量批次為預(yù)測類設(shè)置位。

下一步,函數(shù)內(nèi)部RAM被提取出來,并將在SmartHLS的代碼生成過程中轉(zhuǎn)換為簡單的內(nèi)存接口。這需要對 ROM16 陣列進行簡單的修改。ROM16封裝了Infxl網(wǎng)絡(luò)的結(jié)構(gòu)以及所有參數(shù)。對于狀態(tài)監(jiān)測用例,原始ROM16修改如下:

源語言:

chaijie_default.png

pYYBAGRVsMyAJV_LAAE0yG0XU2c681.png

在測試平臺中,ROM16 將在運行 Infxl 網(wǎng)絡(luò)之前填充。在整個FPGA設(shè)計中也需要等效負載。此加載機制還支持更新已部署的 Infxl 網(wǎng)絡(luò):

poYBAGRVsNKAQhdnAAD_SpeP_K8120.png

多路復(fù)用器 (MUX) 被放入 LSRAM 的一個端口的地址路徑中。與這些用戶可訪問的地址和寫入端口一起,LSRAM可以根據(jù)需要填充和更新。上圖顯示了 IP 核,其中 Infxl 網(wǎng)絡(luò)配置了 FIFO 接口,用于傳感器數(shù)據(jù)和可識別的類類型。但是,根據(jù)合成設(shè)置,可以更改此設(shè)置。

現(xiàn)在讓我們看一下硬件。IP 核的確切大小取決于所選接口和任何所需的附加組件。AXI4接口由于其額外的接口功能,將比類似FIFO的接口或連接到AHB總線的寄存器接口需要更多的資源。上面顯示的配置大約需要以下資源:

? 763 個 LUT 和 776 FF 用于 IP,包括接口

? 546 個 LUT 和 610 FF,僅用于 Infxl 網(wǎng)絡(luò)

在此配置中,對單個輸入向量的推理大約需要 2800 個時鐘周期。以 100 MHz 或 200 MHz 運行,這將分別導(dǎo)致每 28 μs 或 14 μs 進行一次新分類。

當(dāng)以上面顯示的方式實現(xiàn)時,我們可以通過將現(xiàn)有的ROM16替換為更新版本來更新Infxl net的結(jié)構(gòu)和參數(shù)。交換 Infxl 網(wǎng)絡(luò)的內(nèi)容定義需要 ROM16 中每個項目一個時鐘周期。在我們的用例中,ROM16 陣列的長度為 899。這相當(dāng)于899個時鐘周期,其中無法進行識別。但是,可以在新舊ROM16之間進行更快的切換,但需要犧牲一些額外的LSRAM。如果需要連續(xù)操作,可以使用兩個并聯(lián)LSRAM。在兩者中,只有一個在任何給定時間處于活動狀態(tài),另一個處于待機狀態(tài)。要更新 Infxl 網(wǎng)絡(luò),備用 LSRAM 將使用新的 ROM16 進行更新。之后,LSRAM輸出數(shù)據(jù)路徑中的多路復(fù)用器被切換,從而激活新加載的ROM16并停用前一個ROM《》。這種切換可以在一個時鐘周期內(nèi)完成,從而在沒有任何實際延遲的情況下進行更新。

如果對分類率有更高的性能要求,Infxl 網(wǎng)絡(luò)也可以合成為并行結(jié)構(gòu),直至完全并行。這將大大加快分類速度。此優(yōu)化是實現(xiàn)大小和性能之間的權(quán)衡。此外,完全并行的實現(xiàn)將Infxl網(wǎng)絡(luò)的結(jié)構(gòu)和參數(shù)整合到IP核本身中。這將刪除在不重新合成和重新啟動的情況下進行簡單更新的功能。我們一直在討論的用例的完全并行實現(xiàn)大約需要 10900 個 LUT 和 4800 個 FF,但將分類速度加快到大約 600 個時鐘周期(包括所有握手)。

從本質(zhì)上講,Infxl net與Microsemi的SmartHLS相結(jié)合,提供了一種簡單且面向未來的方法,可以將ML整合到各種系統(tǒng)中。本文中討論的用例基于運動傳感器的數(shù)據(jù)。但是,使用 Infxl 網(wǎng)絡(luò)的應(yīng)用程序不僅限于該用例。它可用于從預(yù)測性維護到環(huán)境監(jiān)測、機器人技術(shù)、惡意軟件檢測、醫(yī)療保健可穿戴設(shè)備等用例。

審核編輯:郭婷

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

    關(guān)注

    1625

    文章

    21620

    瀏覽量

    601238
  • 機器人
    +關(guān)注

    關(guān)注

    210

    文章

    28103

    瀏覽量

    205849
  • 機器學(xué)習(xí)
    +關(guān)注

    關(guān)注

    66

    文章

    8349

    瀏覽量

    132312
收藏 人收藏

    評論

    相關(guān)推薦

    ESP8266如何進行OTA更新,但無需重新啟動

    - 有沒有辦法OTA下載新固件,但不能重新啟動 - 并在下一次系統(tǒng)啟動時檢查新固件和交換機。我想進行 OTA 更新,但無需重新啟動。 - E
    發(fā)表于 07-11 07:19

    重新啟動MPLABX后出現(xiàn)許多錯誤通知

    MPLABX后,很好,沒有找到調(diào)試工具…沒有理由,在重新啟動MPLABX之后,PACKIT3工作正常。許多錯誤警報/錯誤通知。斷點是垃圾(很多時候當(dāng)他們拒絕放保存它們)…重新啟動后,工作正常。我認為你
    發(fā)表于 01-29 14:47

    重新啟動PHY時Stack不能工作該怎么辦?

    你好,為了減少產(chǎn)品的功耗,我需要關(guān)掉PHY。問題是當(dāng)我重新啟動PHY時,Stack不能工作:PHY配置正確,我可以讀取PHY內(nèi)部寄存器。我試著在PHY重新啟動后調(diào)用StackInit(),但是它不工作。我怎么辦?
    發(fā)表于 08-09 11:30

    如何重新啟動BLE廣告?

    你好,我有一個外圍設(shè)備,它周期性地連接到中央設(shè)備。第一個實例連接到中心,并按預(yù)期發(fā)送分組數(shù)據(jù)。但是在第二個實例中,它沒有連接間隙事件,并生成AybLeLeEvtGATTHeDeXeltTnIn和外圍停止廣告。如何重新啟動BLE廣告?
    發(fā)表于 10-21 08:54

    stm32為什么會不斷的重新啟動

    注意 由于 stm32 系統(tǒng) 不斷的重新啟動,最后的原因就是stm32開發(fā)板子上面的 reset引腳 是 懸空的狀態(tài),受到其他信號的干擾的,不接的情況下 ,有可能 當(dāng)做是 天線的作用 導(dǎo)致mcu不斷的重新啟動的原因
    發(fā)表于 08-02 06:58

    stm32系統(tǒng)為什么會不斷的重新啟動

    stm32系統(tǒng)為什么會不斷的重新啟動?是什么原因造成的?
    發(fā)表于 09-26 07:36

    如何在重新啟動esp32后用手機重新連接到ble?

    你好任何人都有 BLE esp-idf 的任何示例代碼我想在重新啟動 esp32 后用我的手機重新連接到 ble(esp32),然后不要配對新設(shè)備(只是第一次進行新配對),然后連接自動連接到配對
    發(fā)表于 02-16 08:11

    系統(tǒng)時間在重新啟動時損壞了怎么解決?

    。理論上。但是我注意到(查看日志時間戳)重新啟動后,系統(tǒng)時間非常錯誤。它跳到未來幾分鐘幾小時。在 NTP 事件發(fā)生后,它會得到更正?,F(xiàn)在的問題是:是什么導(dǎo)致了這種行為以及如何在重新啟動時保持時間準確?
    發(fā)表于 03-02 08:35

    斷開連接后如何重新啟動WIFI?

    斷開連接后重新啟動 WIFI
    發(fā)表于 05-04 07:26

    電腦總是重新啟動原因分析

    電腦總是重新啟動原因分析 一、軟件   1.病毒破壞   自從有了計算機以后不久,計算機病毒也應(yīng)運而生。當(dāng)網(wǎng)絡(luò)成為
    發(fā)表于 02-24 13:43 ?947次閱讀

    Farichild推出重新啟動定時器FT8010 簡化智慧型

    Farichild推出重新啟動定時器 簡化智慧型電話“黑幕當(dāng)機”重新啟動程序 實現(xiàn)一個按鍵快速重新啟動,且無需取出電池
    發(fā)表于 09-30 11:16 ?621次閱讀

    新iPhone銷售低迷 蘋果重新啟動iPhone X的生產(chǎn)

    蘋果正在重新啟動 iPhone X 的生產(chǎn),因為新推出的 iPhone XS 系列銷量低迷,還有部分原因是與三星顯示器簽訂的合同有關(guān)。
    發(fā)表于 11-25 10:13 ?556次閱讀

    谷歌開始重新啟動機器人項目

    3月27日訊,據(jù)CNBC消息,谷歌正在重新啟動機器人(18.630, -0.17, -0.90%)項目。
    發(fā)表于 03-27 17:14 ?500次閱讀

    如何使用Web3Js來處理區(qū)塊鏈斷開重新啟動

    如果您的團隊在生產(chǎn)中使用Web3Js,那么您必須意識到在Web3Js中沒有內(nèi)置的重新連接功能來處理區(qū)塊鏈斷開重新啟動。因此,通常情況下,當(dāng)連接下降時,需要重新啟動NodeJS服務(wù)以便
    發(fā)表于 03-03 09:25 ?2202次閱讀

    如何重新啟動Linux服務(wù)器

    使用個人電腦工作的時候,可能會因為各種原因而關(guān)閉機器。對于 Linux 初學(xué)者來說,與電源相關(guān)(關(guān)機、重啟等)的任務(wù)總是最后才想到如何去實現(xiàn)的,所以有可能對于如何重新啟動遠程服務(wù)器不太了解。今天我們介紹一些可以用來通過終端來重新啟動 Linux 系統(tǒng)的命令。
    的頭像 發(fā)表于 05-14 16:03 ?2418次閱讀