本申請是原案的分案申請,原案的申請?zhí)?01410258324.5,申請日2014年6月11日,發(fā)明創(chuàng)造名稱“針對下一代無線廣播的ldpc碼字及編碼方法和編解碼器”。
本發(fā)明涉及一種ldpc碼的編碼方法及編碼器,更具體地說,涉及一種s-iraldpc碼的編碼方法及對應(yīng)的編碼器。
背景技術(shù):
低密度奇偶校驗碼字(lowdensityparitycheck,ldpc)根據(jù)其結(jié)構(gòu)主要可以分為兩類,一類是隨機(jī)的碼字,最經(jīng)典的當(dāng)屬mackay碼,他還有專門的網(wǎng)頁給出他的各種碼字(mackay1999)(richardson2001)(luby2001)(richardsonandurbanke2001);另外一類是基于代數(shù)組合結(jié)構(gòu)(combinatorial)來設(shè)計的碼字。隨機(jī)碼字能夠非常好的逼近香農(nóng)極限,但是由于‘1’分布的隨機(jī)性,導(dǎo)致編碼器的設(shè)計和譯碼器的設(shè)計并不具有并行或者規(guī)律性可行,所以不適合需要具備一定吞吐量系統(tǒng),因此也就沒有被廣泛應(yīng)用了。
而基于代數(shù)組合結(jié)構(gòu)的碼字的出現(xiàn)很好的解決了這方面的問題,這其中,有一類基于有限域(finitegeometry)設(shè)計的碼字具有很好的性能(y.kouands.lin2001),但是這類碼字的缺點是由于其h矩陣密度比較高(大的行重列重),所以當(dāng)使用基于置信傳播的一類算法時,復(fù)雜度非常高。而另一類準(zhǔn)循環(huán)碼字(quasi-cyclicldpc,qc-ldpc)是一類非常重要的基于代數(shù)組合構(gòu)造的碼字。qc-ldpc碼字主要的構(gòu)造是基于準(zhǔn)循環(huán)的單位子矩陣。(j.l.fan2000)(r.m.tanner2001)(r.m.tanner2001)(t.okamura2003)(r.m.tanner2004)這種準(zhǔn)循環(huán)的單位子矩陣結(jié)構(gòu)非常適合實現(xiàn)并行操作的硬件,比如實現(xiàn)并行度大、進(jìn)而高吞吐率的譯碼器。傳統(tǒng)的這種qc-ldpc碼字盡管適合并行度高的譯碼器實現(xiàn),提高了吞吐率,但是通過逆向方法得到了qc結(jié)構(gòu)的生成矩陣可能并不稀疏,或者就算稀疏,其用生成矩陣來編碼得到校驗比特并不是顯然的,要通過求線性方程組來獲得,因此傳統(tǒng)的qc-ldpc碼字的編碼器還是相對復(fù)雜的。為了解決這個問題,學(xué)者zhang和ryan首先提出的結(jié)構(gòu)化的重復(fù)累積碼(structuredirregularrepeataccumulatorcode,s-ira)ldpc碼字(zhangandryan2006),該結(jié)構(gòu)在適合高并行譯碼器的實現(xiàn)的同時,可以以非常簡便高效的方法來完成編碼。該種碼字結(jié)構(gòu)有如下特點,信息比特所對應(yīng)的矩陣部分由準(zhǔn)循環(huán)子矩陣組成,而校驗比特所對應(yīng)的矩陣部分是由雙對角陣組成的。
目前s-ira碼字已經(jīng)被廣泛應(yīng)用在各大通信標(biāo)準(zhǔn)中,主要包括,歐洲第二代數(shù)字廣播電視傳輸標(biāo)準(zhǔn)dvb系列(etsi,2006,dvbt22009,dvb-c22009,dvb-ngh2012);ieee802.11n無線局域網(wǎng)標(biāo)準(zhǔn)(ieee802.11n2009);ieee802.11e無線廣域網(wǎng)標(biāo)準(zhǔn)(ieee802.16e2006);中國數(shù)字電視地面?zhèn)鬏敇?biāo)準(zhǔn)(dttb)(gb20600-2006);移動多媒體廣播(cmmb2006);北美ccsds的近地深空通信系統(tǒng)(ccsds2007);以及一些磁盤存儲設(shè)備的標(biāo)準(zhǔn)等等。從整個國際范圍數(shù)字通信領(lǐng)域的發(fā)展態(tài)勢來看,還會有更多的標(biāo)準(zhǔn)正在或?qū)頃玫絣dpc碼字。
從目前已經(jīng)提交的標(biāo)準(zhǔn)中,特別是商業(yè)上非常成功的dvbt2、dvbs2標(biāo)準(zhǔn),以及最近才定下標(biāo)準(zhǔn)并且商業(yè)上有廣闊前景的dvb-ngh標(biāo)準(zhǔn)(2012年底定稿)來看,其使用的s-ira碼字所對應(yīng)的校驗矩陣主要使用的結(jié)構(gòu)如下:
h=[πh1p]
其中h1是信息比特對應(yīng)的矩陣部分,π是對h1的一個某種形式的行變換,而p是校驗比特對應(yīng)的矩陣部分。
而:
是由l×j個
例如,pi,j的第一種結(jié)構(gòu)如下所示:
pi,j的第二種結(jié)構(gòu)如下所示:
由于pi,j可以由一個以上的單位循環(huán)陣組成,導(dǎo)致其并不適合hss(horizontalshufflescheduling)譯碼算法的硬件實施。關(guān)于這點在dvbt2和s2的實現(xiàn)方法的文獻(xiàn)中有不少提及到,并提出了相關(guān)的犧牲復(fù)雜度的解決辦法。
而p是校驗比特對應(yīng)的矩陣部分,其是如下的雙對角陣:
技術(shù)實現(xiàn)要素:
本發(fā)明的目的旨在提供一種s-iraldpc碼字及對應(yīng)的編碼器、解碼器和編碼方法,來解決現(xiàn)有技術(shù)中常見的s-iraldpc碼的校驗矩陣的結(jié)構(gòu)所帶來的不適合hss(horizontalshufflescheduling)譯碼算法、影響整個ldpc碼字性能的問題。
本專利即提出了一種pi,j只有0個或者1個單位循環(huán)矩陣組成的結(jié)構(gòu)。在保持性能的條件下,適用于hss譯碼。同時提出一種具體參數(shù)的碼字,及其碼表,并提出了相應(yīng)的編碼方法編碼器、譯碼方法及譯碼器。
依據(jù)上述目的,實施本發(fā)明的一種用于編解碼器的s-iraldpc碼字,其碼字的結(jié)構(gòu)為:h=[h1∏p′],h1′為信息比特矩陣,p′是校驗比特矩陣,πp′是對校驗比特矩陣做行變換。其中,信息比特矩陣h1′包括多個循環(huán)子矩陣pi,j,每一個循環(huán)子矩陣只能是單位循環(huán)偏移矩陣或全零矩陣。
依據(jù)上述目的,實施本發(fā)明的一種ldpc編碼器,其采用一種s-ira結(jié)構(gòu)的ldpc碼字,s-iraldpc碼字的結(jié)構(gòu)為:h=[h′1∏p′],h1′為信息比特矩陣,p′是校驗比特矩陣,πp′是對校驗比特矩陣做行變換。其中,信息比特矩陣h1′包括多個循環(huán)子矩陣pi,j,每一個循環(huán)子矩陣只能是單位循環(huán)偏移矩陣或全零矩陣。
依據(jù)上述目的,實施本發(fā)明的一種ldpc解碼器,其采用一種s-ira結(jié)構(gòu)的ldpc碼字,s-iraldpc碼字的結(jié)構(gòu)為:h=[h1′πp′],h1′為信息比特矩陣,p′是校驗比特矩陣,πp′是對校驗比特矩陣做行變換。其中,信息比特矩陣h1′包括多個循環(huán)子矩陣pi,j,每一個循環(huán)子矩陣只能是單位循環(huán)偏移矩陣或全零矩陣。
依據(jù)上述主要特征,本發(fā)明編碼器、解碼器及其中的s-iraldpc碼字的信息比特矩陣為m行×n-m列的矩陣:
依據(jù)上述主要特征,本發(fā)明編碼器、解碼器及其中的s-iraldpc碼字的校驗比特矩陣p′為m行×m列的矩陣:
依據(jù)上述目的,實施本發(fā)明的s-iraldpc碼字的編碼方法包括以下步驟:
獲得信息比特{i0,i1,i2,i3,i4,i5,...,in-m-1,in-m};
初始化校驗比特p0=0,p1=0,p2=0,p3=0,p4=0,...,pm=0;
將每一個校驗比特pk以及與其相連的信息比特做模2和,k=0,1,2…m-1,并做重新排列,得到重排后的校驗比特序列
將重排后的校驗比特序列
依據(jù)上述目的,實施本發(fā)明的ldpc編碼方法和編碼器,其中編碼器內(nèi)置的編碼運(yùn)算模塊采用了所述ldpc的編碼方法,其包括:
計算校驗比特
其中,q=320,m=24000或者m=11520,x表示參與奇偶校驗比特累加的信息比特的地址,針對上述兩個m值,x的表分別為以下兩個碼表:
碼表1:碼率7/12m=24000,碼長n=57600
碼表2:碼率12/15m=11520,碼長n=57600
采用了本發(fā)明的技術(shù)方案,通過大量仿真模擬,找出了比現(xiàn)有技術(shù)更適用于hss(horizontalshufflescheduling)譯碼算法的一種s-iraldpc碼字的信息比特矩陣結(jié)構(gòu),以及使用這種s-iraldpc碼的編碼器、解碼器,從而產(chǎn)生了意想不到的s-iraldpc碼字性能上的提升。
具體實施方式
下面結(jié)合實施例進(jìn)一步說明本發(fā)明的技術(shù)方案。
hss(horizontalshufflescheduling)算法相比于洪水(flooding)算法的區(qū)別在于,flooding算法則是必須等到所有的行操作完之后,得到的數(shù)據(jù)一次性進(jìn)行更新,然后用到下一次迭代中去,而hss算法中在某一次迭代里,每一行行操作后得到的結(jié)果可以立即更新,用到仍然在本次迭代的下一次行操作中去,這樣可以大大提高譯碼算法的收斂速度。另一方面,hss算法只需要保存n個(n為碼長)軟信息和的數(shù)據(jù),以及m×2個(m為校驗矩陣的行數(shù))行操作的結(jié)果軟值信息,相比于flooding算法,節(jié)省了非常多的芯片面積。
但是,現(xiàn)有的hss算法在選擇循環(huán)子塊時,循環(huán)子塊通常不是單位子塊,而是兩個或者兩個以上的單位子塊,這在并行操作的過程中勢必導(dǎo)致內(nèi)存訪問的沖突。這是因為如果循環(huán)子塊由兩個以上的單位子塊構(gòu)成,那么當(dāng)循環(huán)子塊在并行行操作的時候,會有兩個行的行操作輸入同時要求讀取同一塊內(nèi)存,并且在操作完之后同時寫同一塊內(nèi)存。這既沒有達(dá)到hss算法的初衷,也會導(dǎo)致內(nèi)存沖突。
因此,基于現(xiàn)有標(biāo)準(zhǔn)中l(wèi)dpc碼字結(jié)構(gòu)的缺點,具體來說,是信息比特矩陣中的循環(huán)子矩陣可能由有多個循環(huán)單位陣組成導(dǎo)致不適合hss譯碼算法實現(xiàn)的問題,本發(fā)明提出一種新的s-iraldpc碼字的結(jié)構(gòu),其校驗矩陣的結(jié)構(gòu)如下:
h=[h′1πp′],
其中,h′1是信息比特矩陣,p′是校驗比特矩陣,πp′是對校驗比特矩陣p′做的一個某種形式的行變換。
信息比特矩陣h′1是一個m行×n-m列的矩陣,其具體結(jié)構(gòu)如下所示:
在本發(fā)明中,信息比特矩陣h1′包括多個循環(huán)子矩陣pi,j,h1′中的每一個循環(huán)子矩陣pi,j的大小為
根據(jù)上述的pi,j結(jié)構(gòu)的限定可以得到,本發(fā)明的循環(huán)子矩陣pi,j只可能是如下兩種具體的結(jié)構(gòu)形式:
1)
2)
另一方面,為了配合信息比特矩陣h1′的結(jié)構(gòu),本發(fā)明的校驗比特矩陣p′是一個m行×m列的矩陣,其具體結(jié)構(gòu)如下所示:
由上述結(jié)構(gòu)可以看出,校驗比特矩陣p′是一種特殊的雙對角矩陣,其主對角上都是‘1’,次對角線上也為‘1’,各行、列的其余部分位置上均為‘0’。
本發(fā)明另外還公開一種ldpc編碼器,其采用的就是上述的s-iraldpc碼字,具體來說,其校驗矩陣的具體結(jié)構(gòu)是:
h=[h1∏p′],其中,h1′為信息比特矩陣,p′是校驗比特矩陣,∏p′是對校驗比特矩陣做行變換。特別的,信息比特矩陣h1′包括多個循環(huán)子矩陣pi,j,每一個循環(huán)子矩陣只能是單位循環(huán)偏移矩陣或全零矩陣。
本發(fā)明另外還公開一種ldpc解碼器,其采用的就是上述的s-iraldpc碼字,具體來說,其校驗矩陣的具體結(jié)構(gòu)是:
h=[h1′пp′],其中,h1′為信息比特矩陣,p′是校驗比特矩陣,πp′是對校驗比特矩陣做行變換。特別的,信息比特矩陣h1′包括多個循環(huán)子矩陣pi,j,每一個循環(huán)子矩陣只能是單位循環(huán)偏移矩陣或全零矩陣。
由于本發(fā)明的編碼器和解碼器均采用上述公開的ldpc碼字,因此其ldpc碼字的其他細(xì)節(jié)特性在上述說明書中已公開,這里不再重復(fù)說明。
此外,本發(fā)明還公開了上述ldpc碼字的編碼方法,其主要步驟如下:
步驟s1:獲得信息比特,設(shè)置已知的信息比特為{i0,i1,i2,i3,i4,i5,...,in-m-1},所謂編碼即利用校驗矩陣h求出校驗比特:
步驟s2:初始化校驗比特p0=0,p1=0,p2=0,p3=0,p4=0,...,pm=0;
步驟s3:將每一個校驗比特pi以及與其相連的信息比特做模2和,即:pi=pi
步驟s4:將重排后的校驗比特序列
最終得到校驗比特序列:
通過本發(fā)明的說明書所公開的技術(shù)方案可見,本發(fā)明的s-iraldpc碼字的特點是其信息比特矩陣中的循環(huán)子矩陣除了0矩陣的結(jié)構(gòu)之外,只可能由單位循環(huán)偏移矩陣構(gòu)成,這種循環(huán)子矩陣的選擇適應(yīng)了hss算法并行計算是基于循環(huán)子塊的技術(shù)特征,因此當(dāng)循環(huán)子塊在并行行操作的時候,不存在兩個行的行操作輸入同時要求讀取同一塊內(nèi)存,也不存在操作完之后同時寫同一塊內(nèi)容,這樣能夠避免內(nèi)存沖突。
根據(jù)本發(fā)明的信息比特矩陣和校驗比特矩陣所構(gòu)成的s-iraldpc碼、應(yīng)用本發(fā)明ldpc碼的編碼器、解碼器在hss算法中能夠有較佳的碼字性能。
此外,本發(fā)明還公開一種與上述s-iraldpc碼字相對應(yīng)的編碼方法和編碼器,并且能夠?qū)?yīng)上述結(jié)構(gòu)。編碼器內(nèi)置有編碼運(yùn)算模塊,并且編碼運(yùn)算模塊采用了如下的ldpc編碼方法:
在編碼運(yùn)算模塊中,
計算校驗比特
其中,q=320,m=24000或者m=11520,x表示參與奇偶校驗比特累加的信息比特的地址,針對上述兩個不同的m值,x的表分別為以下兩個碼表:
碼表1:碼率7/12m=24000,碼長n=57600
碼表2:碼率12/15m=11520,碼長n=57600
具體來說,令ldpc的碼字為:
c=(i0,i1,...,ij,...,ik-1,p0,p1,...,pm-1);其中,(i0,i1,...,in-m-1)為信息比特比特,是已知的{1,0}序列。(p0,p1,p2,...,pm-1)為校驗比特,為待計算的比特。
首先初始化所述校驗部分所對應(yīng)的各校驗比特,
即p0=0,p1=0,p2=0,p3=0,p4=0,p5=0,...,pm-1=0,其中每個pi代表校驗矩陣中的一行,例如pm代表校驗矩陣中的第m行。
將校驗比特按照q個比特為一組進(jìn)行分組以得到多個校驗比特組。
具體地,首先,設(shè)置所述校驗比特為:
{p0,p1,p2,p3,p4,p5,...,pm-1}
然后,將所述校驗比特按順序以q個比特為一組進(jìn)行分組以得到多個校驗比特組。
例如,校驗比特組為:
{pjq+0,pjq+1,...,pjq+(q-1)},其中,j取值為(0、1、2、…、q-1),其中
其次,將各校驗比特組中的校驗比特與其在低密度奇偶校驗矩陣中所關(guān)聯(lián)的信息比特進(jìn)行累加處理。
具體地,對每個校驗比特組中的q個比特pm作如下異或運(yùn)算:
其中,q=320,m=24000或者m=11520,x表示參與奇偶校驗比特累加的信息比特的地址;x表示各個校驗比特組中第一個校驗比特(例如可以是p0,pq+0,p2q+0,...,pjq+0,...)所代表的所述低密度奇偶校驗矩陣中的行(對應(yīng)第0,q,2q,3q,...,jq,...行)里“1”所在列的位置,但不包括所述低密度奇偶校驗矩陣中校驗部分中的“1”的列的位置。
以碼表1的碼字為例,q=320,校驗比特數(shù)m=24000,信息比特數(shù)n-m=33600。
表1中的第一行數(shù)字:
61297193128114679996118361205032383833041
每個數(shù)字代表了低密度奇偶校驗矩陣中的第一行(對應(yīng)第一個校驗比特p0)中“1”的位置(即列的位置),但這個位置并不包括低密度奇偶校驗矩陣的校驗部分的“1”的列的位置。
另外該行的數(shù)字即為x,代表了第一個校驗比特塊中的第一個比特p0所代表校驗矩陣中的第0行的“1”的位置(即列的位置,列同樣以0開始計數(shù))。
那么有:
做完這個之后,則根據(jù)公式(1)有:
對于其他行依照上述公式(1)依次類推,在此不一一列舉。
之后對累加后的各校驗比特作交織處理。
具體地,包括:對累加后的各校驗比特依照置換格式作交織處理,其中所述置換格式通過如下公式實現(xiàn):
piq'=pi;piq+1'=pi+q;piq+2'=pi+2q;piq+3'=pi+3q;
piq+4'=pi+4q,...,piq+q-1'=pi+(q-1)q;
其中,i=0、1、2、3、……、q-1。
例如,
其中,
在本實施例中,{p0,p1,p2,p3,p4,p5,...,pm-1}表示交織前的校驗比特;
{p0',p1',p2',p3',p4',p5',...,pm-1'}表示交織后的校驗比特。
最后將經(jīng)過交織處理后的各校驗比特進(jìn)行模2加運(yùn)算以得到最終的校驗比特。
具體地,本步驟通過如下公式實現(xiàn):
p′0=p′0
得到的(p0',p1',...pm-1')即為最終編碼后的校驗比特,最終得到的ldpc碼c=(i0,i1,...,ij,...,in-m-1,p0',p1',...,pm-1')。
對于現(xiàn)有技術(shù)中通過犧牲復(fù)雜度來解決ldpc碼用于hss算法時內(nèi)存沖突的問題,本發(fā)明的s-iraldpc碼、使用s-iraldpc碼的編碼器、解碼器中的信息比特矩陣的選擇設(shè)計能夠產(chǎn)生意想不到的技術(shù)效果,從碼字結(jié)構(gòu)本身上,有效地降低了hss算法的復(fù)雜度,解決了上述現(xiàn)有技術(shù)中存在的技術(shù)難題。
所屬領(lǐng)域的技術(shù)人員應(yīng)當(dāng)認(rèn)識到,以上的說明書僅是本發(fā)明眾多實施例中的一種或幾種實施方式,而并非用對本發(fā)明的限定。任何對于以上所述實施例的均等變化、變型以及等同替代等技術(shù)方案,只要符合本發(fā)明的實質(zhì)精神范圍,都將落在本發(fā)明的權(quán)利要求書所保護(hù)的范圍內(nèi)。