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

woaidongmao

文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見(jiàn)諒!~
隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
數(shù)據(jù)加載中……

Intel TBB:Pipeline,軟件流水線的威力

參觀過(guò)工廠裝配線的人一定對(duì)流水線這個(gè)名字不陌生,半成品在皮帶機(jī)上流過(guò)一系列的流水線節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)以自己的方式進(jìn)一步裝配,然后傳給下一節(jié)點(diǎn)?,F(xiàn)代的高性能CPU均采用了這種流水線設(shè)計(jì),將計(jì)算任務(wù)分為取指,譯碼,執(zhí)行,訪存,反饋等幾個(gè)階段。采用流水線設(shè)計(jì)的最大優(yōu)點(diǎn)就是增加了系統(tǒng)吞吐量,例如,當(dāng)?shù)谝粭l指令處于執(zhí)行階段的時(shí)候,譯碼單元可以在翻譯第二條指令,而取指單元?jiǎng)t可以去加載第三條指令。甚至,在某些節(jié)點(diǎn)還可以并行執(zhí)行,例如,現(xiàn)代的MIMD多指令多數(shù)據(jù)的計(jì)算機(jī),可以在同一時(shí)間執(zhí)行多條指令,或者同時(shí)更新多個(gè)數(shù)據(jù)。

 

Intel認(rèn)識(shí)到頻率已成為CPU性能瓶頸之后,多核處理器應(yīng)運(yùn)而生。如今高性能程序設(shè)計(jì)的根本已經(jīng)轉(zhuǎn)變?yōu)槿绾胃浞值睦?/span>CPU資源,更快更多地處理數(shù)據(jù),而Intel所開(kāi)發(fā)的開(kāi)源 TBB庫(kù)巧妙的利用了流水線這種思想,實(shí)現(xiàn)了一個(gè)自適應(yīng)的高性能軟件流水線TBB::pipeline。本文將會(huì)以text_filter為例,簡(jiǎn)單介紹pipeline的實(shí)現(xiàn)原理和一些關(guān)鍵技術(shù)點(diǎn),以求達(dá)到拋磚引玉的效果。

 

介紹TBB::pipeline之前不得不先說(shuō)一下TBB庫(kù)的引擎-task scheduler,它又被稱(chēng)為TBB庫(kù)的心臟[Intel TBB nutshell book],是所有算法的基礎(chǔ)組件,用于驅(qū)動(dòng)整個(gè)TBB庫(kù)的運(yùn)作。例如,TBB庫(kù)所提供的parallel_for算法,里面就有task scheduler的蹤影,pipeline也不例外。

 

先看看parallel_for的實(shí)現(xiàn):

 

template<typename Range, typename Body>

 

void parallel_for( const Range& range, const Body& body, const simple_partitioner& partitioner=simple_partitioner() ) {

 

    internal::start_for<Range,Body,simple_partitioner>::run(range,body,partitioner);

 

}

 

再往下看:

 

    template<typename Range, typename Body, typename Partitioner>

 

    class start_for: public task {

 

        Range my_range;

 

        const Body my_body;

 

        typename Partitioner::partition_type my_partition;

 

        /*override*/ task* execute();

 

 

 

        //! Constructor for root task.

 

        start_for( const Range& range, const Body& body, Partitioner& partitioner ) :

 

...

 

        }

 

可以看到,class start_for是從task繼承的,而這個(gè)class task,就是task scheduler中進(jìn)行任務(wù)調(diào)度的基本元素---task,這也是TBB庫(kù)的靈魂所在。相對(duì)于原生線程庫(kù)(Raw Thread),例如POSIX thread(pthread),TBB庫(kù)可以看作是一種對(duì)多線程更高層面的封裝,它不再使用thread,而是以task作為基本的任務(wù)抽象,從而能夠更好的整合計(jì)算資源并最優(yōu)化的調(diào)度任務(wù)。TBB庫(kù)的種種優(yōu)點(diǎn),如自動(dòng)調(diào)整工作負(fù)荷,系統(tǒng)擴(kuò)展性等,全是拜task scheduler所賜。TBB提供的每種算法都有其獨(dú)特的應(yīng)用背景,如果算法不能滿(mǎn)足用戶(hù)的需求,那么完全可以以task為基類(lèi)派生出新類(lèi),擴(kuò)展出新的任務(wù)執(zhí)行和調(diào)度算法。這種思想貫穿了TBB的整個(gè)設(shè)計(jì),而TBB::pipeline,也是這種思想的典型體現(xiàn)。

 

TBB::pipeline的優(yōu)點(diǎn):

 

保證數(shù)據(jù)執(zhí)行的順序

線程負(fù)載自動(dòng)調(diào)節(jié)

更高的Cache命中率

系統(tǒng)擴(kuò)展性

 

假如目前有這樣一項(xiàng)任務(wù),對(duì)一個(gè)文件的內(nèi)容進(jìn)行分析,將每一個(gè)字符串的首字符改為大寫(xiě),然后寫(xiě)入一個(gè)新文件里。

 

