《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 其他 > 業(yè)界動態(tài) > 常量時(shí)間的優(yōu)先隊(duì)列算法

常量時(shí)間的優(yōu)先隊(duì)列算法

2009-09-25
作者:劉晨亮 許家棟 楊少軍

  摘?? 要: 提出了一種硬件實(shí)現(xiàn)的優(yōu)先隊(duì)列算法,可以在常量時(shí)間內(nèi)完成插入和解壓操作,達(dá)到OC3072線速要求。

  關(guān)鍵詞: 常量時(shí)間的優(yōu)先隊(duì)列? OC3072線速? QoS

?

  隨著網(wǎng)絡(luò)的高速發(fā)展,用戶對網(wǎng)絡(luò)質(zhì)量的需求也越來越高,調(diào)查顯示用戶對網(wǎng)絡(luò)的抱怨主要體現(xiàn)為速度慢,質(zhì)量沒有保證。要解決這個(gè)問題需要對網(wǎng)絡(luò)路由節(jié)點(diǎn)進(jìn)行QoS(Quality of Service)改造,完善已有的QoS功能,用新的具有QoS能力的路由器逐步替代老一代產(chǎn)品。目前IETF等組織提出的QoS方案有2類,即路由器節(jié)點(diǎn)的QoS和路由器網(wǎng)絡(luò)的QoS(如MPLS和Traffic Engineering)。路由器節(jié)點(diǎn)的QoS還可以細(xì)分為公平的需求和不公平的需求。前者主要包括各種公平調(diào)度算法,后者包括公平調(diào)度算法的不公平配置、BES、RVSP、IS和DS算法。節(jié)點(diǎn)QoS中的很多算法(如調(diào)度算法和DS算法)最終都?xì)w結(jié)為傳統(tǒng)的優(yōu)先隊(duì)列算法。由于純軟件實(shí)現(xiàn)的優(yōu)先隊(duì)列算法不能滿足高速路由器的需求,本文提出了一種硬件支持的常量時(shí)間的優(yōu)先隊(duì)列存取算法,能夠達(dá)到OC3072(即160Gbps)線速要求。

1? 相關(guān)工作

  目前有2類常量時(shí)間的優(yōu)先隊(duì)列算法:(1)基于通用內(nèi)存的算法,如P-Heap算法。(2)基于專用內(nèi)存的算法,這種算法起源于vEB(van Emde Boas)優(yōu)先隊(duì)列結(jié)構(gòu),一般被稱作STT(Split Tagged Tree)算法。P-Heap算法提出了一種稱之為P-Heap的數(shù)據(jù)結(jié)構(gòu):每次插入和解壓至少經(jīng)過3次內(nèi)存操作,而且它使用流水線隔行工作,相當(dāng)于進(jìn)行6次內(nèi)存操作才能獲得1次結(jié)果。這種機(jī)制是提高效率的主要瓶頸,最高支持OC192(即10Gbps)線速。STT算法得益于vEB提出的優(yōu)秀結(jié)構(gòu),它的速度足夠支持OC768(即40Gbps),但它必須采用專門定制的內(nèi)存,這種內(nèi)存因?yàn)楫a(chǎn)量很小而導(dǎo)致成本無法降低。受到P-Heap的啟發(fā),提出一種B-Heap結(jié)構(gòu),單一隊(duì)列可以實(shí)現(xiàn)OC768線速。如果把4個(gè)B-Heap優(yōu)先隊(duì)列組合起來,則可以滿足OC3072線速的要求。

2? B-Heap的工作原理

