在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示
電子發燒友網>電子資料下載>可編程邏輯>TVM學習(二):算符融合

TVM學習(二):算符融合

2021-02-19 | pdf | 845.35KB | 次下載 | 2積分

資料介紹

作者:安平博,Xilinx高級工程師;來源:AI加速微信公眾號

算符融合將多個計算單元揉進一個計算核中進行,減少了中間數據的搬移,節省了計算時間。TVM中將計算算符分成四種:

1 injective。一一映射函數,比如加法,點乘等。

2 reduction。輸入到輸出具有降維性質的,比如sum。

3 complex-out。這是計算比較復雜的,比如卷積運算等。

4 opaque。無法被融合的算符,比如sort。

根據以上對算符的不同類型,TVM提供了三種融合規則:

從一定角度看,這種融合實際上是數據計算pipeline化,即兩次計算中間數據不再經歷store-load的過程,而是直接給到下一個計算單元完成計算。

在走入fuse ops代碼之前,還需要了解一些算法基礎知識。算符融合中應用了支配樹算法。在一個有向無環圖中,對于一個節點n來說,從初始節點s出發到達n的所有路徑都經歷一個節點m,那么m就是n的支配點。而距離n最近的支配點被稱作立即支配點。以r為樹根,將所有立即支配點按照支配關系連接起來就形成了支配樹。立即后支配點是從一個點n出發所有到終止節點的路徑中通過的最近節點,形成的支配樹是后支配樹。

在DAG中,對于一個點,所有能到達它的點在支配樹中的LCA,就是它支配樹中的父親。為什么算符融合要建立在后支配樹的基礎上呢?我猜測可能是因為對于兩個可融合算符在DAG中位置分為兩種,一種是父子關系,那么可以直接執行算符融合算法;另外一種是它們之間是后支配關系。對于具有后支配關系的兩個節點(n->m),就要判斷未來路徑上的節點是否都能夠和點m發生融合,如果可以,那么n也可以和m發生融合。比如下圖:

Conv2d要和elemwise add融合,必須判斷它的三個op是否能和elemwise add融合。

TVM中融合流程分為三步:

1 遍歷relay樹,建立DAG用于后支配樹分析;

2 建立后支配樹;

3 應用算符融合算法。

一 建立DAG圖

算符融合代碼在src/relay/transforms/fuse_ops.cc中。其中算符融合也應用在常量折疊中。

首先TVM中通過如下代碼來遍歷relay樹結構并建立DAG圖。


VisitExpr可以遞歸的調用在類IndexedforwardGraph中定義的VisitExpr_函數,通過深度優先搜索遍歷relay樹,并且建立DAG圖。深度優先搜索是從exit節點作為根節點反向搜鎖的,因此搜索樹是一個后序搜索樹。Outputs中保存了一個節點的輸入的邊,在構建后序支配樹會通過這些輸入邊求取LCA。那么在這個搜索樹基礎上應用支配樹算法,就能夠得到一個后序支配樹了。在這個類中針對不同節點類型重寫visitExpr_函數,節點類型有FunctionNode,ConstantNode, CallNode, TuppleNode等。我們來看CallNode的訪問函數定義:

在最后還會遞歸調用ExprVisitor::VisitExpr_函數,最終將深度優先搜索到的節點按照葉節點起始順序一次加入DAG圖中。只有ConstantNode的訪問函數中不再調用VisitExpr_,因為常量節點應該不存在葉節點了。在callNode中會將其輸入加入到DAG中,同時遍歷和輸入以及其op連接的節點,ExprVisitor中對CallNode訪問函數定義為:

因為ExprVisitor是被IndexForwardGraph繼承的,而VisitExpr_是虛擬函數,this就會指向IndexForwardGraph實例,最終就會調用這個類中定義的VisitExpr_函數,實現遞歸的遍歷relay樹。

這里要關注一下OpPatternKind,它定義了算子類型,是不同融合算法使用的依據。其定義在include/tvm/relay/op_attr_types.h文件中。

二 建立后序支配樹

接下來看后序支配樹的構建。構建函數是PostDom。因為根節點(DAG圖的出口)在post_dfs_order中最后,所以從根節點開始尋找每個節點出點的LCA,這個LCA就是后序支配點。

GetNode函數是獲得支配點,構建支配樹。在GetNode中,首先初始化根節點,然后求每個節點的輸入節點的LCA,即是這個節點的支配點。

LeastComonAncestor函數中主要代碼是:

通過兩兩求節點的LCA,來求取所有節點的LCA。程序會將計算圖中的末節點深度設置為1。然后向上逐層增加,那么LCA的共同祖先是相同的,深度也一定是一致。遍歷所有的節點,就得到一個后向支配樹。節點的pattern指向他的LCA。在計算支配點的pattern的時候,會依據pattern的定義,選擇pattern值最大的作為LCA的pattern。這塊不是太深入理解。可能是其定義的從最小值到最大值pattern可以向下進行融合,比如kElemWise=0, kInjective=2, 那么前者就能融合到KInjective中。

