System.ArgumentOutOfRangeException: 索引和長度必須引用該字符串內(nèi)的位置。 參數(shù)名: length 在 System.String.Substring(Int32 startIndex, Int32 length) 在 zhuanliShow.Bind()
【技術(shù)實(shí)現(xiàn)步驟摘要】
本專利技術(shù)屬于數(shù)字電路,更為具體地講,涉及一種數(shù)據(jù)展開器的并行數(shù)據(jù)展開方法。
技術(shù)介紹
1、數(shù)據(jù)展開是一種將帶有數(shù)據(jù)和重復(fù)次數(shù)的數(shù)據(jù)項(xiàng)展開為按其設(shè)定重復(fù)次數(shù)重復(fù)數(shù)據(jù)的技術(shù)。由于數(shù)字電路可以進(jìn)行高效并行數(shù)據(jù)處理,因此使用數(shù)字電路進(jìn)行高速數(shù)據(jù)處理的應(yīng)用非常廣泛。在數(shù)字電路中進(jìn)行數(shù)據(jù)展開時(shí),常見的方法是使用游程解碼技術(shù),這通常通過狀態(tài)機(jī)來實(shí)現(xiàn)。
2、然而,現(xiàn)有的游程解碼技術(shù)存在一些限制。具體來說,基于狀態(tài)機(jī)或計(jì)數(shù)器的傳統(tǒng)游程解碼方法在每個(gè)時(shí)鐘周期內(nèi)僅能處理單個(gè)游程,這限制了數(shù)據(jù)展開的效率,難以滿足現(xiàn)代高速數(shù)據(jù)處理的需求。可以通過并行化來提高效率,但這會大幅增加硬件資源的使用,而硬件資源是有限的。
技術(shù)實(shí)現(xiàn)思路
1、本專利技術(shù)的目的在于克服現(xiàn)有技術(shù)的不足,提供一種數(shù)據(jù)展開器的并行數(shù)據(jù)展開方法,使并行的帶有數(shù)據(jù)和長度的數(shù)據(jù)項(xiàng)展開為固定數(shù)據(jù)個(gè)數(shù)的輸出,同時(shí)具有高靈活、高吞吐率以及低資源使用量等性能。
2、為實(shí)現(xiàn)上述專利技術(shù)目的,本專利技術(shù)一種數(shù)據(jù)展開器的并行數(shù)據(jù)展開方法,其特征在于,包括以下步驟:
3、(1)、設(shè)置數(shù)據(jù)展開器的參數(shù);
4、(2)、創(chuàng)建一個(gè)計(jì)數(shù)器,初始化計(jì)數(shù)器的計(jì)數(shù)值為0;
5、(3)、向數(shù)據(jù)展開器輸入多路并行數(shù)據(jù)項(xiàng)并緩存;
6、向數(shù)據(jù)展開器輸入多路并行數(shù)據(jù)項(xiàng),然后按照輸入的先后順序通過寄存器緩存成兩組,兩組緩存數(shù)據(jù)作為數(shù)據(jù)展開器一輪待展開的數(shù)據(jù)項(xiàng),每組中包含nin路數(shù)據(jù)項(xiàng),兩組緩存數(shù)據(jù)項(xiàng)的索引值記為0~2*
7、(4)、設(shè)置數(shù)據(jù)展開器的展開輪次i,初始化i=1,設(shè)置每輪展開次數(shù)j,初始化j=1;
8、(5)、分別計(jì)算數(shù)據(jù)展開器第i輪展開時(shí)寄存器中兩組緩存數(shù)據(jù)項(xiàng)的長度之和,分別記為l1st,i和l2nd,i:
9、
10、其中,li,1(k)、li,2(k)分別表示第i輪展開時(shí)寄存器中兩組緩存數(shù)據(jù)中第k路數(shù)據(jù)項(xiàng)的長度值;
11、(6)、計(jì)算數(shù)據(jù)展開器在第i輪第j次展開時(shí)的起點(diǎn)位置和終點(diǎn)位置;
12、(6.1)、設(shè)置數(shù)據(jù)展開器第一輪展開數(shù)據(jù)時(shí)的溢出長度loverflow=0,第一輪的第一次展開的起點(diǎn)位置pstart=0;
13、(6.2)、計(jì)算數(shù)據(jù)展開器在第i輪第j次展開的起點(diǎn)位置pstart,ij:
14、pstart,ij=loverflow,i+cntij*nout
15、其中,cntij為第i輪第j次展開計(jì)數(shù)器的計(jì)數(shù)值,nout為展開器的輸出位個(gè)數(shù),loverflow為展開起點(diǎn)位置pstart相比第一組數(shù)據(jù)項(xiàng)長度的溢出長度loverflow:
16、
17、其中,pstart,(i-1)last表示第i-1輪展開時(shí)最后一次展開的起點(diǎn)位置,l1st,i-1表示第i-1輪展開時(shí)寄存器中緩存的第一組數(shù)據(jù)項(xiàng)的長度之和;
18、(6.3)、計(jì)算數(shù)據(jù)展開器在第i輪第j次展開的終點(diǎn)位置pend,ij:
19、pend,ij=pstart,ij+nout
20、(7)、計(jì)算第i輪展開時(shí)計(jì)數(shù)器的計(jì)數(shù)目標(biāo)值;
21、(7.1)、計(jì)算第i輪展開時(shí)的保留長度lremain,i;
22、利用第一組緩存數(shù)據(jù)項(xiàng)的長度之和l1st,i減去溢出長度loverflow,i作為第一組緩存數(shù)據(jù)項(xiàng)剩余未被展開的長度,記為保留長度lremain,i;
23、lremain,i=l1st,i-loverflow,i
24、(7.2)、將保留長度lremain,i除以展開器的輸出位個(gè)數(shù)nout,取商并求余數(shù),然后將商作為lremain,i的高位lremain_high,i,將余數(shù)作為lremain,i的低位lremain_low,i;
25、
26、(7.3)、計(jì)算第i輪展開時(shí)計(jì)數(shù)器的計(jì)數(shù)目標(biāo)值cnttarget,i;
27、
28、(8)、判斷計(jì)數(shù)器的計(jì)數(shù)值cnt是否達(dá)到計(jì)數(shù)目標(biāo)值cnttarget,如果cnt<cnttarget,則進(jìn)入步驟(9);否則,進(jìn)入步驟(10);
29、(9)、數(shù)據(jù)展開器進(jìn)行第i輪數(shù)據(jù)展開;
30、(9.1)、讀取兩組緩存數(shù)據(jù)然后拼接成一組數(shù)據(jù),記為li(k),k=0,1,2,…,2*nin;
31、(9.2)、計(jì)算li(k)中每路數(shù)據(jù)項(xiàng)偏移值;
32、
33、其中,|li(k)|表示數(shù)據(jù)li(k)中第k路數(shù)據(jù)項(xiàng)的長度,offseti(k)表示數(shù)據(jù)li(k)中第k路數(shù)據(jù)項(xiàng)的偏移值;
34、(9.3)、計(jì)算第i輪第j次展開時(shí)終點(diǎn)位置對應(yīng)的索引值iend,ij;
35、iend,ij=min{k|offseti(k+1)>pend,ij}
36、(9.4)、計(jì)算第i輪第j次展開時(shí)篩選數(shù)據(jù)項(xiàng)的起點(diǎn)位置、終點(diǎn)位置對應(yīng)的索引值;
37、
38、iselected_end,ij=iselected_start,ij+nselect-1
39、其中,iselected_start,ij、iselected_end,ij分別表示篩選數(shù)據(jù)項(xiàng)的起點(diǎn)位置、終點(diǎn)位置對應(yīng)的索引值,nselect為篩選數(shù)據(jù)項(xiàng)個(gè)數(shù);
40、(9.5)、將數(shù)據(jù)li(k)中,按照索引值iselected_start,ij和iselected_end,ij,從2nin個(gè)數(shù)據(jù)項(xiàng)中篩選出對應(yīng)索引位置的所有數(shù)據(jù)項(xiàng)作為第i輪第j次展開時(shí)的數(shù)據(jù)項(xiàng);
41、(9.6)、計(jì)算各篩選數(shù)據(jù)項(xiàng)的偏移值offsetselected,ij(p);
42、
43、其中,p=1,2,…,nselect;
44、(9.7)、計(jì)算各篩選數(shù)據(jù)項(xiàng)的使能信號enableij(p);
45、
46、其中,true代表使能數(shù)據(jù)項(xiàng),false代表不使能數(shù)據(jù)項(xiàng);
47、(9.8)、根據(jù)各篩選數(shù)據(jù)項(xiàng)的偏移值和使能信號,構(gòu)建一個(gè)nselect行nout列的掩碼矩陣m;
48、其中,掩碼矩陣m的每個(gè)元素為0或1,當(dāng)掩碼矩陣m中第p行第q列元素mpq滿足:enableij(p)為true且offsetselected,ij(p)≤q<o(jì)ffsetselected,ij(p+1)時(shí),mpq取值為1,否則取值為0;
49、(9.9)、取出掩碼矩陣m每列中元素為1對應(yīng)數(shù)據(jù),然后按序拼接得到長度為nout的數(shù)據(jù)項(xiàng),并作為數(shù)據(jù)展開器在第i輪第j次展開后的輸出數(shù)據(jù);
50、(9.10)、待第j次展開完成后,將計(jì)數(shù)器的計(jì)數(shù)值加1,然后令j=j(luò)+1,并返回步驟(6.2)進(jìn)行下一輪的數(shù)據(jù)展開;
51、(10)、將計(jì)數(shù)器的計(jì)數(shù)值清零;令i=i+1,然后控制數(shù)據(jù)展開器將寄存器內(nèi)第二組緩存數(shù)據(jù)覆蓋第一組緩存數(shù)據(jù),再按順繼續(xù)接收輸入的多路并行數(shù)據(jù)項(xiàng)并緩本文檔來自技高網(wǎng)...
【技術(shù)保護(hù)點(diǎn)】
1.一種數(shù)據(jù)展開器的并行數(shù)據(jù)展開方法,其特征在于,包括以下步驟:
【技術(shù)特征摘要】
1.一種數(shù)據(jù)展開器的并行數(shù)據(jù)展開...
【專利技術(shù)屬性】
技術(shù)研發(fā)人員:肖寅東,劉科,付在明,涂思陽,
申請(專利權(quán))人:電子科技大學(xué)深圳高等研究院,
類型:發(fā)明
國別省市:
還沒有人留言評論。發(fā)表了對其他瀏覽者有用的留言會獲得科技券。