一個(gè)傳統(tǒng)的串行執(zhí)行的解決方案是:

 

分別創(chuàng)建讀入和寫(xiě)出文件

 

while (!EOF)

{

從文件讀入一個(gè)字符串

首字符轉(zhuǎn)化為大寫(xiě)字符

寫(xiě)入一個(gè)字符串到文件

}

關(guān)閉讀入和寫(xiě)出文件的描述符

 

這么簡(jiǎn)單的過(guò)程,還有可能通過(guò)TBB::Pipeline來(lái)提供性能嗎?我們來(lái)看看Pipeline的解決方案:

 

1.分別創(chuàng)建讀入和寫(xiě)出文件描述符

 

2.建立三個(gè)task,分別是從文件讀入一個(gè)字符串,首字符轉(zhuǎn)化為大寫(xiě)字符,“ 寫(xiě)入一個(gè)字符串到文件,其中需要指定從文件讀入一個(gè)字符串寫(xiě)入一個(gè)字符串到文件這兩個(gè)task為串行執(zhí)行。(為什么要串行執(zhí)行,請(qǐng)自行思考或者去看Intel TBBnutshell book)

 

3.啟動(dòng)Pipeline,Pipeline通過(guò)內(nèi)建的task scheduler來(lái)調(diào)度這些task的運(yùn)行。

 

 

用一個(gè)29MB的文件作為測(cè)試用例,在我的雙核機(jī)器上串行執(zhí)行的速度是 0.527582秒,而Pipeline的速度是0.446161,對(duì)于更復(fù)雜的邏輯,Pipeline的性能還會(huì)顯著提升。性能提升的奧秘,就在于Pipeline能夠自動(dòng)根據(jù)系統(tǒng)情況,以并行方式執(zhí)行首字符轉(zhuǎn)化為大寫(xiě)字符這個(gè)task。

 

具體的Pipeline的示例代碼和使用,可以去參考Intel TBBnutshell book,這里想繼續(xù)深究一下:

 

1.  為什么Pipeline可以保證數(shù)據(jù)執(zhí)行的順序?既然TBB歸根到底是通過(guò)多線程執(zhí)行任務(wù),為什么不會(huì)在讀入先后兩個(gè)字符串后,后讀入的字符串先被下一個(gè)task處理?Pipeline里是不是有一個(gè)類(lèi)似于FIFO 先進(jìn)先出隊(duì)列之類(lèi)的東西?

 

2.  為什么Pipeline能夠自動(dòng)地并行執(zhí)行首字符轉(zhuǎn)化為大寫(xiě)字符這個(gè)task?如果這個(gè)task被并行執(zhí)行了,那么又怎么保證第一點(diǎn)?

 

3.  Pipeline是怎么保證那些task被串行執(zhí)行的。

 

4.  所謂自動(dòng)根據(jù)系統(tǒng)情況,進(jìn)行任務(wù)調(diào)度是怎么一回事?

 

這些既是問(wèn)題,也是Pipeline中的關(guān)鍵技術(shù)點(diǎn),有心的可以去研讀一下Pipeline的代碼先睹為快。

 

Intel TBBnutshell book -- <Intel Threading Building Blocks Outfitting C++ for Multi-Core Processor Parallelism>

 

