青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

C++ Coder

HCP高性能計算架構,實現,編譯器指令優化,算法優化, LLVM CLANG OpenCL CUDA OpenACC C++AMP OpenMP MPI

C++博客 首頁 新隨筆 聯系 聚合 管理
  98 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks

http://blog.csdn.net/zhang0311/article/details/8224093
近年來,基于CPU+GPU的混合異構計算系統開始逐漸成為國內外高性能計算領域的熱點研究方向。在實際應用中,許多基于 CPU+GPU 的混合異構計算機系統表現出了良好的性能。但是,由于各種歷史和現實原因的制約,異構計算仍然面臨著諸多方面的問題,其中最突出的問題是程序開發困難,尤其是擴展到集群規模級別時這個問題更為突出。主要表現在擴展性、負載均衡、自適應性、通信、內存等方面。

一、    CPU+GPU協同計算模式

CPU+GPU異構協同計算集群如圖1所示,CPU+GPU異構集群可以劃分成三個并行層次:節點間并行、節點內CPU與GPU異構并行、設備(CPU或GPU)內并行。根據這三個層次我們可以得到CPU+GPU異構協同計算模式為:節點間分布式+節點內異構式+設備內共享式。

1           節點間分布式

CPU+GPU異構協同計算集群中,各個節點之間的連接與傳統CPU集群一樣,采用網絡連接,因此,節點間采用了分布式的計算方式,可以采用MPI消息通信的并行編程語言。

2           節點內異構式

CPU+GPU異構協同計算集群中,每個節點上包含多核CPU和一塊或多塊GPU卡,節點內采用了異構的架構,采用主從式的編程模型,即每個GPU卡需要由CPU進程/線程調用。

由于每個節點上,CPU核數也比較多,計算能力也很大,因此,在多數情況下,CPU也會參與部分并行計算,根據CPU是否參與并行計算,我們可以把CPU+GPU異構協同計算劃分成兩種計算模式:

1)       CPU/GPU協同計算:CPU只負責復雜邏輯和事務處理等串行計算,GPU 進行大規模并行計算;

2)       CPU+GPU共同計算:由一個CPU進程/線程負責復雜邏輯和事務處理等串行計算,其它CPU進程/線程負責小部分并行計算,GPU負責大部分并行計算。

由于CPU/GPU協同計算模式比CPU+GPU共同計算模式簡單,下面的介紹中,我們以CPU+GPU共同計算模式為例進行展開介紹各種編程模式。

在CPU+GPU共同計算模式下,我們把所有的CPU統稱為一個設備(device),如雙路8核CPU共有16個核,我們把這16個核統稱成一個設備;每個GPU卡成為一個設備。根據這種劃分方式,我們可以采用MPI進程或OpenMP線程控制節點內的各設備之間的通信和數據劃分。

3           設備內共享式

1)       CPU設備:每個節點內的所有多核CPU采用了共享存儲模型,因此,把節點內的所有多核CPU看作一個設備, 可以采用MPI進程或OpenMP線程、pThread線程控制這些CPU核的并行計算。

2)       GPU設備:GPU設備內有自己獨立的DRAM存儲,GPU設備也是共享存儲模型,在GPU上采用CUDA或OpenCL編程控制GPU眾核的并行計算。CUDA編程模式只在NVIDIA GPU上支持,OpenCL編程模式在NVIDIA GPU和AMD GPU都支持。

根據前面對CPU+GPU異構協同計算模式的描述,我們可以得到CPU+GPU異構協同計算的編程模型(以MPI和OpenMP為例)如表1所示。


圖1 CPU+GPU異構協同計算架構

表1 CPU+GPU異構協同計算編程模型

 

節點間分布式

節點內異構式

設備內共享式

CPU

GPU

模式1

MPI

OpenMP

OpenMP

CUDA/OpenCL

模式2

MPI

MPI

OpenMP

CUDA/OpenCL

模式3

MPI

MPI

MPI