2.1 基本操作

  硬件B-Heap的操作特點(diǎn)是在各個(gè)分層之間使用流水線工作,插入元素的同時(shí)也完成了解壓元素的操作。這一點(diǎn)和P-Heap有所不同,雖然P-Heap也是流水線工作,但需要隔層操作。假設(shè)插入的元素序列為{0,3,4,2,

6,8,1,9,1,7,5,3,2,8,0,-1,-1,-1,-1,2,-1,5,3,9},則初始階段的插入解壓過程如圖1所示,對應(yīng)前8個(gè)元素;有空閑情況下的插入解壓過程如圖2所示,對應(yīng)最后8個(gè)元素,說明流量減小時(shí)插入占位數(shù)據(jù)-1的過程;255是-1的一種表達(dá)方式,其中涉及到比較模式切換問題,中間8個(gè)元素的插入解壓類似于圖1的無空閑情況下的操作。上述3個(gè)過程雖然各自代表實(shí)際操作中的各種情況,但是三者之間設(shè)計(jì)成連續(xù)的,便于觀察。元素從下向上流經(jīng)該結(jié)構(gòu),方框代表針對堆結(jié)構(gòu)每一層的數(shù)據(jù)寄存器,最下端的寄存器為插入輸入,灰色寄存器為解壓輸出。

?

?

  主要的工作機(jī)制是每次操作選擇一條最小路徑,每一次操作按最小路徑進(jìn)行,比較后進(jìn)行流水線上移。這里的最小路徑是指從上到下依次選擇上層入選節(jié)點(diǎn)的子節(jié)點(diǎn)中較小的元素所構(gòu)成的路徑。其中有2種特殊情況:(1)最上面一層只有一個(gè)節(jié)點(diǎn),因此入選。(2)如果子節(jié)點(diǎn)中元素大小相等則左手子節(jié)點(diǎn)入選。每一層所對應(yīng)的寄存器作為該層的比較輸入,與該層最小路徑上的元素作比較,將較小者放入上一層寄存器的緩沖器。每層寄存器都包括一個(gè)寄存器的緩沖器。寄存器讀取前打開,寫入前關(guān)閉,以滿足流水線操作時(shí)的同步要求。規(guī)定當(dāng)前沒有輸入時(shí)用-1模擬1個(gè)輸入,即所謂的空閑情況。對最下面一層的輸入寄存器為-1的狀態(tài)需要進(jìn)行一次特殊的操作,即結(jié)構(gòu)中所有比較器進(jìn)行模式切換,將-1認(rèn)為是與255進(jìn)行比較,這樣有助于空閑情況下將原來元素按從小到大的順序解壓出來。在具體實(shí)現(xiàn)中將-1認(rèn)為是255的模式切換很容易辦到,因?yàn)閷τ谝粋€(gè)有符號字節(jié)-1,如果用無符號字節(jié)對其進(jìn)行識別就是255。有了這種機(jī)制,在空閑情況下也可以保證空閑之前進(jìn)入堆中的數(shù)據(jù)能夠正常流出。輸出結(jié)果顯示,圖中的B-Heap結(jié)構(gòu)實(shí)現(xiàn)了排隊(duì)空間n=8的在線優(yōu)先隊(duì)列。

2.2 最小路徑查找

  通過觀察可以發(fā)現(xiàn),每次操作都需要查找最小路徑,這一環(huán)節(jié)是B-Heap算法進(jìn)行高速處理的關(guān)鍵。查找的最小路徑如圖3所示。結(jié)構(gòu)中每一層節(jié)點(diǎn)的地址可以表示為從0開始的二進(jìn)制數(shù),例如從上向下第4層的每一次操作的輸入地址可表示為000,001,010,011,100,101,110,111。B-Heap的狀態(tài)可以表示為X|XX|XXXX|……,其中X為0或1。0表示左手節(jié)點(diǎn)小于右手節(jié)點(diǎn),1表示左手節(jié)點(diǎn)大于右手節(jié)點(diǎn),|為層分隔符,區(qū)別從上到下每一層的狀態(tài)。則圖3中B-Heap的狀態(tài)可表示為,每次操作在每一層中最多修改1bit。查找最小路徑即求出從狀態(tài)到每一層輸入地址的轉(zhuǎn)換結(jié)構(gòu)。下面介紹如何設(shè)計(jì)該轉(zhuǎn)換:由于每一層使用不同的內(nèi)存,屬于并行操作,因此可以在上一次操作結(jié)束時(shí)得到所有的狀態(tài)位,而每次僅僅修改1bit,這樣不會造成較大的總線寬度硬件耗費(fèi)。要從狀態(tài)中找出最小路徑可以通過一個(gè)以狀態(tài)為輸入。多層地址為輸出的地址編碼器來完成。如果采用ASIC,則可以使用足夠的寄存器存儲狀態(tài),從而完全在片內(nèi)實(shí)現(xiàn)編碼器,對外只保留很小的總線寬度,能滿足每層只修改1bit即可。