posted on 2009-05-02 01:53 肥仔 閱讀(3552) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 庫(kù) & 代碼段

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲一区二区欧美| 久久亚洲美女| 韩国一区二区三区美女美女秀| 亚洲福利视频在线| 国产一区二区精品| 一区二区精品国产| 中文欧美在线视频| 欧美大片免费观看在线观看网站推荐| 久久久国产精品一区二区三区| 欧美日韩在线视频一区| 亚洲欧洲在线观看| 999亚洲国产精| 欧美久久九九| 亚洲精品久久久久久久久久久| 亚洲欧洲精品一区二区三区不卡| 久久资源av| 男人天堂欧美日韩| 亚洲福利视频一区二区| 久久免费的精品国产v∧| 蜜桃av一区| 欧美激情欧美狂野欧美精品| 在线观看日韩欧美| 美女脱光内衣内裤视频久久网站| 欧美99在线视频观看| 激情一区二区三区| 久久婷婷av| 亚洲国产精品电影在线观看| 亚洲美洲欧洲综合国产一区| 欧美日韩国产综合在线| 亚洲最新中文字幕| 欧美中文在线视频| 国模精品一区二区三区色天香| 久久精品国产清自在天天线| 欧美成人午夜免费视在线看片| 亚洲精品三级| 国产精品观看| 久久精品日韩欧美| 亚洲激情在线视频| 亚洲欧美在线看| 国产综合网站| 欧美片在线观看| 亚洲永久免费精品| 欧美高清在线视频| 亚洲欧美视频在线| 在线成人中文字幕| 欧美精品在线视频观看| 亚洲一区二区三区精品在线| 另类av导航| 亚洲一区二区精品视频| 国产亚洲精品v| 欧美不卡在线视频| 亚洲男同1069视频| 亚洲第一精品夜夜躁人人躁| 亚洲视频每日更新| 国内成+人亚洲| 欧美另类视频| 久久久精品免费视频| 亚洲欧洲日韩在线| 久久精品国产精品亚洲精品| 亚洲日本aⅴ片在线观看香蕉| 欧美日韩三级在线| 久久久国产精品亚洲一区| 日韩天堂av| 免费一区视频| 午夜欧美电影在线观看| 亚洲韩国日本中文字幕| 国产欧美 在线欧美| 欧美精品二区三区四区免费看视频| 亚洲欧美日韩综合国产aⅴ| 亚洲高清在线精品| 久久久久9999亚洲精品| 一区二区高清在线| 136国产福利精品导航| 国产精品美女久久福利网站| 久久综合中文字幕| 亚洲欧美国产视频| a4yy欧美一区二区三区| 欧美国产一区二区三区激情无套| 午夜日韩在线观看| 99热这里只有精品8| 一区二区视频免费完整版观看| 国产精品久久综合| 欧美日韩精品免费观看视频| 久久亚洲风情| 久久婷婷人人澡人人喊人人爽 | 在线观看成人网| 国产精品视频九色porn| 欧美日韩在线第一页| 欧美黄色小视频| 欧美大片在线观看一区二区| 久久人人看视频| 久久精品国产综合| 欧美在线啊v一区| 欧美二区在线观看| 老司机精品福利视频| 久久成人久久爱| 性高湖久久久久久久久| 一区二区三区日韩欧美| 一本到高清视频免费精品| 亚洲精品免费网站| 欧美一区午夜视频在线观看| 久久人91精品久久久久久不卡| 国产一区二区三区在线观看免费视频| 欧美午夜不卡影院在线观看完整版免费| 免费观看日韩| 久久久久久久综合日本| 欧美伊人久久| 欧美中文字幕不卡| 欧美一站二站| 久久综合九色综合欧美就去吻| 久久久亚洲影院你懂的| 久久亚洲美女| 欧美—级a级欧美特级ar全黄| 欧美丰满少妇xxxbbb| 欧美国产日韩一区二区在线观看| 欧美成人在线免费观看| 欧美激情精品久久久六区热门| 欧美精品福利| 国产精品www色诱视频| 欧美色道久久88综合亚洲精品| 欧美日韩一区在线观看| 欧美日韩国产色视频| 欧美国产在线观看| 美女精品视频一区| 欧美精品在线观看一区二区| 国产精品多人| 国产精品日韩高清| 国内精品视频久久| 国产综合18久久久久久| 亚洲国产日韩欧美| 亚洲国产导航| 亚洲视频在线观看网站| 一本色道久久综合亚洲91| 一本大道久久a久久精品综合| 99精品欧美一区二区三区综合在线 | 在线观看91精品国产麻豆| 国产一区二区成人| 亚洲国产美女精品久久久久∴| 在线成人h网| 亚洲一区免费| 欧美一级淫片播放口| 欧美国产日韩一区二区| 欧美一区二视频| 欧美阿v一级看视频| 9l视频自拍蝌蚪9l视频成人 | 久久精品一区| 欧美激情一区二区三区| 欧美成人免费在线| 国产精品成人va在线观看| 狠狠色丁香久久婷婷综合丁香| 黄色成人av在线| 一本久久综合亚洲鲁鲁| 一区二区三区视频观看| 亚洲日本理论电影| 亚洲一二三四区| 欧美成人视屏| 一区二区三区精品久久久| 久久精品综合| 欧美激情精品久久久久| 精品99视频| 亚洲视频网站在线观看| 正在播放亚洲一区| 久久国产精品99国产| 女女同性精品视频| 亚洲免费人成在线视频观看| 欧美一区二区三区四区在线观看地址 | 欧美精品福利在线| 国产视频久久| 在线观看视频一区二区欧美日韩| av不卡在线观看| 一区二区久久久久| 欧美3dxxxxhd| 性欧美大战久久久久久久久| 老司机精品视频网站| 国产精品揄拍500视频| 亚洲欧洲一区二区在线观看| 欧美在线视频免费观看| 亚洲二区在线视频| 久久精品视频99| 国产精品二区影院| 一区二区三区国产在线观看| 亚洲一区不卡| 亚洲精品一区在线观看| 美日韩在线观看| 国产精品无人区| 香蕉免费一区二区三区在线观看| 欧美高清视频一区二区| 久久久久综合一区二区三区| 欧美日韩小视频| 99精品国产一区二区青青牛奶| 欧美一区免费视频| 亚洲制服av| 欧美麻豆久久久久久中文| 日韩视频中午一区| 亚洲免费成人av电影| 免费不卡在线视频| 久久这里只精品最新地址| 国产精品亚洲一区| 久久99伊人| 亚洲一区二区三区国产|