三 融合

完成了DAG和postDominator tree構建后,就開始融合操作。TVM中定義了group結構體,用于表示融合后的圖結構。Group結構體如下:

如果某些算符可以融合,那么就通過這個結構體中的parent,master_ref將這些節點建立連接關系。Group首先進行初始化和DAG相同的圖。然后分別遍歷dag,postDominator tree,以及group圖中節點,來判斷算符是否能被融合。Dag中和postDom中對應相同index的節點分別是被支配點和支配點。主要融合函數是以下兩個函數:


在runFuse中,有幾種情況是不進行算符融合的:

1 算符類型是Kopaque的。

2 該節點不存在支配點。

3 能夠融合的節點超過了一定數量。

融合操作算法基本上是考察當前節點到其支配點所有路徑上的節點是否都符合融合規則,如果符合就進行融合,不符合就不融合。函數CheckPath就是用于考察src到sink路徑是否能夠融合的。

融合分成了三個phase,每個phase處理不同可融合類型。這里我沒有深入研究。當判斷支配樹的前后節點可以融合后,就通過函數commitFuse執行融合操作。

完成融合之后,會遍歷節點創建新的graph。

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DC電源插座圖紙
  2. 0.67 MB   |  3次下載  |  免費
  3. 2AN-1267: 使用ADSP-CM408F ADC控制器的電機控制反饋采樣時序
  4. 1.41MB   |  3次下載  |  免費
  5. 3AN158 GD32VW553 Wi-Fi開發指南
  6. 1.51MB   |  2次下載  |  免費
  7. 4AN148 GD32VW553射頻硬件開發指南
  8. 2.07MB   |  1次下載  |  免費
  9. 5AN111-LTC3219用戶指南
  10. 84.32KB   |  次下載  |  免費
  11. 6AN153-用于電源系統管理的Linduino
  12. 1.38MB   |  次下載  |  免費
  13. 7AN-283: Σ-Δ型ADC和DAC[中文版]
  14. 677.86KB   |  次下載  |  免費
  15. 8SM2018E 支持可控硅調光線性恒流控制芯片
  16. 402.24 KB  |  次下載  |  免費

本月

  1. 1ADI高性能電源管理解決方案
  2. 2.43 MB   |  450次下載  |  免費
  3. 2免費開源CC3D飛控資料(電路圖&PCB源文件、BOM、
  4. 5.67 MB   |  138次下載  |  1 積分
  5. 3基于STM32單片機智能手環心率計步器體溫顯示設計
  6. 0.10 MB   |  130次下載  |  免費
  7. 4使用單片機實現七人表決器的程序和仿真資料免費下載
  8. 2.96 MB   |  44次下載  |  免費
  9. 5美的電磁爐維修手冊大全
  10. 1.56 MB   |  24次下載  |  5 積分
  11. 6如何正確測試電源的紋波
  12. 0.36 MB   |  18次下載  |  免費
  13. 7感應筆電路圖
  14. 0.06 MB   |  10次下載  |  免費
  15. 8萬用表UT58A原理圖
  16. 0.09 MB   |  9次下載  |  5 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分
主站蜘蛛池模板: 亚洲综合婷婷 | 男人资源在线 | 韩国xxxxxxxx69 | 九九九精品 | 88影视在线观看污污 | 国产成人一区二区三中文 | 你懂的免费 | 亚洲五月婷 | 天天摸日日干 | 91大神精品| 日本黄色小视频在线观看 | 国产亚洲一区二区精品 | 欧美在线视频二区 | 亚洲国产精品久久婷婷 | 老师下面很湿很爽很紧 | 香蕉视频在线免费播放 | 亚洲综合久久综合激情久久 | 欧美一级黄色影片 | 欧美性受一区二区三区 | 国产成人影院在线观看 | 欧美黑人性受xxxx喷水 | 国产精品露脸脏话对白 | 日本全黄视频 | 国模巴| 视色4se视频在线观看 | 亚1州区2区3区4区产品乱码 | 1024国产基地永久免费 | 久久综合九色综合欧美播 | 国产成人毛片亚洲精品不卡 | 四虎影院最新地址 | 国产高清在线精品一区 | 久久精品亚洲青青草原 | 国产情侣真实露脸在线最新 | 久久大综合 | 四虎国产精品4hu永久 | 国产三级精品最新在线 | 国产亚洲精品久久久久久久软件 | 97一本大道波多野吉衣 | 四虎国产精品影库永久免费 | 午夜精品视频在线 | 免费一级黄色录像 |