?

?

  內(nèi)部邏輯類似于前綴樹,實(shí)際上是在前綴樹結(jié)構(gòu)基礎(chǔ)上簡化了一半的狀態(tài)耗費(fèi)。定義每個(gè)二叉樹節(jié)點(diǎn)的左、右子節(jié)點(diǎn)的比較結(jié)果為b,稱為路徑選擇變量。b是一個(gè)布爾量,為0表示左手子節(jié)點(diǎn)的值小于右手子節(jié)點(diǎn)的值,為1則恰好相反。從二叉樹的根開始,判斷路徑選擇變量,如果為1,則選擇左子樹;如果為0,則選擇右子樹。照此向下推進(jìn),直到葉節(jié)點(diǎn)為止,所形成的路徑就是需要尋找的最小路徑。路徑選擇變量存儲在寄存器中,每個(gè)變量占用1bit。因?yàn)榈谝粚硬⒉恍枰撟兞?所以路徑選擇變量總共占有n/2bit,使用m個(gè)寄存器,其中m=? 。為了區(qū)別每一層的數(shù)據(jù)寄存器數(shù)組T,這m個(gè)寄存器稱為路徑選擇寄存器。

  使用ASIC實(shí)現(xiàn)時(shí),判斷路徑選擇變量并選擇一條分支的時(shí)間耗費(fèi)t是門級,目前的硬件工藝可以做到十幾到幾十個(gè)皮秒(ps)。整條路徑選擇的時(shí)間耗費(fèi)大約為t的倍。一般情況下<20,所以整條路徑選擇的時(shí)間實(shí)現(xiàn)不會超過1ns。輸出的每一層的地址是可以復(fù)用的,如圖3的狀態(tài)字中最小路徑對應(yīng)每一層節(jié)點(diǎn)地址為{0,0,01,011,0111,……},上層的地址是下層地址的前綴。由此可知第一層不需要地址,因此所有輸出數(shù)據(jù)的地址位數(shù)=

  綜上所述,B-Heap算法的一次存取要完成以下步驟。

  (1)根據(jù)每一層的比較地址找到比較節(jié)點(diǎn),打開數(shù)據(jù)寄存器數(shù)組T中每個(gè)寄存器的緩存,刷新寄存器。(2)取出比較節(jié)點(diǎn)的值和本層數(shù)據(jù)寄存器中的值相比較,其中較小值寫入上一層數(shù)據(jù)寄存器的緩存,較大值寫入該節(jié)點(diǎn)。同時(shí),輸入寄存器和輸出寄存器中都有了最新值。(3)將較大值和比較節(jié)點(diǎn)的兄弟節(jié)點(diǎn)進(jìn)行比較,如果左節(jié)點(diǎn)大于右節(jié)點(diǎn),則b=1;反之,b=0。將結(jié)果寫入路徑選擇寄存器的相應(yīng)位置。(4)將路徑選擇寄存器的值輸入路徑選擇模塊以選擇一條最小路徑。這一步由ASIC實(shí)現(xiàn),輸入n/2位,輸出位。輸出中含有所有層的下一次比較地址。

