欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

一種資源配置靈活的吉比特ldpc譯碼方法

文檔序號:7545285閱讀:294來源:國知局
一種資源配置靈活的吉比特ldpc譯碼方法
【專利摘要】一種資源配置靈活的吉比特LDPC譯碼方法,通過將N個LDPC碼字的初始化軟信息拼裝為一個多路的譯碼信息,并同時進行多路CNU、VNU計算。N個LDPC碼字譯碼過程中的中間信息存儲同樣采用拼裝的結(jié)構(gòu)實現(xiàn),既實現(xiàn)了資源的有效利用,同時可以將譯碼的速率按需要提升到吉比特以上。本發(fā)明適用于對譯碼速率有不同要求的場合,可靈活實現(xiàn)資源占用和譯碼速率的折衷。
【專利說明】一種資源配置靈活的吉比特LDPC譯碼方法
【技術(shù)領(lǐng)域】
[0001]本發(fā)明涉及數(shù)字信息傳輸【技術(shù)領(lǐng)域】,特別涉及一種資源配置靈活的吉比特LDPC譯碼方法。
【背景技術(shù)】
[0002]低密度奇偶校驗(LDPC, Low Density Parity Check)碼是一種線性分組碼,可以用生成矩陣G和校驗矩陣H來表示,并且它的奇偶校驗矩陣H中非零元素的個數(shù)遠遠小于零元素的個數(shù)。
[0003]LDPC碼的譯碼算法主要是基于二分圖的消息傳遞(Message Passing)算法,具體包括硬判決譯碼算法、概率譯碼算法、和積算法、最小和算法、比特翻轉(zhuǎn)和大數(shù)邏輯等LDPC譯碼方法。其中,和積(Sum Product)算法又稱置信傳播(BP,Belief Propagation)算法,實質(zhì)上是二進制概率譯碼算法的對數(shù)域運算。譯碼器的輸入為接收序列的對數(shù)似然比,在對數(shù)空間下,通過利用變量節(jié)點和校驗節(jié)點的約束關(guān)系進行迭代譯碼。此時變量節(jié)點的約束關(guān)系表現(xiàn)為“和”的形式,即各變量節(jié)點的輸出是各個輸入對數(shù)似然比的和;而校驗節(jié)點的約束關(guān)系表現(xiàn)為“積”的形式,即各校驗節(jié)點的輸出是各個輸入對數(shù)似然值某種函數(shù)的乘積。由于兩個校驗節(jié)點的計算特性,因此該算法稱之為“和積”算法。
[0004]在LDPC碼的實現(xiàn)中,譯碼算法和譯碼器設(shè)計是決定碼字性能和應(yīng)用前景的重要因素之一。目前,BP算法作為LDPC碼的一種經(jīng)典譯碼算法被人們廣泛使用。在其于BP算法的譯碼器具體實現(xiàn)方法上,按照速率的高低一般可分為全并行方式、串行方式和半并行方式。對于一個行列大小為MXN的LDPC校驗矩陣,全并行方式每次迭代時,同時對其M行/N列進行更新,具有譯碼速率快的優(yōu)點,但實現(xiàn)復(fù)雜度和資源占用率很高,當(dāng)M/N較大時,基本不可實現(xiàn)。串行方式實現(xiàn)的譯碼器具有結(jié)構(gòu)簡單、資源占用少的特點,不足之處在于譯碼速率較低,無法滿足吉比特譯碼需求。
[0005]半并行方式的譯碼是目前應(yīng)用最多的吉比特譯碼實現(xiàn)方法,實現(xiàn)時主要包括五個主要部分:信道信息存儲器、旋轉(zhuǎn)網(wǎng)絡(luò)、行運算單元、列運算單元及外信息存儲器。首先譯碼器接收經(jīng)過量化的對數(shù)似然比信息,寫入信道存儲器。接收完一幀信息后,開始從信道信息存儲器中讀出信道信息,通過旋轉(zhuǎn)網(wǎng)絡(luò)改變讀出的信道信息的位置使在LDPC碼校驗矩陣中同一行的信道信息送入同一個行列運算單元。同時將外信息存儲器中存儲的外信息也讀出并送到行列運算單元和信道信息一起進行行列運算。運算的結(jié)果寫回到信道信息存儲器和外信息存儲器。當(dāng)校驗矩陣的所有行都完成了一次行列運算后則一次迭代譯碼過程結(jié)束
[0006]半并行方式在每次迭代時,只更新一個碼字的部分行/列,可有獲得較快的譯碼速率,且在資源和復(fù)雜度上具有可實現(xiàn)性,但其譯碼器的結(jié)構(gòu)與校驗矩陣的特點有關(guān)系,譯碼器結(jié)構(gòu)一旦設(shè)計好,其譯碼速率、所占用的資源都固定下來,欠缺應(yīng)用的靈活性。另一方面,半并行譯碼器包含一個旋轉(zhuǎn)網(wǎng)絡(luò)模塊,其通常的實現(xiàn)都需要一個桶形移位器裝置,以實現(xiàn)行/列更新時,信息映射關(guān)系的轉(zhuǎn)換,具有邏輯實現(xiàn)復(fù)雜度較高的特點。
【發(fā)明內(nèi)容】

