本發(fā)明涉及通信技術(shù)領(lǐng)域,具體涉及一種譯碼方法中校驗節(jié)點的更新方法及譯碼器。
背景技術(shù):
信道編碼是保證通信系統(tǒng)和存儲系統(tǒng)可靠工作的關(guān)鍵技術(shù)。二進制低密度奇偶校驗(LDPC)碼是一類性能可逼近香農(nóng)極限的線性糾錯碼。在過去的十余年里,二進制LDPC碼得到快速的發(fā)展并廣泛應(yīng)用于通信和數(shù)據(jù)傳輸系統(tǒng)中。多進制LDPC碼可以表現(xiàn)出比二進制LDPC碼更好的糾錯能力,更低的錯誤平層并高度適用于高階調(diào)制。在無線通信、深空通信和數(shù)字存儲系統(tǒng)中,多進制LDPC碼都表現(xiàn)出了取代二進制LDPC碼的巨大潛力。然而,多進制LDPC碼的基于置信度傳播(BP)譯碼算法的巨大復(fù)雜度一直阻礙其實際的應(yīng)用。
多進制和積譯碼算法(QSPA)是最優(yōu)的BP譯碼算法,但是其譯碼復(fù)雜度也最大。對于有限域GF(q)(q=2r)下的多進制LDPC碼,QSPA算法在譯碼過程中,對每個碼字符號需要存儲和計算該符號全部q個域元素的置信度。校驗節(jié)點的更新運算是基于dc個長度為q的置信度向量之間的卷積運算。每個校驗節(jié)點運算需要dcq2數(shù)量級的計算量和計算復(fù)雜度。
因此,設(shè)計高效且譯碼復(fù)雜度低,設(shè)計結(jié)構(gòu)簡單的譯碼算法來推動多進制LDPC碼在通信和存儲系統(tǒng)中的廣泛應(yīng)用是亟待解決的問題。
技術(shù)實現(xiàn)要素:
為解決上述技術(shù)問題,本發(fā)明提供一種譯碼方法中校驗節(jié)點的更新方法及譯碼器,實現(xiàn)有效地匹配計算效率,提高譯碼效率,降低在校驗節(jié)點的計算復(fù)雜度。
為實現(xiàn)上述目的,本發(fā)明提供以下技術(shù)方案:
一方面,本發(fā)明提供了一種譯碼方法中校驗節(jié)點的更新方法,包括:
用網(wǎng)格圖表示輸入校驗節(jié)點的置信度向量;
將網(wǎng)格圖中的節(jié)點劃分為集合;
集合中的節(jié)點連接組成固定路徑;
通過固定路徑輸出置信度向量。
進一步的,所述將網(wǎng)格圖中的節(jié)點劃分為集合的步驟,之前還包括:
按照網(wǎng)格圖中每列第x個節(jié)點置信度值遞增或遞減的順序?qū)W(wǎng)格圖中的每列進行排序。
進一步的,按照網(wǎng)格圖中每列第二個節(jié)點置信度值遞增或遞減的順序?qū)W(wǎng)格圖中的每列進行排序。
進一步的,所述將網(wǎng)格圖中的節(jié)點劃分為集合的步驟,具體包括:
在網(wǎng)格圖中選取t行以及t行之前的所有節(jié)點組成集合1;
集合2的范圍為:在網(wǎng)格圖中t行之后,d行以及d行之前的,所述網(wǎng)格圖中第r行置信度值的最小值和次小值所在列的節(jié)點,其中r>t;
集合3的范圍為:在網(wǎng)格圖中d行之后,e行以及e行之前的,所述網(wǎng)格圖中第s行置信度值的最小值和次小值所在列的節(jié)點,其中s>d;
集合N的范圍為:在網(wǎng)格圖中f行之后,所述網(wǎng)格圖中第v行置信度值的最小值和次小值所在列的節(jié)點,其中v>f。
進一步的,所述通過固定路徑輸出置信度向量的步驟,之前還包括:
將固定路徑存儲至所述網(wǎng)格圖中的額外列中,通過額外列中的固定路徑輸出置信度向量。
進一步的,其特征在于,將網(wǎng)格圖中第一行節(jié)點組成的固定路徑、含有一個偏離網(wǎng)格圖中第一行節(jié)點組成的固定路徑的節(jié)點所組成的固定路徑以及含有兩個偏離網(wǎng)格圖中第一行節(jié)點組成的固定路徑的節(jié)點所組成的固定路徑存儲至網(wǎng)格圖中的額外列中。
進一步的,所述通過額外列中的固定路徑輸出置信度向量的步驟,之后還包括:
將輸出置信度向量的順序調(diào)整為輸入校驗節(jié)點時的置信度向量的順序。
另一方面,本發(fā)明提供了一種譯碼器,包括:
接收單元、初始化單元、變量節(jié)點更新單元、端口預(yù)調(diào)單元以及校驗節(jié)點更新單元;
所述接收單元,用于向初始化單元輸出符號信息向量;
所述初始化單元,用于將符號信息向量初始化并至二分圖中,并將符號信息向量傳遞給校驗節(jié)點更新單元;
所述校驗節(jié)點更新單元,用于對輸入校驗節(jié)點的符號信息向量進行更新運算并傳遞給變量節(jié)點更新單元;
所述變量節(jié)點更新單元,用于接收校驗節(jié)點更新單元輸出的符號信息向量并進行變量節(jié)點更新計算,將計算結(jié)果傳遞給校驗節(jié)點更新單元;
所述端口預(yù)調(diào)單元,用于根據(jù)輸入校驗節(jié)點更新單元的符號信息向量的順序調(diào)整校驗節(jié)點更新單元輸出的符號信息向量的順序。
進一步的,所述校驗節(jié)點更新單元包括:
校驗寄存器,用于存儲輸入的符號信息向量;
校驗比較器,用于讀取校驗寄存器中輸入的預(yù)設(shè)符號信息向量,選擇符號信息向量中最可信和次可信的元素;
校驗選擇器,用于選擇集合中的元素參與更新運算;
存儲器,用于存儲額外列中的校驗值。
進一步的,所述端口預(yù)調(diào)單元包括:
端口預(yù)調(diào)緩存器,用于存儲輸入校驗節(jié)點更新單元的符號信息向量;
端口預(yù)調(diào)比較器,用于讀取校驗寄存器中輸入的預(yù)設(shè)符號信息向量,選擇符號信息向量中最可信和次可信的元素;
端口預(yù)調(diào)選擇器,用于對緩存器中存儲的符號信息向量進行排序并輸出至校驗節(jié)點更新單元。
由上述技術(shù)方案可知,本發(fā)明所述的一種譯碼方法中校驗節(jié)點的更新方法及譯碼器,實現(xiàn)了降低了譯碼算法的復(fù)雜度,降低了在校驗節(jié)點的計算復(fù)雜度。同時選取固定的偏差路徑、采用判決置信度可以在很小的譯碼性能損失下,提高譯碼吞吐量,減少硬件資源的消耗。
附圖說明
為了更清楚地說明本發(fā)明實施例或現(xiàn)有技術(shù)中的技術(shù)方案,下面將對實施例或現(xiàn)有技術(shù)描述中所需要使用的附圖作簡單地介紹,顯而易見地,下面描述中的附圖是本發(fā)明的一些實施例,對于本領(lǐng)域普通技術(shù)人員來講,在不付出創(chuàng)造性勞動的前提下,還可以根據(jù)這些附圖獲得其他的附圖。
圖1是本發(fā)明實施例一提供的一種譯碼方法中校驗節(jié)點的更新方法的流程示意圖;
圖2是本發(fā)明實施例提供的劃分集合數(shù)為4的網(wǎng)格圖;
圖3是本發(fā)明實施例二提供的一種譯碼方法中校驗節(jié)點的更新方法的流程示意圖;
圖4是本發(fā)明實施例提供的校驗矩陣示意圖;
圖5是本發(fā)明實施例提供的Tanner圖;
圖6是本發(fā)明實施例提供的劃分集合數(shù)為2的網(wǎng)格圖;
圖7是本發(fā)明實施例三提供的一種譯碼器的結(jié)構(gòu)示意圖;
圖8是本發(fā)明實施例提供的校驗節(jié)點更新單元的結(jié)構(gòu)示意圖;
圖9是本發(fā)明實施例提供的端口預(yù)調(diào)單元的結(jié)構(gòu)示意圖;
圖10是本發(fā)明實施例提供的一種固定路徑譯碼器中寄存器與比較器的連接電路示意圖。
具體實施方式
為使本發(fā)明實施例的目的、技術(shù)方案和優(yōu)點更加清楚,下面將結(jié)合本發(fā)明實施例中的附圖,對本發(fā)明實施例中的技術(shù)方案進行清楚、完整的描述,顯然,所描述的實施例是本發(fā)明一部分實施例,而不是全部的實施例?;诒景l(fā)明中的實施例,本領(lǐng)域普通技術(shù)人員在沒有作出創(chuàng)造性勞動前提下所獲得的所有其他實施例,都屬于本發(fā)明保護的范圍。
信道編碼是保證通信系統(tǒng)和存儲系統(tǒng)可靠工作的關(guān)鍵技術(shù)。二進制LDPC碼得到快速的發(fā)展并廣泛應(yīng)用于通信和數(shù)據(jù)傳輸系統(tǒng)中。多進制LDPC碼可以表現(xiàn)出比二進制LDPC碼更好的糾錯能力,更低的錯誤平層并高度適用于高階調(diào)制。然而,多進制LDPC碼的基于置信度傳播(BP)譯碼算法的巨大復(fù)雜度一直阻礙其實際的應(yīng)用。因此,設(shè)計高效且譯碼復(fù)雜度低,設(shè)計結(jié)構(gòu)簡單的譯碼算法來推動多進制LDPC碼在通信和存儲系統(tǒng)中的廣泛應(yīng)用是亟待解決的問題。為解決上述技術(shù)問題,本發(fā)明實施例提供一種譯碼方法中校驗節(jié)點的更新方法及譯碼器。
本發(fā)明實施例一提供一種譯碼方法中校驗節(jié)點的更新方法,參見圖1,本發(fā)明的更新方法具體包括:
S101:用網(wǎng)格圖表示輸入校驗節(jié)點的置信度向量;
在本步驟中,首先根據(jù)信道接收來的比特信息序列計算出每個碼字符號的比特或者符號置信度向量,并用每個碼字符號的置信度向量初始化變量節(jié)點傳遞給校驗節(jié)點的邊信息。然后進行碼字判決,若是合法的碼字或者達到最大迭代次數(shù),則終止譯碼,輸出譯碼結(jié)果,否則將置信度向量輸入校驗節(jié)點進行更新運算。
采用Rι,c和Rc,ι(0≤ι<ρ)分別表示一個校驗節(jié)點的長度為nm輸入置信度向量和輸出置信度向量。Rsι,c和Rsc,ι分別存儲Rι,c和Rc,ι中每個置信度對應(yīng)的域元素。用一個網(wǎng)格圖表示校驗節(jié)點的每個輸入向量,網(wǎng)格圖中的每一列對應(yīng)于一個輸入置信度向量Rι,c和其對應(yīng)的域元素向量Rsι,c。
S102:將網(wǎng)格圖中的節(jié)點劃分為集合;
在本步驟中,將網(wǎng)格圖中的所有列劃分為N個集合。集合1(S0)包含前t行的所有節(jié)點,t<<nm。很明顯,集合1包含了網(wǎng)格圖中絕大多數(shù)的最可靠的節(jié)點。集合2(S1)包含第e1行中最小值和次小值所對應(yīng)列的第t+1~d1個節(jié)點(t<e1<d1),集合3(S2)包含第e2行中最小值和次小值所對應(yīng)列的第d1+1~d2個節(jié)點(d1<e2<d2),依次類推,集合N(SN-1)包含第eN-1行中最小值和次小值所對應(yīng)列的第dN-2+1~nm個節(jié)點(dN-2<eN-1<nm)。參見圖2,是一個行重為4的網(wǎng)格圖,t的取值為3,N=4。
S103:集合中的節(jié)點連接組成固定路徑;
在本步驟中,網(wǎng)格圖中第一行節(jié)點的組合即為最可靠路徑,即ML路徑。在網(wǎng)格圖中引進一個額外列ΔRs存儲與最可靠路徑相比最多只有兩個位置偏差(偏差節(jié)點)的固定路徑的校驗值,這些偏差位置只能是N個集合中的元素,ΔR存儲ΔRs中每個校驗值的置信度。以t的取值為3,N=4為例:ΔRs和ΔR的更新如下:
其中e1'和e1”分別表示網(wǎng)格圖中第e1行中最小值和次小值所對應(yīng)的輸入向量的序號,e2'和e2”分別表示網(wǎng)格圖中第e2行中最小值和次小值所對應(yīng)的輸入向量的序號,e3'和e3”分別表示網(wǎng)格圖中第e3行中最小值和次小值所對應(yīng)的輸入向量的序號。
S104:通過固定路徑輸出置信度向量。
在本步驟中,將固定路徑存儲至所述網(wǎng)格圖中的額外列中,通過額外列中的固定路徑輸出置信度向量。將網(wǎng)格圖中第一行節(jié)點組成的固定路徑、含有一個偏離網(wǎng)格圖中第一行節(jié)點組成的固定路徑的節(jié)點所組成的固定路徑以及含有兩個偏離網(wǎng)格圖中第一行節(jié)點組成的固定路徑的節(jié)點所組成的固定路徑存儲至網(wǎng)格圖中的額外列中。
所述校驗節(jié)點輸出置信度向量的固定路徑為:
1、固定路徑存儲的置信度值小于集合N中第k行置信度值的最小值或次小值;其中,所述固定路徑存儲的置信度值為該固定路徑中所有節(jié)點的置信度值的和;即:
設(shè)置標記向量以判斷固定路徑的可靠性。以t的取值為3,N=4為例:對于0≤k<4ρ+2d3-8,兩個標記向量T和分別標志ΔR中每個置信度是否小于和
2、排除含有該輸出的置信度向量中的偏差節(jié)點組成的固定路徑;即:
通過在ΔRs和ΔR中去掉自己所在列中的節(jié)點,若某固定路徑的偏差節(jié)點包含該輸出向量對應(yīng)的輸入列中的節(jié)點,則舍棄該固定路徑。對于偏差節(jié)點不位于集合N中次小值所在列固定路徑,若T向量中對應(yīng)的值為1,則舍棄該路徑;對于偏差節(jié)點位于集合N中次小值所在列固定路徑,若向量中對應(yīng)的值為1,則舍棄該路徑。
從上述描述可知,本發(fā)明所提供的一種譯碼方法中校驗節(jié)點的更新方法,減少了排序運算,并降低了在校驗節(jié)點的計算復(fù)雜度。同時可以并行地更新置信度信息,有效地匹配計算效率,提高譯碼效率。
本發(fā)明實施例二提供一種譯碼方法中校驗節(jié)點的更新方法,參見圖3,上述步驟S101之前,還包括如下步驟:
S100:按照網(wǎng)格圖中每列第x個節(jié)點置信度值遞增或遞減的順序?qū)W(wǎng)格圖中的每列進行排序。
上述步驟S104之后,還包括如下步驟:
S105:將輸出置信度向量的順序調(diào)整為輸入校驗節(jié)點時的置信度向量的順序。
在本步驟中,將校驗節(jié)點輸出的置信度向量輸入值變量節(jié)點,變量節(jié)點接收進行更新運算的置信度向量后,將置信度向量傳遞給校驗節(jié)點;譯碼器對變量節(jié)點輸出的碼字進行判決;直至譯碼器譯出合法的碼字或者達到最大迭代次數(shù),終止譯碼,輸出譯碼結(jié)果。
本發(fā)明提出的校驗節(jié)點更新方法是基于多進制LDPC碼的校驗矩陣Tanner圖的信息傳輸?shù)g碼算法。Tanner圖結(jié)構(gòu)由多進制LDPC碼的校驗矩陣H決定,參見圖4和圖5,為一個LDPC碼的校驗矩陣和它對應(yīng)的Tanner圖。Tanner圖由變量節(jié)點和校驗節(jié)點以及連接這兩種節(jié)點的邊構(gòu)成。變量節(jié)點(VN)和校驗節(jié)點(CN)分別代表校驗矩陣的每一列和每一行,如果在校驗矩陣H中元素第i行第j列的元素是非零元素,那么就表示Tanner圖中第i個CN與第j個VN相連。多進制LDPC碼的基于Tanner圖的信息傳輸?shù)g碼算法分為譯碼初始化和譯碼迭代兩部分,迭代過程包括如下步驟:譯碼結(jié)果硬判決、校驗節(jié)點更新、變量節(jié)點更新,直到譯碼成功或達到最大迭代次數(shù)時結(jié)束譯碼。
本發(fā)明的校驗節(jié)點更新方法可以適用于任意概率譯碼器,本發(fā)明以多進制LDPC碼為例對本發(fā)明的實施方式展開詳細描述。本發(fā)明的譯碼過程中所有可靠性信息更新是在符號置信度形式下進行的,以下結(jié)合具體實例分別進行描述。
假設(shè)多進制LDPC碼由在有限域GF(q)(q=2r)下大小為m×n,列重和行重分別為γ,ρ的奇偶校驗矩陣H的零空間定義。用h0,h1,...,hm-1表示矩陣H的每一行,其中hi=(hi,0,hi,1,...,hi,n-1),0≤i<m。令c=(c0,c1,…,cn-1)是碼字空間中的一個碼,則c=(c0,c1,…,cn-1)是一個長度為n的GF(2r)下的向量,該碼字向量可以用一個長度為nr的二進制向量等效表示。用cj(0≤j≤n-1)表示碼字的第j個符號,用cj=(cj,0,cj,1,…,cj,r-1)表示第j個符號的二進制表示,cj,t表示第j個符號的第t位二進制位,值為0或1。當通信系統(tǒng)使用BPSK調(diào)制方式進行傳輸時,對碼字二進制表示的每一比特做如下映射:0→+1V,1→-1V。經(jīng)過二進制輸入加性高斯白噪聲(BI-AWGN)信道后,系統(tǒng)接收到的碼字信息為y=(y0,y1,...,yn-1),其中yj=(yj,0,yj,1,...,yj,r-1)為第j個碼字符號r個比特的對數(shù)似然比,0≤j≤n-1,0≤t≤r-1。z=(z0,z1,…,zn-1)為硬判決接收向量,其中zj=(zj,0,zj,1,...,zj,r-1)為第j個碼字符號r個硬判決比特。
第j個碼字符號的符號置信度向量可以通過一個長度q的對數(shù)似然比向量來計算:
其中,Pr(cj=al|yj)是第j個碼字符號cj取域元素al∈GF(q)的后驗概率,因此,Lj[0]=0,且Lj[l]越小,cj=al越可靠。
對每個碼字的q-符號置信度向量只截取LLR最小的前nm個域元素及其對應(yīng)的LLR值,即得到截取的信道輸出的碼字符號置信度向量:
Y=[Y0,Y1,...,Yn-1]
其中對應(yīng)的域元素向量為Yj,t=Lj(SYj,t),0≤j<n,0≤t<nm。定義變量節(jié)點節(jié)點j傳遞給CN節(jié)點i的邊信息為:及對應(yīng)的域元素向量:使用信道輸出的碼字符號信息分別初始化Uj→i和SUj→i:
Uj→i,l=Y(jié)j,l
SUj→i,l=SYj→i,l
其中0≤j<n,0≤j<m,0≤l<nm。
以一個校驗節(jié)點的更新為例,校驗節(jié)點更新運算規(guī)則如下:
Step1:Rι,c和Rc,ι(0≤ι<ρ)分別表示一個CN的長度為nm輸入置信度向量和輸出置信度向量。Rsι,c和Rsc,ι分別存儲Rι,c和Rc,ι中每個置信度對應(yīng)的域元素。用一個網(wǎng)格圖表示CN的每個輸入向量,網(wǎng)格圖中的每一列對應(yīng)于一個輸入置信度向量Rι,c和其對應(yīng)的域元素向量Rsι,c。將網(wǎng)格圖中的每一列按照其第二個元素置信度值的從小到大往右排序。排序后網(wǎng)格圖中第二行元素的大小關(guān)系如下:R0,c[1]≤R1,c[1]≤…≤Rρ-1,c[1]。將網(wǎng)格圖中的所有列劃分為兩個集合。集合1(S0)包含前t行的所有節(jié)點,t<<nm。很明顯,集合1包含了網(wǎng)格圖中絕大多數(shù)的最可靠的節(jié)點。集合2(S1)只包含第nm/2行中最小值和次小值所對應(yīng)列的節(jié)點(這兩列各自的前t個節(jié)點除外)。參見圖6所示,是一個行重為4的網(wǎng)格圖,t的取值為3。
Step2:計算固定偏差路徑。網(wǎng)格圖中第一行元素的組合即為最可靠路徑,即ML路徑。在網(wǎng)格圖中引進一個額外列ΔRs存儲最可靠路徑最多只有兩個位置偏差的固定路徑的校驗值,這些偏差位置只能是集合1或者集合2中的元素,如圖6所示。ΔR存儲ΔRs中每個校驗值的置信度。ΔRs和ΔR的更新如下:
其中i'和i'‘’分別表示網(wǎng)格圖中第行中最小值和次小值所對應(yīng)的輸入向量的序號。
Step3:設(shè)置標記向量以判斷固定路徑的可靠性。對于0≤k<4ρ+2nm-8,兩個標記向量T和分別標志ΔR中每個置信度是否小于和
和
Step4:并行地更新CN的輸出向量。通過在ΔRs和ΔR中去掉自己所在列中的元素,CN的ρ個輸出向量Rsc,ι和Rc,ι的更新如下:
和
Rc,ι[d]=ΔR[k],
其中0≤ι<ρ,0≤d<nm,k的取值范圍由不同的情況決定。對于ι=0,如果i′≠0,k的取值范圍是
{k:T[k]=1}∩{k=0or1<k≤ρor2ρ≤k<3ρ-2ork>3ρ-2},
否則,
對于1≤ι<ρ,如果ι≠i′,k的取值范圍是
{k:T[k]=1}∩{0≤k≤2ρ-1ork≥3ρ-2}∩{k≠ι+1andk≠ρ+ιandk≠3ρ+ι-2},
否則,
CN更新計算完成后再將對應(yīng)輸出向量的順序調(diào)整回原順序,并將置信度向量傳遞給相鄰的VN,進行VN更新計算。
從上述描述可知,本發(fā)明提供一種譯碼方法中校驗節(jié)點的更新方法,根據(jù)網(wǎng)格圖上不同偏差路徑的置信度差異的不同,將所述網(wǎng)格圖節(jié)點劃分成兩個集合,以集合為單位選取固定偏差路徑進行譯碼過程中的計算。
本發(fā)明實施例三提供一種譯碼器,參見圖7,本發(fā)明的譯碼器具體包括:
接收單元、初始化單元、變量節(jié)點更新單元、端口預(yù)調(diào)單元以及校驗節(jié)點更新單元;
所述接收單元,用于向初始化單元輸出符號信息向量;
所述初始化單元,用于將符號信息向量初始化并至二分圖中,并將符號信息向量傳遞給校驗節(jié)點更新單元;
所述校驗節(jié)點更新單元,用于對輸入校驗節(jié)點的符號信息向量進行更新運算并傳遞給變量節(jié)點更新單元;
所述變量節(jié)點更新單元,用于接收校驗節(jié)點更新單元輸出的符號信息向量并進行變量節(jié)點更新計算,將計算結(jié)果傳遞給校驗節(jié)點更新單元;
所述端口預(yù)調(diào)單元,用于根據(jù)輸入校驗節(jié)點更新單元的符號信息向量的順序調(diào)整校驗節(jié)點更新單元輸出的符號信息向量的順序。
在具體實施時,校驗節(jié)點更新單元首先對所有輸入信息向量選取固定路徑構(gòu)造出一個輔助信息向量,輔助信息向量中每個元素對應(yīng)一條路徑,輸出信息向量中元素的計算為輔助信息向量中的元素減去各端口對應(yīng)路徑上的輸入元素。變量節(jié)點更新單元將計算結(jié)果傳遞給校驗節(jié)點再次進行碼字判決,如此反復(fù)迭代直到譯出正確碼字或直到達到最大迭代次數(shù)為止。
所述校驗節(jié)點更新單元包括:
校驗寄存器,用于存儲輸入的符號信息向量;
校驗比較器,用于讀取校驗寄存器中輸入的預(yù)設(shè)符號信息向量,選擇符號信息向量中最可信和次可信的元素;
校驗選擇器,用于選擇集合中的元素參與更新運算;
存儲器,用于存儲額外列中的校驗值。
在具體實施時,參見圖8,校驗節(jié)點更新單元(CNU)的硬件電路結(jié)構(gòu)圖,四個端口的輸入信息向量首先分別緩存至四組寄存器中,并按順序計算額外信息向量中各元素。當預(yù)設(shè)偏差元素輸入時,比較器讀入這四個數(shù)據(jù),找到最可信及次可信的元素和它們對應(yīng)的端口,控制各端口的二選一數(shù)據(jù)選擇器選擇集合1中的元素或集合2中的元素參與運算。同時最可信及次可信元素還控制輸出緩存的寫使能,根據(jù)與最可信及次可信元素比較結(jié)果判斷輸出路徑是否保留,若輸出路徑的置信度小于最可信及次可信元素,則保留,否則舍棄。
所述端口預(yù)調(diào)單元包括:
端口預(yù)調(diào)緩存器,用于存儲輸入校驗節(jié)點更新單元的符號信息向量;
端口預(yù)調(diào)比較器,用于讀取校驗寄存器中輸入的預(yù)設(shè)符號信息向量,選擇符號信息向量中最可信和次可信的元素;
端口預(yù)調(diào)選擇器,用于對緩存器中存儲的符號信息向量進行排序并輸出至校驗節(jié)點更新單元。
在具體實施時,在信息向量輸入至校驗節(jié)點更新單元(CNU)進行計算前,需要根據(jù)每個信息向量第二個元素的大小將端口順序進行調(diào)整,CNU計算完成后再將端口調(diào)整回原順序。因此本發(fā)明設(shè)計了端口預(yù)調(diào)單元,參見圖9,首先對輸入信息向量進行緩存,比較器根據(jù)偏差為1的元素找到擁有最可信元素和次可信元素的兩個端口,左側(cè)兩個數(shù)據(jù)選擇器為dc選一多路選擇器,與所有緩存器的輸出相連,分別選通擁有最可信元素的信息向量和擁有次可信元素的信息向量,其余數(shù)據(jù)選擇器為三選一多路選擇器,與原端口0、原端口1及原對應(yīng)端口相連,原端口擁有最可信元素的選擇器選通原端口0的信息向量,原端口擁有次可信元素的選擇器選通原端口1的信息向量,其余選擇器選通原端口數(shù)據(jù)。隨著行重的增加,只需增加若干緩存器和占用資源較少的三選一多路選擇器,不會造成硬件資源占用的大幅增加。
在CNU中,比較結(jié)果只在選擇網(wǎng)格圖集合2中的元素及輸出時對計算過程進行了控制,距預(yù)設(shè)偏差元素輸入有一定的時間間隔;而對于端口預(yù)調(diào)單元,由于當一個校驗節(jié)點的輸入數(shù)據(jù)全部輸入CNU模塊后,端口預(yù)調(diào)電路可以立即讀入下一個校驗節(jié)點的輸入數(shù)據(jù)并對端口順序進行調(diào)整,比較器的時延只對每次迭代第一個校驗節(jié)點的計算時延有影響。采用了圖10所示的并行輸入串行比較的方式,比較器接收到開始信號后對所有輸入數(shù)據(jù)進行緩存,首先比較前兩個端口的數(shù)據(jù)大小,存為最小值和次小值,接下來將第三個端口的數(shù)據(jù)與當前最小值和次小值進行比較,并根據(jù)結(jié)果更新最小值和次小值,同時將第三端口之后其他端口的數(shù)據(jù)全部移至前一端口數(shù)據(jù)寄存器,繼續(xù)將第三端口寄存器的數(shù)據(jù)與當前最小值和次小值進行比較,直至比較完所有端口數(shù)據(jù)。從輸入到輸出比較結(jié)果一共需要ρ個時鐘周期,當行重增加時,只需相應(yīng)增加端口緩存寄存器,而比較邏輯電路不需要增加,可以在滿足時序要求的情況下減少硬件資源的占用。
通過上述描述可知,通過本發(fā)明提供的固定路徑譯碼器降低了譯碼復(fù)雜度,尤其降低了在校驗節(jié)點的計算復(fù)雜度。同時本發(fā)明選取固定的偏差路徑、采用合適的判決置信度可以在很小的譯碼性能損失,提高譯碼吞吐量,減少硬件資源的消耗。
以上實施例僅用于說明本發(fā)明的技術(shù)方案,而非對其限制;盡管參照前述實施例對本發(fā)明進行了詳細的說明,本領(lǐng)域的普通技術(shù)人員應(yīng)當理解:其依然可以對前述各實施例所記載的技術(shù)方案進行修改,或者對其中部分技術(shù)特征進行等同替換;而這些修改或替換,并不使相應(yīng)技術(shù)方案的本質(zhì)脫離本發(fā)明各實施例技術(shù)方案的精神和范圍。