3? 性能評估和合并隊(duì)列

  由于路徑選擇的時(shí)間在總的時(shí)間耗費(fèi)中不占很大比重,因此B-Heap插入和解壓的時(shí)間耗費(fèi)約為P-Heap的1/4。其中逐行操作比隔行操作快一倍,插入和解壓的同步進(jìn)行比分別進(jìn)行快一倍。所以按照P-Heap分析所依據(jù)的內(nèi)存和ASIC工藝水平,B-Heap可以達(dá)到OC768線速。同時(shí),可以使用4片B-Heap擴(kuò)展排隊(duì)長度和操作速度,對4片子優(yōu)先隊(duì)列進(jìn)行RR(Round Robin)調(diào)度可以達(dá)到OC3072線速。

4? 結(jié)束語

  本文提出了一種硬件輔助的優(yōu)先隊(duì)列算法B-Heap,通過特殊的結(jié)構(gòu)和操作策略可以達(dá)到OC3072線速,在使用普通內(nèi)存的方法中優(yōu)于P-Heap算法。B-Heap算法的主要不足是排隊(duì)長度受到寄存器的限制,例如一個(gè)1024排隊(duì)長度的B-Heap需要16個(gè)寄存器,目前的工藝完全可以承受。但是如果排隊(duì)長度按幾何比例增長,則B-Heap的實(shí)現(xiàn)依賴于能夠集成的寄存器數(shù)目。

?

參考文獻(xiàn)

1?? Xipeng X,Lionel M N.Internet QoS:A Big Picture.IEEE Network,1999;(4)

2?? Bhagwan R,Lin B.Fast and Scalable Priority Queue?Architecture for Highspeed Network Switches.IEEE?Infocom,2000;(3)