[0007]本發(fā)明的技術(shù)解決問題為:克服現(xiàn)有技術(shù)的不足,提供了一種LDPC高速譯碼裝置,按照譯碼速率需求,對多幀碼字的譯碼軟信息進行拼接,同時進行CNU、VNU的迭代更新計算。采用本發(fā)明能夠?qū)崿F(xiàn)資源和譯碼速率的靈活配置,且實現(xiàn)復(fù)雜度較低。
[0008]本發(fā)明的技術(shù)解決方案為:
[0009]一種資源配置靈活的吉比特LDPC譯碼方法,步驟如下:
[0010](I)在碼字分配器中,將外部輸入的N個LDPC碼字的初始化軟信息以幀為單位分別存儲在碼字分配器中的N個輸入FIFO中,等待譯碼;
[0011](2)將外部輸入的N個LDPC碼字的初始化軟信息按照LDPC校驗矩陣的結(jié)構(gòu)分別存儲在中間信息存儲模塊的N個子模塊中;
[0012](3)當(dāng)某個輸入FIFO中存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量時,給控制器發(fā)出開始譯碼指示信號;
[0013](4)控制器接收到開始譯碼指示信號后控制多路CNU單元讀取所述中間信息存儲模塊N個子模塊中的信息,每個子模塊中均讀取LDPC碼字的M行信息,拼裝為一個N*M行的信息向量,進行CNU計算,并將計算結(jié)果返回給所述N個子模塊中,覆蓋所述讀取的LDPC碼字M行信息所對應(yīng)的位置;
[0014](5)重復(fù)執(zhí)行步驟(4),直到完成N個LDPC碼字中所有軟信息的CNU計算,即完成了 LDPC碼字的一次CNU運算的更新,之后進入步驟(6);
[0015](6)控制器控制多路VNU單元讀取CNU運算更新后的N個子模塊中的LDPC碼字的K列信息,拼裝為一個N*K列的信息向量,結(jié)合所述碼字分配器中N個輸入FIFO中的信息進行VUN計算,得到N*K列的VNU更新結(jié)果和N*K個用于硬判決的校驗信息;VUN更新結(jié)果返回給所述N個中間信息存儲器的子模塊,覆蓋所述讀取的LDPC碼字K列信息所對應(yīng)的位置;N*K個用于硬判決的校驗信息送入碼字輸出緩沖器中進行緩存;
[0016](7)重復(fù)執(zhí)行步驟(6),直到完成N個LDPC碼字中所有軟信息的VNU計算,且用于硬判決的校驗信息累加為N個LDPC碼字的幀長,即完成了 LDPC碼字的一次VNU運算的更新,之后進入步驟(8);
[0017](8)碼字輸出緩沖器將所述N個LDPC碼字幀長的硬判決校驗信息與LDPC校驗矩陣相乘,如果N個LDPC碼字的校驗和均為0,則譯碼成功,將硬判決校驗信息輸出;否則返回步驟(4)再次進行迭代,如果迭代次數(shù)超過預(yù)設(shè)值,則將硬判決校驗信息直接輸出。
[0018]所述輸入FIFO中存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量是指:存儲的信息長度達到一個幀長。
[0019]步驟(5)中每次在同一個子模塊中讀取的LDPC碼字的M行信息均不重復(fù)。
[0020]所述N、M和K均為正整數(shù)。
[0021]本發(fā)明與現(xiàn)有技術(shù)相比具有如下優(yōu)點:
[0022]I)在譯碼過程中,同時對N個LDPC碼字進行合并譯碼,可以獲得較高的譯碼速率。
[0023]2)在迭代譯碼過程中,對于每個待譯LDPC碼字,其信息的讀取采用結(jié)構(gòu)化實現(xiàn),通過將N個LDPC譯碼信息拼裝為一個N*M行/N*K列的信息向量進行CNU/VNU計算,其在譯碼速率上相當(dāng)于同時對I個LDPC碼字的N*M行同時進行計算,而同時避免了對I個LDPC碼字的多行/多列信息的并行讀取,從而不需要在譯碼器中配置一般的桶形移位器,降低了實現(xiàn)的復(fù)雜度。采用本發(fā)明可以靈活實現(xiàn)譯碼速率和資源需求的折衷,具有較大的實際意義。
【專利附圖】