CUDA/OpenCL

二、    CPU+GPU協同計算負載均衡性設計

下面以模式2為例簡單介紹多節點CPU+GPU協同計算任務劃分和負載均衡,模式2的進程和線程與CPU核和GPU設備對應關系如圖2所示。若采用主從式MPI通信機制,我們在節點0上多起一個進程(0號進程)作為主進程,控制其它所有進程。每個節點上啟動3個計算進程,其中兩個控制GPU設備,一個控制其余所有CPU核的并行,在GPU內采用CUDA/OpenCL并行,在CPU設備內采用OpenMP多線程并行。

由于CPU+GPU協同計算模式分為3個層次,那么負載均衡性也需要在這3個層次上分別設計。在模式2的編程方式下,節點內和節點間均采用MPI進程,合二為一,設計負載均衡時,只需要做到進程間(設備之間)的負載均衡和CPU設備內OpenMP線程負載均衡、GPU設備內CUDA線程負載均衡即可。

對于設備內,采用的是共享存儲器模型,CPU設備上的OpenMP線程可以采用schedule(static/ dynamic/ guided )方式;GPU設備上只要保證同一warp內的線程負載均衡即可。

對于CPU+GPU協同計算,由于CPU和GPU計算能力相差很大,因此,在對任務和數據劃分時不能給CPU設備和GPU設備劃分相同的任務/數據量,這就增加了CPU與GPU設備間負載均衡的難度。CPU與GPU之間的負載均衡最好的方式是采用動態負載均衡的方法,然而有些應用無法用動態劃分而只能采用靜態劃分的方式。下面我們分別介紹動態劃分和靜態劃分。

1)       動態劃分:對于一些高性能計算應用程序,在CPU與GPU之間的負載均衡可以采用動態負載均衡的優化方法,例如有N個任務/數據,一個節點內有2個GPU卡,即三個設備(CPU和2個GPU),動態負載均衡的方法是每個設備先獲取一個任務/數據進行計算,計算之后立即獲取下一個任務,不需要等待其他設備,直到N個任務/數據計算完成。這種方式只需要在集群上設定一個主進程,負責給各個計算進程分配任務/數據。

2)       靜態劃分:在一些應用中,無法采用動態劃分的方式,需要靜態劃分方法,然而靜態劃分方法使異構設備間的負載均衡變得困難,有時甚至無法實現。對于一些迭代應用程序,我們可以采用學習型的數據劃分方法,如先讓CPU和GPU分別做一次相同計算量的計算,然后通過各自的運行時間計算出CPU與GPU的計算能力比例,然后再對數據進行劃分。


圖2 CPU+GPU協同計算示意圖(以每個節點2個GPU為例)

三、    CPU+GPU協同計算數據劃分示例

假設某一應用的數據特點如圖3所示,從輸出看,結果中的每個值的計算需要所有輸入數據的信息,所有輸出值的計算之間沒有任何數據依賴性,可以表示成outj=;從輸入看,每個輸入值對所有的輸出值都產生影響,所有輸入數據之間也沒有任何數據依賴性。從數據特點可以看出,該應用既可以對輸入進行并行數據劃分也可以對輸出進行數據劃分。下面我們分析CPU+GPU協同計算時的數據劃分方式。


圖3 并行數據示例

1         按輸入數據劃分

假設按輸入數據劃分,我們可以采用動態的方式給每個CPU或GPU設備分配數據,做到動態負載均衡,然而這種劃分方式,使所有的線程向同一個輸出位置保存結果,為了正確性,需要使所有的線程對每個結果進行原子操作,這樣將會嚴重影響性能,極端情況下,所有線程還是按順序執行的。因此,這種方式效果很差。

2         按輸出數據劃分

