自適應(yīng)計(jì)算如何化解 AI 產(chǎn)品化難題
人工智能發(fā)展迅速,創(chuàng)新步伐不斷加快。然而,雖然軟件行業(yè)已經(jīng)成功在生產(chǎn)中部署了 AI,但包括汽車、工業(yè)和智能零售等在內(nèi)的硬件行業(yè),在 AI 產(chǎn)品化方面仍處于初級(jí)階段。阻礙 AI 算法概念驗(yàn)證 (PoC) 成為真正硬件部署的主要差距仍然存在。這些不足之處在很大程度上是由于“小數(shù)據(jù)”、數(shù)據(jù)輸入“不完美”以及更 “先進(jìn)模型”的不斷演進(jìn)所造成的。對(duì)于軟件開(kāi)發(fā)者和 AI 科學(xué)家們來(lái)說(shuō),該如何應(yīng)對(duì)這些挑戰(zhàn)呢?我堅(jiān)信, 應(yīng)對(duì)之道便是自適應(yīng)硬件。
本文引用地址:http://www.ex-cimer.com/article/202105/425653.htm( Nick Ni 擁有多倫多大學(xué)計(jì)算機(jī)工程碩士學(xué)位,擁有 10 多項(xiàng)專利和出版物)
小數(shù)據(jù)
谷歌 ( Goolge ) 和臉書 ( Facegbook) 等互聯(lián)網(wǎng)巨頭每天都會(huì)定期收集和分析海量數(shù)據(jù)。然后,他們使用這些數(shù)據(jù)來(lái)創(chuàng)建擁有可接受性能的 AI 模型。在這種情況下,用于訓(xùn)練模型的硬件與用于運(yùn)行模型的硬件有很大不同。
另一方面,在硬件行業(yè),大數(shù)據(jù)的可用性受到更多的限制,導(dǎo)致 AI 模型不夠成熟。因此,收集更多數(shù)據(jù)和運(yùn)行“在線模型”(為不斷提高精度在相同的已部署硬件上執(zhí)行訓(xùn)練和推斷)成為一種主要推動(dòng)力。
為了解決這一問(wèn)題,自適應(yīng)計(jì)算(如:現(xiàn)場(chǎng)可編程門陣列 FPGA 和經(jīng)過(guò)邊緣驗(yàn)證的自適應(yīng)片上系統(tǒng) SoC 器件)可以同時(shí)運(yùn)行推斷和訓(xùn)練,從而不斷進(jìn)行自我更新以適應(yīng)新捕獲的數(shù)據(jù)。而傳統(tǒng)的 AI 訓(xùn)練則需要借助云或大型本地?cái)?shù)據(jù)中心,并花費(fèi)數(shù)天和數(shù)周的時(shí)間才能完成。另一方面,真正的數(shù)據(jù)主要是在邊緣生成的,在同一個(gè)邊緣設(shè)備中運(yùn)行 AI 推斷和訓(xùn)練不僅可以降低總擁有成本 (TCO),而且還可以減少時(shí)延和安全漏洞。
數(shù)據(jù)輸入“不完美”
雖然發(fā)布 AI 模型 PoC 來(lái)展示使用 X 射線圖像檢測(cè)新冠病毒的精度變得越來(lái)越容易,但這些 PoC 幾乎總是基于精心整理的干凈的輸入圖片。在現(xiàn)實(shí)生活中,來(lái)自醫(yī)療設(shè)備、機(jī)器人和移動(dòng)汽車的攝像頭和傳感器輸入,會(huì)出現(xiàn)隨機(jī)失真現(xiàn)象,例如暗淡的圖像和各種角度的物體。這些輸入首先需要經(jīng)過(guò)復(fù)雜的預(yù)處理以進(jìn)行清理和重新格式化,然后才能輸入到 AI 模型中。對(duì)于理解 AI 模型的輸出并做出正確的決策而言,后處理是非常重要的。
的確,有些芯片可能非常擅長(zhǎng) AI 推斷加速,但它們幾乎總是只加速完整應(yīng)用的一部分。以智能零售為例,預(yù)處理包括多流視頻解碼,然后是傳統(tǒng)的計(jì)算機(jī)視覺(jué)算法 ,用于調(diào)整視頻的大小、重塑視頻的形狀和轉(zhuǎn)換視頻的格式。此外,后處理還包括對(duì)象跟蹤和數(shù)據(jù)庫(kù)查找。最終客戶不太關(guān)心 AI 推斷的運(yùn)行速度,而是關(guān)心它們是否能滿足整個(gè)應(yīng)用管道的視頻流性能和/或?qū)崟r(shí)響應(yīng)能力。FPGA 和自適應(yīng) SoC 在使用特定領(lǐng)域架構(gòu) (DSA) 加速這些預(yù)處理和后處理算法方面有著良好的記錄。此外,添加 AI 推斷 DSA 將可以支持對(duì)整個(gè)系統(tǒng)進(jìn)行優(yōu)化,以滿足端到端的產(chǎn)品需求。
圖1 DSA 需要加速 AI 和非 AI 圖片來(lái)源:Ben Dickson
更“先進(jìn)模型”的不斷演進(jìn)
AI 研究界可以說(shuō)是當(dāng)今技術(shù)領(lǐng)域最活躍的領(lǐng)域之一,世界各地的頂級(jí)研究人員每天都在發(fā)明新的 AI 模型。這些模型提高了精度,降低了計(jì)算要求,并滿足了新型 AI 應(yīng)用的需求。然而,這種快速的創(chuàng)新,無(wú)疑也持續(xù)給現(xiàn)有的半導(dǎo)體硬件器件帶來(lái)了壓力,需要更新的架構(gòu)來(lái)有效地支持現(xiàn)代算法。MLPerf 等標(biāo)準(zhǔn)基準(zhǔn)測(cè)試證明:在運(yùn)行實(shí)際 AI 工作負(fù)載時(shí),最先進(jìn)的 CPU、GPU 和 AI ASIC 芯片,遠(yuǎn)遠(yuǎn)低于這些技術(shù)提供商們所宣傳的 30% 的性能。這種差距不斷推動(dòng)著業(yè)界對(duì)新型 DSA 的需求,以期跟上創(chuàng)新的步伐。
驅(qū)動(dòng)新型 DSA 需求的主要?jiǎng)恿Γㄒ韵逻@些最新趨勢(shì)。深度卷積是一個(gè)新興的層,需要高存儲(chǔ)器帶寬和專用內(nèi)部存儲(chǔ)器緩存才能高效運(yùn)行。AI 芯片和 GPU 通常采用固定的 L1/L2/L3 緩存架構(gòu)和有限的內(nèi)部存儲(chǔ)器帶寬,導(dǎo)致效率十分低下。
研究人員不斷發(fā)明新的定制層,而當(dāng)前的芯片,本身并不提供本地支持。出于這個(gè)原因,它們需要在無(wú)加速的情況下在主機(jī) CPU 上運(yùn)行,這往往形成了性能瓶頸。
稀疏神經(jīng)網(wǎng)絡(luò)是另一種富有前景的優(yōu)化技術(shù)。在這種網(wǎng)絡(luò)中,通過(guò)修剪網(wǎng)絡(luò)邊緣、刪除卷積中的精細(xì)顆粒矩陣值等措施,網(wǎng)絡(luò)被高度修剪,簡(jiǎn)化程度有時(shí)能高達(dá) 99%。然而,要在硬件中高效運(yùn)行這一優(yōu)化,則需要專門的稀疏架構(gòu),并為這些運(yùn)算提供編碼器和解碼器,大多數(shù)芯片都不具備這些功能。
二進(jìn)制/三進(jìn)制屬于極端優(yōu)化,讓所有數(shù)學(xué)運(yùn)算都按單個(gè)數(shù)位操作。大多數(shù) AI 芯片和 GPU 僅有 8 位、16 位或浮點(diǎn)計(jì)算單元,因此采用極低精度并不能獲得任何性能或功耗效率。FPGA 和自適應(yīng) SoC 是完美的,因?yàn)殚_(kāi)發(fā)者可以開(kāi)發(fā)完美的 DSA,并根據(jù)產(chǎn)品的工作負(fù)載對(duì)現(xiàn)有器件進(jìn)行重新編程。作為證明,最新的 MLPerf 包括賽靈思與Mipsology合作提交的一份文件,該文件使用 ResNet-50 標(biāo)準(zhǔn)基準(zhǔn)測(cè)試實(shí)現(xiàn)了 100% 的硬件數(shù)據(jù)表性能。
圖2 針對(duì) FPGA 的 MLPerf 基準(zhǔn)測(cè)試 圖片來(lái)源:Ben Dickson
沒(méi)有硬件專業(yè)知識(shí)?毫無(wú)問(wèn)題!
一直以來(lái),F(xiàn)PGA 和自適應(yīng) SoC 面臨的最大挑戰(zhàn),就是需要硬件專業(yè)知識(shí)來(lái)實(shí)施和部署 DSA。好消息是:現(xiàn)在有了支持 C++、Python 和流行 AI 框架(如 TensorFlow 和 PyTorch)的工具,如:Vitis 統(tǒng)一軟件平臺(tái),軟件和 AI 開(kāi)發(fā)者之間的差距被大大縮小了。
除了軟件抽象工具方面的更多開(kāi)發(fā)以外,開(kāi)源庫(kù)(如 Vitis 硬件加速庫(kù))在開(kāi)發(fā)者社區(qū)中的采用度也顯著提高。在賽靈思最近舉辦的設(shè)計(jì)競(jìng)賽中,吸引了 1000 多名開(kāi)發(fā)者,并發(fā)布了眾多創(chuàng)新項(xiàng)目,從用手勢(shì)控制的無(wú)人機(jī),到使用二進(jìn)制神經(jīng)網(wǎng)絡(luò)的強(qiáng)化學(xué)習(xí),不一而足。重要的是,大多數(shù)提交的項(xiàng)目都是由不具備 FPGA 使用經(jīng)驗(yàn)的軟件和 AI 開(kāi)發(fā)者完成的。這證明 FPGA 行業(yè)正在采取正確的措施,使軟件和 AI 開(kāi)發(fā)者能夠化解現(xiàn)實(shí)生活中的 AI 產(chǎn)品化難題。
圖3 靈活應(yīng)變?nèi)f物智能 圖片來(lái)源:Ben Dickson
直到最近,普通軟件開(kāi)發(fā)者和 AI 科學(xué)家在想要利用硬件的自適應(yīng)特性時(shí)仍會(huì)望而卻步, 因?yàn)檫@在以前都需要特定的硬件專業(yè)知識(shí)。而現(xiàn)如今,通過(guò)借助新的開(kāi)源工具,軟件開(kāi)發(fā)者一樣能夠運(yùn)用自適應(yīng)硬件。編程難度的下降,使得數(shù)十萬(wàn)名軟件開(kāi)發(fā)者和 AI 科學(xué)家們,能更充分地受益于 FPGA 和自適應(yīng) SoC 的優(yōu)勢(shì),讓硬件解決方案成為下一代應(yīng)用的選擇。事實(shí)上,DSA 將代表 AI 推斷的未來(lái),軟件開(kāi)發(fā)者和 AI 科學(xué)家將借助s硬件的自適應(yīng)特性來(lái)開(kāi)發(fā)他們的下一代應(yīng)用。
評(píng)論