【附圖說明】
[0024]圖1為本發(fā)明方法流程圖;
[0025]圖2為本發(fā)明譯碼裝置示意圖;
【具體實施方式】
[0026]如圖2所示,本發(fā)明譯碼方法所依托的譯碼裝置包括:碼字分配器、多路CNU單元、多路VNU單元、碼字輸出緩沖器、控制器和中間信息存儲模塊;
[0027]碼字分配器接收前級輸入的串行初始化軟信息,按照設(shè)計參數(shù),對N個LDPC碼的初始化軟信息進行緩存和重組,以幀為單位存儲于輸入緩沖區(qū)中,同時還存入中間信息存儲模塊。當(dāng)緩存的軟信息達到一次譯碼的數(shù)據(jù)要求時,則開始將軟信息輸入多路CNU單元、多路VNU單元進行譯碼迭代,得到相應(yīng)的行更新信息、列更新信息。控制器對各模塊的工作狀態(tài)進行實時控制,當(dāng)監(jiān)視到當(dāng)前N幀的迭代譯碼完成時,則控制將譯碼后的數(shù)據(jù)送入碼字輸出緩沖器。碼字輸出緩沖器對輸入的譯碼完成的N幀并行碼字進行緩存和重組,轉(zhuǎn)換后串行數(shù)據(jù)流輸出,完成譯碼操作。
[0028]如圖1所示,本發(fā)明提供的一種資源配置靈活的吉比特LDPC譯碼方法,步驟如下:
[0029](I)在碼字分配器中,將外部輸入的N個LDPC碼字的初始化軟信息以幀為單位分別存儲在碼字分配器中的N個輸入FIFO中,等待譯碼;
[0030](2)將外部輸入的N個LDPC碼字的初始化軟信息按照LDPC校驗矩陣的結(jié)構(gòu)分別存儲在中間信息存儲模塊的N個子模塊中;
[0031](3)當(dāng)某個輸入FIFO中存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量時,給控制器發(fā)出開始譯碼指示信號;所述輸入FIFO中存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量是指:存儲的信息長度達到一個幀長。
[0032](4)控制器接收到開始譯碼指示信號后控制多路CNU單元讀取所述中間信息存儲模塊N個子模塊中的信息,每個子模塊中均讀取LDPC碼字的M行信息,拼裝為一個N*M行的信息向量,進行CNU計算,并將計算結(jié)果返回給所述N個子模塊中,覆蓋所述讀取的LDPC碼字M行信息所對應(yīng)的位置;
[0033](5)重復(fù)執(zhí)行步驟(4),直到完成N個LDPC碼字中所有軟信息的CNU計算,即完成了 LDPC碼字的一次CNU運算的更新,之后進入步驟(6);每次在同一個子模塊中讀取的LDPC碼字的M行信息均不重復(fù)。
[0034](6)控制器控制多路VNU單元讀取CNU運算更新后的N個子模塊中的LDPC碼字的K列信息,拼裝為一個N*K列的信息向量,結(jié)合所述碼字分配器中N個輸入FIFO中的信息進行VUN計算,得到N*K列的VNU更新結(jié)果和N*K個用于硬判決的校驗信息;VUN更新結(jié)果返回給所述N個中間信息存儲器的子模塊,覆蓋所述讀取的LDPC碼字K列信息所對應(yīng)的位置;N*K個用于硬判決的校驗信息送入碼字輸出緩沖器中進行緩存;
[0035](7)重復(fù)執(zhí)行步驟(6),直到完成N個LDPC碼字中所有軟信息的VNU計算,且用于硬判決的校驗信息累加為N個LDPC碼字的幀長,即完成了 LDPC碼字的一次VNU運算的更新,之后進入步驟(8);
[0036](8)碼字輸出緩沖器將所述N個LDPC碼字幀長的硬判決校驗信息與LDPC校驗矩陣相乘,如果N個LDPC碼字的校驗和均為0,則譯碼成功,將硬判決校驗信息輸出;否則返回步驟(4)再次進行迭代,如果迭代次數(shù)超過預(yù)設(shè)值,則將硬判決校驗信息直接輸出。
[0037]所述N、M和K均為正整數(shù)。N的取值決定了譯碼器的并行路數(shù),N值越大則總的譯碼速率越高。M和K的取值可按照LDPC碼校驗矩陣的結(jié)構(gòu)特點進行選擇,一般與校驗矩陣的行子塊數(shù)和列子塊數(shù)有關(guān)。中間信息存儲器隨著所需并行路數(shù)N值的增加可以靈活方便的進行擴展,不涉及整個譯碼器結(jié)構(gòu)的調(diào)整,以滿足不同譯碼速率的應(yīng)用需求。
[0038]下面以CCSDS標(biāo)準(zhǔn)規(guī)定的7/8碼率LDPC碼為例,給出一個具體實施例。CCSDS標(biāo)準(zhǔn)規(guī)定的7/8碼率LDPC碼檢驗矩陣H為QC-LDPC (準(zhǔn)循環(huán)LDPC矩陣),子陣A表示為MXM(M=511)的循環(huán)矩陣,下一行為上一行的循環(huán)移位。H矩陣總共包含32個行重為2和列重為2的子陣,其中有2個子塊行和16個子塊列。以N=S路并行譯碼為例,對譯碼方法進行說明。
[0039](I)在碼字分配器中,將外部輸入的N=S個LDPC碼字的初始化軟信息以幀為單位分別存儲在碼字分配器中的8個輸入FIFO中,等待譯碼;
[0040](2)將外部輸入的N=8個LDPC碼字的初始化軟信息按照LDPC校驗矩陣的結(jié)構(gòu)分別存儲在中間信息存儲模塊的N=S個子模塊中;
[0041](3)當(dāng)碼字分配器中所存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量時,給控制器發(fā)出開始譯碼指示信號;
[0042](4)控制器接收到開始譯碼指示信號后控制多路CNU單元讀取所述中間信息存儲模塊N=8個子模塊中的信息,每個子模塊中均讀取LDPC碼字的M=2行信息,拼裝為一個8*2行的信息向量,進行CNU計算,并將計算結(jié)果返回給所述N=S個子模塊中,覆蓋所述讀取的LDPC碼字2行信息所對應(yīng)的位置;
[0043](5)重復(fù)執(zhí)行步驟(4),直到完成N=8個LDPC碼字中所有軟信息的CNU計算,即完成了 LDPC碼字的一次CNU運算的更新,之后進入步驟(6);每次在同一個子模塊中讀取的LDPC碼字的M=2行信息均不重復(fù)。
[0044](6)控制器控制多路VNU單元讀取CNU運算更新后的N=8個子模塊中的LDPC碼字的K=16列信息,拼裝為一個8*16列的信息向量,結(jié)合所述碼字分配器中Ν=8個輸入FIFO中的信息進行VUN計算,得到8*16列的VNU更新結(jié)果和8*16個用于硬判決的校驗信息;VUN更新結(jié)果返回給所述N=S個中間信息存儲器的子模塊,覆蓋所述讀取的LDPC碼字K=16列信息所對應(yīng)的位置;8*16個用于硬判決的校驗信息送入碼字輸出緩沖器中進行緩存;
[0045](7)重復(fù)執(zhí)行步驟(6),直到完成Ν=8個LDPC碼字中所有軟信息的VNU計算,且用于硬判決的校驗信息累加為N=S個LDPC碼字的幀長,即完成了 LDPC碼字的一次VNU運算的更新,之后進入步驟(8);
[0046](8)碼字輸出緩沖器將所述Ν=8個LDPC碼字幀長的硬判決校驗信息與LDPC校驗矩陣相乘,如果N=S個LDPC碼字的校驗和均為0,則譯碼成功,將硬判決校驗信息輸出;否則返回步驟(4)再次進行迭代,如果迭代次數(shù)超過預(yù)設(shè)值,則將硬判決校驗信息直接輸出。
【權(quán)利要求】
1.一種資源配置靈活的吉比特LDPC譯碼方法,其特征在于步驟如下: (1)在碼字分配器中,將外部輸入的N個LDPC碼字的初始化軟信息以幀為單位分別存儲在碼字分配器中的N個輸入FIFO中,等待譯碼; (2)將外部輸入的N個LDPC碼字的初始化軟信息按照LDPC校驗矩陣的結(jié)構(gòu)分別存儲在中間信息存儲模塊的N個子模塊中; (3)當(dāng)某個輸入FIFO中存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量時,給控制器發(fā)出開始譯碼指示信號; (4)控制器接收到開始譯碼指示信號后控制多路CNU單元讀取所述中間信息存儲模塊N個子模塊中的信息,每個子模塊中均讀取LDPC碼字的M行信息,拼裝為一個N*M行的信息向量,進行CNU計算,并將計算結(jié)果返回給所述N個子模塊中,覆蓋所述讀取的LDPC碼字M行信息所對應(yīng)的位置; (5)重復(fù)執(zhí)行步驟(4),直到完成N個LDPC碼字中所有軟信息的CNU計算,即完成了LDPC碼字的一次CNU運算的更新,之后進入步驟(6); (6)控制器控制多路VNU單元讀取CNU運算更新后的N個子模塊中的LDPC碼字的K列信息,拼裝為一個N*K列的信息向量,結(jié)合所述碼字分配器中N個輸入FIFO中的信息進行VUN計算,得到N*K列的VNU更新結(jié)果和N*K個用于硬判決的校驗信息;VUN更新結(jié)果返回給所述N個中間信息存儲器的子模塊,覆蓋所述讀取的LDPC碼字K列信息所對應(yīng)的位置;N*K個用于硬判決的校驗信息送入碼字輸出緩沖器中進行緩存; (7)重復(fù)執(zhí)行步驟(6),直到完成N個LDPC碼字中所有軟信息的VNU計算,且用于硬判決的校驗信息累加為N個LDPC碼字的幀長,即完成了 LDPC碼字的一次VNU運算的更新,之后進入步驟(8); (8)碼字輸出緩沖器將所述N個LDPC碼字幀長的硬判決校驗信息與LDPC校驗矩陣相乘,如果N個LDPC碼字的校驗和均為0,則譯碼成功,將硬判決校驗信息輸出;否則返回步驟(4)再次進行迭代,如果迭代次數(shù)超過預(yù)設(shè)值,則將硬判決校驗信息直接輸出。
2.根據(jù)權(quán)利要求1所述的一種資源配置靈活的吉比特LDPC譯碼方法,其特征在于:所述輸入FIFO中存儲的信息構(gòu)成一個完整的LDPC譯碼軟信息向量是指:存儲的信息長度達到一個巾貞長。
3.根據(jù)權(quán)利要求1所述的一種資源配置靈活的吉比特LDPC譯碼方法,其特征在于:步驟(5)中每次在同一個子模塊中讀取的LDPC碼字的M行信息均不重復(fù)。
4.根據(jù)權(quán)利要求1所述的一種資源配置靈活的吉比特LDPC譯碼方法,其特征在于:所述N、M和K均為正整數(shù)。
【文檔編號】H03M13/11GK103888149SQ201410106044
【公開日】2014年6月25日 申請日期:2014年3月20日 優(yōu)先權(quán)日:2014年3月20日
【發(fā)明者】陳昕, 李申陽, 宋振宇, 徐祎志 申請人:航天恒星科技有限公司
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
鲁甸县| 额敏县| 丘北县| 喀喇沁旗| 习水县| 汉川市| 庆城县| 广昌县| 张家口市| 新沂市| 梅河口市| 阿鲁科尔沁旗| 博爱县| 安新县| 射阳县| 晋江市| 五华县| 濉溪县| 凉城县| 布尔津县| 原平市| 海晏县| 红桥区| 钟祥市| 宕昌县| 肇庆市| 宜兰县| 泾川县| 汽车| 崇州市| 洱源县| 晋城| 横山县| 乐至县| 临汾市| 江孜县| 平和县| 峡江县| 舞阳县| 穆棱市| 万载县|