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

string

string
posts - 27, comments - 177, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理
通常我們大量使用array of structure來開發程序,因為array of structure 具有面向對象的特征,易于描述客觀世界,代碼也容易理解。但是 array of structure 卻常常會阻礙程序的并行化。
structure of array 與之相反,它易于并行化,但拙于描述客觀世界,代碼也變得難以理解。 
要想代碼性能好就要使用structure of array , 要想開發效率高就要使用array of structure, 設計之初就要做出選擇,開發后期如果想轉換到另一種方案將會大費周章。 
 Intel 的 Array building block 提供了一套編程接口 讓我們可以從array of structure 的視角編寫基于 structure of array的程序。這話說起來有點繞,可以這樣理解,在邏輯層是array of structure , 在物理層是structrue of array. 
在C++中我們如何實現這種邏輯層(array of structure )/物理層(structrue of array )的分離與映射呢?
這是我們基于array of structure 的程序
struct RGB
{
        int r;
        int g;
        int b;
};
template<class T>
void test(T& rgb, size_t n)
{
    int i =0;
    for(i=0;i<SIZE;i++){
        rgb[i].r = 3*i;
        rgb[i].g = 3*i + 1;
        rgb[i].b = 3*i + 2;
    }
    for(i=0;i<SIZE;i++){
        rgb[i].b=rgb[i].r + rgb[i].g;
    }

#define SIZE 65536
int main()
{
  RGB* rgb = new RGB[SIZE];
  test(rgb, SIZE);
}

要將上面的程序轉換為SOA,我們首先為RGB定義一個影子
struct RGBshadow
{
        RGBshadow(int& r, int& g, int& b):r(r),g(g),b(b){}
        int& r;
        int& g;
        int& b;
};

然后我們有一個模板類用于定義SOA類,此類為通用類
template<class Shadow, typename T1, typename T2, typename T3>
class SOA
{
    public:
        typedef T1 aligned_t1 __attribute__((aligned(16)));
        typedef T2 aligned_t2 __attribute__((aligned(16)));
        typedef T3 aligned_t3 __attribute__((aligned(16)));
    public:
        SOA(int n){
            r = (aligned_t1*)_mm_malloc(n*sizeof(T1), 64);
            g = (aligned_t2*)_mm_malloc(n*sizeof(T2), 64);
            b = (aligned_t3*)_mm_malloc(n*sizeof(T3), 64);
        }
        ~SOA(){
            if(r) _mm_free(r);
            if(g) _mm_free(g);
            if(b) _mm_free(b);
        }
        Shadow operator [] ( size_t i){
            return Shadow(r[i],g[i],b[i]);
        }
    private:
        aligned_t1* r ;
        aligned_t2* g ;
        aligned_t3* b ;
};

#define SIZE 65536
int main()
{
  RGB* rgb = new RGB[SIZE];
  test(rgb, SIZE);
  SOA<RGBshadow, intint,int> soa(SIZE);
  test(soa, SIZE);
}
編譯器會自動向量化test(soa,SIZE);
test(rgb, SIZE);中的第二個for循環生成的代碼如下:
.L14:
    movl    (
%rbx,%rax), %edx
    addl    
4(%rbx,%rax), %edx
    movl    
%edx, 8(%rbx,%rax)
    addq    $
12%rax
    cmpq    $
786432%rax
    jne .L14

test(soa, SIZE);中的第二個for循環生成的代碼如下:
.L16:
    movdqa  (
%rsi,%rax), %xmm0
    paddd   (
%rcx,%rax), %xmm0
    movdqa  
%xmm0, (%rdx,%rax)
    addq    $
16%rax
    cmpq    $
262144%rax
    jne .L16

要將AOS轉換為SOA,分如下三步
1。 定義一個影子結構
2。 利用SOA<shadow,...>模板定義相應的SOA結構
3。 修改業務代碼,SOA<shadow,...> 與AOS有相同的操作方式,因而可以盡量少的修改代碼。


Feedback

# re: 并行化你的程序--Array of structure 與 structure of Array  回復  更多評論   

2012-08-06 14:14 by ningle
看你的博客,uefi的application基本都是用C++寫成,難道這是現在uefi application開發的主流嘛?

# re: 并行化你的程序--Array of structure 與 structure of Array  回復  更多評論   

2012-08-06 22:16 by djx_zh
@ningle
開發UEFI application的主流還是C。 如果application規模十分龐大,用C++開發效率會高些。

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜日韩在线观看| 美女主播视频一区| 亚洲精品影院| 欧美性淫爽ww久久久久无| 亚洲女人av| 欧美一区二区网站| 精品999久久久| 欧美高清视频一区| 欧美精品在线观看91| 亚洲女人天堂av| 欧美一区二区女人| 亚洲第一偷拍| 在线视频一区二区| 黄色一区二区在线| 91久久中文| 国产精品久久久久久久久久尿| 欧美一区二区三区婷婷月色| 久久久91精品国产| 亚洲视频精选在线| 久久国产主播| 亚洲午夜视频在线| 久久精品午夜| 亚洲网址在线| 久久久久这里只有精品| 亚洲视频网在线直播| 久久久精品网| 亚洲图片欧洲图片av| 久久狠狠婷婷| 亚洲欧美日韩精品| 免费欧美视频| 久久久久久久久岛国免费| 欧美日韩国产成人精品| 久久综合九九| 国产精品成人一区二区| 欧美激情第4页| 国产伦一区二区三区色一情| 欧美国产日韩在线| 国产亚洲在线观看| 中文精品在线| 夜久久久久久| 免费成人在线视频网站| 久久精选视频| 国产精品网站一区| 99日韩精品| 日韩一级黄色av| 免费亚洲电影在线| 久久美女性网| 国产老肥熟一区二区三区| 亚洲国产精品悠悠久久琪琪| 狠狠入ady亚洲精品经典电影| 在线视频日韩| 亚洲一区视频在线| 欧美日韩在线三区| 亚洲国产成人porn| 最新国产成人在线观看| 久久婷婷av| 久热精品在线视频| 国产综合18久久久久久| 亚洲一区二区三区国产| 亚洲一区久久久| 欧美日韩在线一区二区三区| 最新高清无码专区| 日韩一级在线| 欧美日韩免费观看一区=区三区| 欧美激情一区二区三区全黄| 亚洲福利国产精品| 老司机一区二区| 欧美激情精品久久久久| 亚洲精品美女| 欧美另类高清视频在线| 99国产精品99久久久久久粉嫩 | 亚洲欧美资源在线| 亚洲欧美另类在线观看| 国产麻豆午夜三级精品| 亚洲男人的天堂在线| 欧美一区三区二区在线观看| 国产一二三精品| 久久精品视频在线看| 欧美国产精品专区| 亚洲精品一二三| 欧美三级电影大全| 西瓜成人精品人成网站| 久久综合综合久久综合| 亚洲精选中文字幕| 欧美视频免费| 午夜精品视频一区| 欧美凹凸一区二区三区视频| 亚洲国产影院| 欧美视频在线一区二区三区| 亚洲欧美成人一区二区三区| 久久久久久夜| 亚洲精品欧美一区二区三区| 国产精品av一区二区| 欧美一级淫片播放口| 欧美国产综合一区二区| 亚洲婷婷国产精品电影人久久| 国产精品五区| 欧美成人精品不卡视频在线观看| 亚洲每日更新| 久久亚洲一区二区三区四区| 亚洲精品国产精品乱码不99按摩| 国产精品福利网| 噜噜噜噜噜久久久久久91| 一区二区三区精品在线| 久久综合色天天久久综合图片| 99精品欧美一区二区三区综合在线| 国产精品羞羞答答| 美国成人毛片| 欧美一区二视频| 99国产精品私拍| 久久亚洲精品网站| 亚洲夜间福利| 亚洲精品久久久蜜桃| 国产嫩草一区二区三区在线观看| 欧美xxx成人| 久久久久国色av免费观看性色| 妖精成人www高清在线观看| 美日韩精品免费| 久久成人综合视频| 在线亚洲成人| 亚洲精品女人| 尤物精品国产第一福利三区 | 久久久久久亚洲精品中文字幕| 日韩一区二区福利| 欧美激情视频一区二区三区不卡| 久久精品官网| 小黄鸭精品密入口导航| 一区二区三区不卡视频在线观看 | 狠狠久久亚洲欧美| 国产精品一区二区在线观看| 欧美日韩亚洲国产一区| 免费成人av| 老牛国产精品一区的观看方式| 亚洲午夜精品一区二区三区他趣| 亚洲免费激情| 亚洲精品综合| 亚洲精品国产视频| 亚洲激情综合| 亚洲激情网站| 日韩视频一区二区三区在线播放免费观看 | 99国产精品久久久久久久| 亚洲国产精品久久人人爱蜜臀| 在线免费不卡视频| 在线视频成人| 亚洲缚视频在线观看| 在线播放国产一区中文字幕剧情欧美| 国产日韩欧美一区二区| 国产亚洲欧美一区二区| 国产免费成人| 伊人成综合网伊人222| 一区二区三区自拍| 91久久黄色| 亚洲精品美女久久久久| 99精品国产一区二区青青牛奶| 日韩亚洲欧美成人一区| 99国产精品久久久久久久久久| 亚洲视频欧洲视频| 欧美一二三区精品| 久久久91精品国产| 欧美韩日高清| 日韩一级精品视频在线观看| 亚洲一区二区三区在线| 欧美与欧洲交xxxx免费观看| 久久久精品午夜少妇| 欧美黄色小视频| 国产精品对白刺激久久久| 国产亚洲美州欧州综合国| 在线日本成人| 亚洲私人影院| 久久国产精品久久久久久电车| 久久中文久久字幕| 91久久精品日日躁夜夜躁国产| 日韩亚洲精品在线| 欧美一区二区三区另类| 欧美成人四级电影| 国产精品免费观看视频| 黄色在线一区| 亚洲一区二区在线免费观看| 久久手机免费观看| 亚洲毛片av| 久久久久久网址| 国产精品国产馆在线真实露脸| 国产一区二区三区在线观看免费视频| 亚洲人成网在线播放| 午夜精品一区二区三区电影天堂| 免费观看不卡av| 一级成人国产| 免费看成人av| 国产亚洲欧美另类一区二区三区| 亚洲精品系列| 美女精品国产| 性亚洲最疯狂xxxx高清| 欧美乱妇高清无乱码| 一区二区三区在线视频免费观看 | 欧美影院精品一区| 亚洲国产小视频| 久久精品论坛| 国产精品一区二区在线观看不卡 | 亚洲精品在线观看免费| 久久精品99国产精品日本 |