1、MNN是什麼?阿裡妹導讀:近日,阿裡正式開源輕量級深度學習端側推理引擎“MNN”。
AI科學家賈揚清如此評價道:“與 Tensorflow、Caffe2 等同時覆蓋訓練和推理的通用框架相比,MNN 更注重在推理時的加速和優化,解決在模型部署的階段的效率問題,從而在移動端更高效地實現模型背後的業務。這和服務器端 TensorRT 等推理引擎的想法不謀而合。在大規模機器學習應用中,考慮到大規模的模型部署,機器學習的推理側計算量往往是訓練側計算量的十倍以上,所以推理側的優化尤其重要。”
MNN背後的技術框架如何設計?未來有哪些規劃?今天一起來深入了解。
MNN 是一個輕量級的深度學習端側推理引擎,核心解決深度神經網絡模型在端側推理運行問題,涵蓋深度神經網絡模型的優化、轉換和推理。目前,MNN已經在手淘、手貓、優酷、聚劃算、UC、飛豬、千牛等 20 多個 App 中使用,覆蓋直播、短視頻、搜索推薦、商品圖像搜索、互動營銷、權益發放、安全風控等場景,每天穩定運行上億次。此外,菜鳥自提櫃等 IoT 設備中也有應用。在 2018 年雙十一購物節中,MNN 在天貓晚會笑臉紅包、掃一掃、明星猜拳大戰等場景中使用。
該項目已經在 Github 開源,關注“阿裡技術”官方公衆号,并在對話框内回複“MNN”,即可獲得 Github 下載鍊接、了解更多詳情。
2、MNN的優勢MNN 負責加載網絡模型,推理預測返回相關結果,整個推理過程可以分為模型的加載解析、計算圖的調度、在異構後端上高效運行。MNN 具有通用性、輕量性、高性能、易用性的特征:
通用性:
輕量性:
高性能:
易用性:
3.1 模塊設計
如上圖所示,MNN 可以分為 Converter 和 Interpreter 兩部分。
Converter 由 Frontends 和 Graph Optimize 構成。前者負責支持不同的訓練框架,MNN 當前支持 Tensorflow(Lite)、Caffe 和 ONNX;後者通過算子融合、算子替代、布局調整等方式優化圖。
Interpreter 由 Engine 和 Backends 構成。前者負責模型的加載、計算圖的調度;後者包含各計算設備下的内存分配、Op 實現。在 Engine 和 Backends 中,MNN應用了多種優化方案,包括在卷積和反卷積中應用 Winograd 算法、在矩陣乘法中應用 Strassen 算法、低精度計算、Neon 優化、手寫彙編、多線程優化、内存複用、異構計算等。
3.2 性能比較
采用業務常用的 MobileNet、SqueezeNet 和主流開源框架進行比較,結果如下圖:
MNN 相比于 NCNN、Mace、Tensorflow Lite、Caffe2 都有 20% 以上的優勢。我們其實更加聚焦在内部使用的業務模型優化上,針對人臉檢測等模型進行深入優化,iPhone6 可以達到單幀檢測 5ms 左右。
注:Mace、Tensorflow Lite、Caffe2 均使用截止 2019 年 3 月 1 日 GitHub 代碼倉庫的 master 分支;NCNN 由于編譯問題采用 20181228 Release 預編譯庫。
4、MNN的開源曆史4.1 為什麼要做端側推理?
随着手機算力的不斷提升,以及深度學習的快速發展,特别是小網絡模型不斷成熟,原本在雲端執行的推理預測就可以轉移到端上來做。端智能即在端側部署運行 AI 算法,相比服務端智能,端智能具有低延時、兼顧數據隐私、節省雲端資源等優勢。目前端智能正逐漸變為趨勢,從業界來看,它已經在 AI 攝像、視覺特效等場景發揮了巨大價值。
手淘作為電商的超級 App ,業務形态豐富,拍立淘、直播短視頻、互動營銷、試妝、個性化推薦搜索等業務場景都有端智能訴求,結合端智能能力,可以給用戶帶來新的交互體驗,助力業務創新突破。
一般來說,端側深度學習的應用可以分成如下幾個階段:
由上可知,端側推理引擎是端智能應用的核心模塊,需要在有限算力、有限内存等限制下,高效地利用資源,快速完成推理。可以說,端側推理引擎實現的優劣,直接決定了算法模型能否在端側運行,決定了業務能否上線。因此,我們需要一個端側推理引擎,一個優秀的端側推理引擎。
4.2 為什麼要開源 MNN?
在 2017 年初,我們在開始引擎研發之前,重點調研了系統方案和開源方案,從通用性、輕量性、高性能、安全性等方面深入分。CoreML 是 Apple 的系統框架,MLKit 和 NNAPI 是 Android 的系統框架,系統框架最大的優勢是輕量性 —— 在包大小方面相對寬裕。而最大的劣勢是通用性,CoreML 需要 iOS 11 ,MLKit 和NNAPI 需要 Android 8.1 ,可以覆蓋的機型非常有限,同時難以支持嵌入式設備的使用場景。此外,系統框架支持的網絡類型、Op 類型都較少,可拓展性又較差,還未能充分利用設備的算力,加之存在模型安全方面的問題。綜上種種,系統框架不是一個很好的選擇。開源方案中 Tensorflow Lite 宣而未發,Caffe 較成熟但不是面向端側場景設計和開發的,NCNN 則剛剛發布還不夠成熟。總的來說,我們找不到一套面向不同訓練框架,不同部署環境,簡單高效安全的端側推理引擎。
因此,我們希望提供面向不同業務算法場景,不同訓練框架,不同部署環境的簡單、高效、安全的端側推理引擎 MNN 。能夠抹平 Android 和 iOS 的差異,碎片設備之間的差異,不同訓練框架的差異,實現快速的在端側部署運行,并且能夠根據業務模型進行 OP 靈活添加和 CPU/GPU 等異構設備深入性能優化。
随着時間推移,NCNN、Tensorflow Lite、Mace、Anakin 等逐步升級和開源,給與我們很好的輸入和借鑒。我們随着業務需求也在不斷叠代和優化,并且經曆了雙十一考驗,已經相對成熟和完善,所以開源給社區,希望給應用和 IoT 開發者貢獻我們的力量。
5、應用場景目前,MNN 已經在手淘、貓客、優酷、聚劃算、UC、飛豬、千牛等20 集團App中集成,在拍立淘、直播短視頻、互動營銷、實人認證、試妝、搜索推薦等場景使用,每天穩定運行上億次。2018年雙十一購物節中,MNN 也在貓晚笑臉紅包、掃一掃明星猜拳大戰等場景中使用。
拍立淘是在手淘裡面的一個圖像搜索和識别産品,從14年首次上線經過不斷叠代發展目前已經成長為 UV 超過千萬的應用。其中的技術也在不斷叠代更新,從最早的拍照上傳圖片雲端識别,演進到目前在端上做物體識别和摳圖再上傳雲端識别,有效地提升了用戶體驗同時節省了服務端計算成本。針對一些簡單的物體分類萬物識别和 logo 識别,目前也已經支持直接通過端上的模型進行實時識别。
笑臉紅包是18年雙十一貓晚開場的第一個節目,這個玩法是基于實時人臉檢測和表情識别能力做的,相比之前各種通過屏幕觸控的交互玩法,這個活動通過攝像頭實時人臉檢測算法實現從傳統觸控交互玩法到自然交互玩法的跨越,給用戶帶來新的用戶體驗。
集五福是19年春節的活動,也是手淘第一次通過掃年貨的方式加入到這個活動中來。通過掃一掃商品識别能力,識别紅色年貨,除了福卡之外,還能得到羽絨被、五糧液、茅台、帝王蟹等實物大獎和貓超、天貓精靈等無門檻優惠券,讓家裡的年貨變成下金蛋的“母雞”。
6、Roadmap我們計劃每兩個月 Release 一個穩定版本。當前規劃如下:
模型優化方面:
調度優化方面:
計算優化:
其他:
作者: MNN
,更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!