3?? Brodnik A.Worst Case Constant Time Priority Queue.WCCTPQ,2000;(3)

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品99久久久久久久久久久久| 亚洲国产成人av| 国产一区二区三区日韩欧美| 欧美四级剧情无删版影片| 欧美成人精精品一区二区频| 久久久久免费观看| 欧美一区二区三区视频免费播放| 亚洲一二三区精品| 99在线热播精品免费99热| 亚洲国产天堂网精品网站| 欧美亚洲在线观看| 午夜久久久久久| 午夜欧美精品| 欧美影院一区| 久久国产一区| 亚洲电影欧美电影有声小说| 久久国产欧美日韩精品| 欧美亚洲一级| 欧美在线影院在线视频| 亚洲欧美国产制服动漫| 亚洲影视在线| 亚洲一区在线免费观看| 亚洲一区999| 亚洲一区二区视频在线观看| 亚洲一区二区三区视频| 亚洲一区二区在| 亚洲欧美精品suv| 西瓜成人精品人成网站| 久久精品二区| 亚洲日本中文| 一区二区三区色| 亚洲欧美日韩国产一区| 性做久久久久久免费观看欧美| 性欧美办公室18xxxxhd| 欧美在线一区二区三区| 久久久久久久久久久一区| 久久精品综合网| 免费看的黄色欧美网站| 欧美紧缚bdsm在线视频| 欧美色综合网| 国产日韩欧美在线播放| 影院欧美亚洲| 亚洲精品日韩一| 亚洲欧美一区在线| 亚洲黄一区二区| 夜夜嗨av一区二区三区四季av| 亚洲在线观看免费| 久久精品最新地址| 欧美成人免费观看| 欧美图区在线视频| 国产一区二区高清不卡| 亚洲国产乱码最新视频| 亚洲视频欧洲视频| 久久国产精品一区二区三区| 99国内精品| 午夜精品偷拍| 美女任你摸久久| 欧美午夜欧美| 国内精品久久久久久久影视蜜臀| 亚洲人体影院| 亚洲一区区二区| 亚洲黄色av| 亚洲自拍偷拍一区| 久久免费高清视频| 欧美日韩国产va另类| 国产乱码精品1区2区3区| 一区二区三区在线免费观看| 99视频精品免费观看| 欧美在线免费一级片| 日韩亚洲欧美高清| 久久国产欧美日韩精品| 欧美精品一区二区高清在线观看| 久久视频在线视频| 欧美日韩精品久久久| 国产一区二区三区高清在线观看| 亚洲日本va午夜在线电影| 亚洲一区二区网站| 99视频精品全国免费| 久久超碰97中文字幕| 欧美日韩成人在线视频| 国产一区二区日韩精品| 一区二区三区国产在线| 欧美在线影院| 午夜久久美女| 米奇777在线欧美播放| 国产精品日韩在线| 91久久精品日日躁夜夜躁国产| 午夜精品久久久久久久蜜桃app | 99精品视频免费观看| 欧美一区二区黄| 欧美全黄视频| 激情校园亚洲| 亚洲女同性videos| 一区二区日韩欧美| 模特精品裸拍一区| 国产日本欧美一区二区三区| 亚洲国产一区二区三区在线播| 欧美在线精品免播放器视频| 午夜精品久久久久久久| 欧美日韩精品三区| 亚洲国产成人av好男人在线观看| 欧美一区二区三区精品电影| 亚洲一区二区三区色| 欧美激情精品久久久久久| 国产一区二区在线免费观看| 亚洲一二三区在线| 亚洲午夜国产一区99re久久| 欧美激情欧美狂野欧美精品| 在线成人国产| 亚洲国产精品成人久久综合一区| 亚洲欧美日韩在线观看a三区| 欧美久久久久| 亚洲人在线视频| 亚洲人成在线播放网站岛国| 久久综合亚洲社区| 狠狠综合久久| 久久精品91久久香蕉加勒比| 久久精品女人| 国产视频综合在线| 亚洲日本欧美| 国产精品99久久久久久白浆小说| 欧美一区二区三区久久精品| 国产精品www网站| 国产精品99久久久久久久久久久久 | 一区二区三区久久精品| 欧美日本一区| 亚洲黄色在线| 99热免费精品在线观看| 欧美日韩天堂| 一卡二卡3卡四卡高清精品视频| 在线视频日韩精品| 国产精品v日韩精品| 亚洲一级一区| 欧美在线观看视频在线| 国产欧美日韩在线视频| 午夜精品视频一区| 久久久91精品国产| 韩国美女久久| 亚洲激情欧美激情| 欧美激情第3页| 一区二区免费在线视频| 亚洲一区二区视频| 国产精品一二三四| 欧美一区二区三区免费在线看| 久久精品亚洲国产奇米99| 伊人久久综合| 亚洲乱码精品一二三四区日韩在线| 欧美精品一区二区在线播放| 99精品欧美一区二区蜜桃免费| 亚洲欧美日本国产专区一区| 国产亚洲aⅴaaaaaa毛片| 久久高清福利视频| 免费短视频成人日韩| 日韩一级免费| 久久精品国亚洲| 亚洲经典视频在线观看| 亚洲无线视频| 国产一区二区三区久久精品| 亚洲韩日在线| 欧美午夜免费电影| 欧美在线日韩精品| 欧美精品久久久久久久| 国内欧美视频一区二区| 99热精品在线观看| 国产精品嫩草99a| 亚洲国产日韩一区| 欧美日韩一区二区三区免费| 亚洲自拍偷拍麻豆| 美女图片一区二区| 一区二区三区久久网| 久久久不卡网国产精品一区| 国产精品一区二区久久久久| 久久国产精品久久久| 欧美裸体一区二区三区| 亚洲专区一区| 欧美国产日韩精品免费观看| 亚洲天堂网在线观看| 麻豆国产精品777777在线| 99精品国产福利在线观看免费| 久久激情综合网| 亚洲区一区二区三区| 欧美在线三区| 亚洲国产一区二区a毛片| 欧美一区日本一区韩国一区| 亚洲国产合集| 欧美一区二区三区精品| 亚洲区中文字幕| 久久久久久9| 一区二区三区国产在线观看| 久久这里有精品视频| 一区二区欧美国产| 免费看亚洲片| 午夜精品在线观看| 久久亚洲不卡| 亚洲欧美美女| 欧美另类videos死尸| 亚洲二区视频在线| 国产精品久久婷婷六月丁香| 亚洲日本精品国产第一区| 国产精品亚洲产品|