《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 業界動態 > GPU高效通信算法——Ring Allreduce

GPU高效通信算法——Ring Allreduce

2019-10-12

  今天介紹一種新的GPU多卡計算的通信優化算法——Ring Allreduce

  先來講一下常規的GPU多卡分布式計算的原理。

  第一點:我們知道GPU在矩陣并行化計算方面非常有優勢,所以適合深度學習的訓練。

  第二點:使用多個GPU卡訓練同一個深度學習任務就是分布式計算。

  第三點:在分布式計算過程中,需要對計算任務資源進行分片,通常的方式是將完整的網絡結構放到每一個GPU上,然后將訓練數據進行分片分發到不同的GPU卡上。

640 (2).JPEG

  于是GPU分布式計算的具體形式就比較清晰了,以上圖為例。GPU1~4卡負責網絡參數的訓練,每個卡上都布置了相同的深度學習網絡,每個卡都分配到不同的數據的minibatch。每張卡訓練結束后將網絡參數同步到GPU0,也就是Reducer這張卡上,然后再求參數變換的平均下發到每張計算卡,整個流程有點像mapreduce的原理。

  這里面就涉及到了兩個問題:

  問題一,每一輪的訓練迭代都需要所有卡都將數據同步完做一次Reduce才算結束。如果卡數比較少的情況下,其實影響不大,但是如果并行的卡很多的時候,就涉及到計算快的卡需要去等待計算慢的卡的情況,造成計算資源的浪費。

  問題二,每次迭代所有的計算GPU卡多需要針對全部的模型參數跟Reduce卡進行通信,如果參數的數據量大的時候,那么這種通信開銷也是非常龐大,而且這種開銷會隨著卡數的增加而線性增長。

  為了解決這樣的問題,就引入了一種通信算法Ring Allreduce,通過將GPU卡的通信模式拼接成一個環形,從而減少隨著卡數增加而帶來的資源消耗,如下圖所示:

640 (1).JPEG

  將GPU卡以環形通信之后,每張卡都有一個左手卡和右手卡,那么具體的模型參數是如何傳遞的呢,可以看下圖:

640.JPG

  因為每張卡上面的網絡結構是固定的,所以里面的參數結構相同。每次通信的過程中,只將參數send到右手邊的卡,然后從左手邊的卡receive數據。經過不斷地迭代,就會實現整個參數的同步,也就是reduce。

  形成以下這張圖的樣式:

640.webp (4).jpg

  通過Ring Allreduce的方式,基本上可以實現當GPU并行卡數的增加,實現計算性能的線性增長。

640.webp (3).jpg

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 影音先锋男人看片资源| 欧美国产成人精品一区二区三区| 国产最新凸凹视频免费| yy6080一级毛片高清| 日韩欧美在线播放视频| 亚洲精品狼友在线播放| 美女让男人捅爽| 国产成人精品男人的天堂网站| 99精品视频在线观看免费| 推油少妇久久99久久99久久| 亚洲乱码一区av春药高潮| 玖玖在线资源站| 国产XXXX99真实实拍| 欧洲97色综合成人网| 大香煮伊在2020久| 中文在线最新版天堂| 日韩精品成人一区二区三区| 亚洲欧美日韩中文字幕久久 | 麻豆国产VA免费精品高清在线| 国产麻豆videoxxxx实拍| 一区二区三区视频观看| 日本人指教视频| 亚洲AV日韩AV高潮无码专区| 欧美黑人xxxx性高清版| 内裤奇缘电子书| 色综合合久久天天综合绕视看| 国产最猛性xxxxxx69交| 91精品免费观看| 夫妇交换性三中文字幕| 中文字幕一区二区人妻性色| 日韩加勒比在线| 亚洲免费闲人蜜桃| 激情内射日本一区二区三区| 午夜小视频男女在线观看| 视频在线一区二区三区| 国产成人综合精品| 18禁无遮挡羞羞污污污污免费| 在线你懂的网站| swag台湾在线| 情人伊人久久综合亚洲| 久久久久久久99视频|