一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>可編程邏輯>TVM學(xué)習(xí)(二):算符融合

TVM學(xué)習(xí)(二):算符融合

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

資料介紹

作者:安平博,Xilinx高級(jí)工程師;來源:AI加速微信公眾號(hào)

算符融合將多個(gè)計(jì)算單元揉進(jìn)一個(gè)計(jì)算核中進(jìn)行,減少了中間數(shù)據(jù)的搬移,節(jié)省了計(jì)算時(shí)間。TVM中將計(jì)算算符分成四種:

1 injective。一一映射函數(shù),比如加法,點(diǎn)乘等。

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

3 complex-out。這是計(jì)算比較復(fù)雜的,比如卷積運(yùn)算等。

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

根據(jù)以上對(duì)算符的不同類型,TVM提供了三種融合規(guī)則:

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

在走入fuse ops代碼之前,還需要了解一些算法基礎(chǔ)知識(shí)。算符融合中應(yīng)用了支配樹算法。在一個(gè)有向無環(huán)圖中,對(duì)于一個(gè)節(jié)點(diǎn)n來說,從初始節(jié)點(diǎn)s出發(fā)到達(dá)n的所有路徑都經(jīng)歷一個(gè)節(jié)點(diǎn)m,那么m就是n的支配點(diǎn)。而距離n最近的支配點(diǎn)被稱作立即支配點(diǎn)。以r為樹根,將所有立即支配點(diǎn)按照支配關(guān)系連接起來就形成了支配樹。立即后支配點(diǎn)是從一個(gè)點(diǎn)n出發(fā)所有到終止節(jié)點(diǎn)的路徑中通過的最近節(jié)點(diǎn),形成的支配樹是后支配樹。

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

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

TVM中融合流程分為三步:

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

2 建立后支配樹;

3 應(yīng)用算符融合算法。

一 建立DAG圖

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

首先TVM中通過如下代碼來遍歷relay樹結(jié)構(gòu)并建立DAG圖。


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

在最后還會(huì)遞歸調(diào)用ExprVisitor::VisitExpr_函數(shù),最終將深度優(yōu)先搜索到的節(jié)點(diǎn)按照葉節(jié)點(diǎn)起始順序一次加入DAG圖中。只有ConstantNode的訪問函數(shù)中不再調(diào)用VisitExpr_,因?yàn)槌A抗?jié)點(diǎn)應(yīng)該不存在葉節(jié)點(diǎn)了。在callNode中會(huì)將其輸入加入到DAG中,同時(shí)遍歷和輸入以及其op連接的節(jié)點(diǎn),ExprVisitor中對(duì)CallNode訪問函數(shù)定義為:

因?yàn)镋xprVisitor是被IndexForwardGraph繼承的,而VisitExpr_是虛擬函數(shù),this就會(huì)指向IndexForwardGraph實(shí)例,最終就會(huì)調(diào)用這個(gè)類中定義的VisitExpr_函數(shù),實(shí)現(xiàn)遞歸的遍歷relay樹。

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

二 建立后序支配樹

接下來看后序支配樹的構(gòu)建。構(gòu)建函數(shù)是PostDom。因?yàn)楦?jié)點(diǎn)(DAG圖的出口)在post_dfs_order中最后,所以從根節(jié)點(diǎn)開始尋找每個(gè)節(jié)點(diǎn)出點(diǎn)的LCA,這個(gè)LCA就是后序支配點(diǎn)。

GetNode函數(shù)是獲得支配點(diǎn),構(gòu)建支配樹。在GetNode中,首先初始化根節(jié)點(diǎn),然后求每個(gè)節(jié)點(diǎn)的輸入節(jié)點(diǎn)的LCA,即是這個(gè)節(jié)點(diǎn)的支配點(diǎn)。

LeastComonAncestor函數(shù)中主要代碼是:

通過兩兩求節(jié)點(diǎn)的LCA,來求取所有節(jié)點(diǎn)的LCA。程序會(huì)將計(jì)算圖中的末節(jié)點(diǎn)深度設(shè)置為1。然后向上逐層增加,那么LCA的共同祖先是相同的,深度也一定是一致。遍歷所有的節(jié)點(diǎn),就得到一個(gè)后向支配樹。節(jié)點(diǎn)的pattern指向他的LCA。在計(jì)算支配點(diǎn)的pattern的時(shí)候,會(huì)依據(jù)pattern的定義,選擇pattern值最大的作為L(zhǎng)CA的pattern。這塊不是太深入理解??赡苁瞧涠x的從最小值到最大值pattern可以向下進(jìn)行融合,比如kElemWise=0, kInjective=2, 那么前者就能融合到KInjective中。

三 融合

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

如果某些算符可以融合,那么就通過這個(gè)結(jié)構(gòu)體中的parent,master_ref將這些節(jié)點(diǎn)建立連接關(guān)系。Group首先進(jìn)行初始化和DAG相同的圖。然后分別遍歷dag,postDominator tree,以及group圖中節(jié)點(diǎn),來判斷算符是否能被融合。Dag中和postDom中對(duì)應(yīng)相同index的節(jié)點(diǎn)分別是被支配點(diǎn)和支配點(diǎn)。主要融合函數(shù)是以下兩個(gè)函數(shù):


在runFuse中,有幾種情況是不進(jìn)行算符融合的:

1 算符類型是Kopaque的。

2 該節(jié)點(diǎn)不存在支配點(diǎn)。

3 能夠融合的節(jié)點(diǎn)超過了一定數(shù)量。

融合操作算法基本上是考察當(dāng)前節(jié)點(diǎn)到其支配點(diǎn)所有路徑上的節(jié)點(diǎn)是否都符合融合規(guī)則,如果符合就進(jìn)行融合,不符合就不融合。函數(shù)CheckPath就是用于考察src到sink路徑是否能夠融合的。

融合分成了三個(gè)phase,每個(gè)phase處理不同可融合類型。這里我沒有深入研究。當(dāng)判斷支配樹的前后節(jié)點(diǎn)可以融合后,就通過函數(shù)commitFuse執(zhí)行融合操作。

完成融合之后,會(huì)遍歷節(jié)點(diǎn)創(chuàng)建新的graph。

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

評(píng)論

查看更多

下載排行

本周

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

本月

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

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分