按輸出數據劃分的話可以讓每個線程做不同位置的結果計算,計算完全獨立,沒有依賴性。如果采用靜態劃分的方式,由于CPU和GPU計算能力不同,因此,很難做到負載均衡。采用動態的方式可以做到負載均衡,即把結果每次給CPU或GPU設備一塊,當設備計算完本次之后,立即向主進程申請下一個分塊,這樣可以做到完全負載均衡。按輸出數據劃分,無論采用靜態劃分還是動態劃分,都會帶來另外一個問題,由于每個結果的計算都需要所有輸入信息,那么所有進程(設備)都需要讀取一遍所有輸入數據,動態劃分時還不只一次,尤其對于輸入數據很大時,這將會對輸入數據的IO產生很大的影響,很有可能使IO程序性能瓶頸。

3         按輸入和輸出同時劃分

由于按輸入或按輸出劃分都存在不同的缺點,我們可以采用輸入和輸出同時劃分的方式進行數據劃分,如圖4所示。

從輸出角度,讓所有的計算進程(設備)都有一份計算結果,設備內的線程對結果進行并行計算,每個設備都有一份局部的計算結果,所有設備都計算完畢之后,利用MPI進程對所有設備的計算結果進行規約,規約最后的結果即是最終的結果。

從輸入角度,按輸入數據動態劃分給不同的計算進程(設備),這樣可以滿足所有的計算進程負載均衡。


圖4 CPU+GPU協同計算數據劃分示例

posted on 2013-02-17 13:27 jackdong 閱讀(1737) 評論(0)  編輯 收藏 引用 所屬分類: OpenCL
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲性人人天天夜夜摸| 精品二区久久| 黄色成人在线免费| 亚洲综合99| 美女诱惑黄网站一区| 亚洲欧美激情诱惑| 国产精品久久久久毛片大屁完整版 | 亚洲风情亚aⅴ在线发布| 亚洲欧美日韩国产综合在线| 亚洲人午夜精品免费| 久久久久久久成人| 亚洲高清视频在线观看| 亚洲国产欧美一区二区三区久久 | 亚洲免费大片| 亚洲婷婷综合色高清在线| 欧美日韩中文字幕在线视频| 欧美一级在线视频| 蜜臀久久久99精品久久久久久| 亚洲欧洲日产国产网站| 在线国产日韩| 日韩亚洲国产欧美| 韩国av一区二区三区| 亚洲第一区色| 国产欧美精品日韩精品| 麻豆成人在线观看| 国产欧美一级| 亚洲美女性视频| 伊人激情综合| 亚洲欧美日韩一区在线观看| 欧美视频二区| 另类综合日韩欧美亚洲| 欧美午夜精品理论片a级大开眼界| 欧美一级欧美一级在线播放| 久久久久久色| 久久久久久久尹人综合网亚洲 | 一区二区欧美在线观看| 美女国产精品| 国产性色一区二区| 99精品视频网| 亚洲激情av| 久久国产精品电影| 欧美一级精品大片| 国产精品视频一区二区三区| 欧美激情在线有限公司| 欧美午夜精彩| 亚洲免费网址| 久久久人成影片一区二区三区 | 国产一区再线| 久久精品在线观看| 美女在线一区二区| 亚洲精品美女久久7777777| 免播放器亚洲一区| 91久久精品视频| 欧美国产日韩在线观看| 91久久精品美女高潮| 一本色道久久综合亚洲精品按摩| 免费欧美日韩国产三级电影| 欧美激情亚洲| 一区二区三区在线视频播放| 亚洲无线观看| 久久精品国产在热久久 | 欧美精品激情在线观看| 亚洲最新视频在线| 亚洲欧美日韩人成在线播放| 国产精品美女黄网| 亚洲欧美清纯在线制服| 亚洲成在线观看| 久久精品青青大伊人av| av成人免费在线观看| 亚洲国产日韩一区| 国产综合欧美在线看| 亚洲欧洲在线免费| 能在线观看的日韩av| 在线亚洲欧美专区二区| 亚洲国产欧美日韩另类综合| 国产欧美日韩精品专区| 欧美午夜电影一区| 欧美1区2区3区| 久久久久久久综合狠狠综合| 亚洲国产天堂网精品网站| 久久精品国产99国产精品| 樱桃视频在线观看一区| 国产精品亚洲综合久久| 欧美日韩精品久久久| 蜜臀av一级做a爰片久久| 99re6这里只有精品| 国产欧美91| 国产精品视频观看| 国产精品美女一区二区| 欧美午夜不卡在线观看免费 | 亚洲激情视频网| 韩国三级在线一区| 极品尤物av久久免费看| 国产精品一区久久久久| 国产精品99一区| 国语自产精品视频在线看抢先版结局 | 欧美午夜精品理论片a级按摩| 欧美性一区二区| 怡红院av一区二区三区| 亚洲精品日韩综合观看成人91| 日韩亚洲精品在线| 久久黄金**| 日韩亚洲国产欧美| 老色鬼久久亚洲一区二区| 欧美日韩国产综合视频在线观看中文 | 亚洲视频第一页| 噜噜噜噜噜久久久久久91| 亚洲国产综合91精品麻豆| 亚洲视频中文| 欧美日本一道本| 国产综合色一区二区三区| 亚洲乱码久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲国产va精品久久久不卡综合| 亚洲每日在线| 女同一区二区| 永久久久久久| 久久久噜噜噜久噜久久| 亚洲欧美成人在线| 国产精品成人一区二区| 亚洲精品一区二区三区不| 欧美大片免费观看| 久久另类ts人妖一区二区| 亚洲免费视频一区二区| 欧美日韩综合在线| 亚洲一区二区三区四区五区午夜| 91久久国产综合久久| 久久综合给合久久狠狠狠97色69| 国产精品日日做人人爱| 亚洲欧美日本国产专区一区| 日韩视频在线观看| 欧美午夜电影一区| 欧美伊人久久久久久久久影院| 99综合电影在线视频| 亚洲免费激情| 久久免费精品日本久久中文字幕| 国产精品久久久久久亚洲毛片| 亚洲午夜日本在线观看| 亚洲欧美日韩中文在线制服| 国产日本亚洲高清| 亚洲国产片色| 国产亚洲欧美激情| 亚洲国产一区二区三区在线播 | 久久久另类综合| 最新成人在线| 亚洲欧美国产不卡| 亚洲激情自拍| 欧美在线观看视频| 亚洲婷婷在线| 久久婷婷国产综合尤物精品| 亚洲一区不卡| 欧美电影免费网站| 久久免费黄色| 国产欧美日韩一区二区三区在线观看 | 亚洲免费中文字幕| 亚洲私人影院| 欧美日韩国产欧| 欧美大色视频| 亚洲国产精品一区二区第一页 | 国产精品久久久久久久一区探花| 久久免费国产精品| 国产精品女人久久久久久| 亚洲三级网站| 亚洲免费观看视频| 欧美国产日韩一区二区在线观看| 蜜桃av一区二区三区| 狠狠色狠狠色综合日日五| 亚洲尤物视频在线| 香蕉精品999视频一区二区| 欧美午夜视频| 欧美资源在线观看| 老司机久久99久久精品播放免费| 国产日韩欧美日韩| 久久精品91| 亚洲国产日韩欧美综合久久| 亚洲精品精选| 欧美日韩综合在线免费观看| 9国产精品视频| 久久久最新网址| 亚洲精品在线一区二区| 欧美日韩免费高清| 欧美在线播放| 91久久久亚洲精品| 香蕉久久一区二区不卡无毒影院| 国产一区二区精品丝袜| 欧美电影在线| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲电影天堂av| 国产精品捆绑调教| 久久一区二区三区超碰国产精品| 亚洲第一网站| 欧美精品一区视频| 先锋影音一区二区三区| 亚洲精品看片| 黄色国产精品| 国产精品久久久久久影视| 另类激情亚洲| 久久婷婷国产综合精品青草 | 国产亚洲欧美一区二区三区| 久久亚洲综合|