JP4432902B2 - 復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法 - Google Patents

復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法 Download PDF

Info

Publication number
JP4432902B2
JP4432902B2 JP2005506568A JP2005506568A JP4432902B2 JP 4432902 B2 JP4432902 B2 JP 4432902B2 JP 2005506568 A JP2005506568 A JP 2005506568A JP 2005506568 A JP2005506568 A JP 2005506568A JP 4432902 B2 JP4432902 B2 JP 4432902B2
Authority
JP
Japan
Prior art keywords
decoding
check matrix
code
parity check
linear
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2005506568A
Other languages
English (en)
Other versions
JPWO2004107585A1 (ja
Inventor
敦 菊池
雅之 服部
俊之 宮内
一夫 渡辺
真紀子 菅
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Corp
Original Assignee
Sony Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sony Corp filed Critical Sony Corp
Publication of JPWO2004107585A1 publication Critical patent/JPWO2004107585A1/ja
Application granted granted Critical
Publication of JP4432902B2 publication Critical patent/JP4432902B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/09Error detection only, e.g. using cyclic redundancy check [CRC] codes or single parity bit
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/29Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes
    • H03M13/2906Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes using block codes
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B20/00Signal processing not specific to the method of recording or reproducing; Circuits therefor
    • G11B20/10Digital recording or reproducing
    • G11B20/18Error detection or correction; Testing, e.g. of drop-outs
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B20/00Signal processing not specific to the method of recording or reproducing; Circuits therefor
    • G11B20/10Digital recording or reproducing
    • G11B20/18Error detection or correction; Testing, e.g. of drop-outs
    • G11B20/1866Error detection or correction; Testing, e.g. of drop-outs by interleaving
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/11Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/11Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
    • H03M13/1102Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
    • H03M13/1105Decoding
    • H03M13/1111Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/11Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
    • H03M13/1102Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
    • H03M13/1191Codes on graphs other than LDPC codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/13Linear codes
    • H03M13/19Single error correction without using particular properties of the cyclic codes, e.g. Hamming codes, extended or generalised Hamming codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/29Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes
    • H03M13/2933Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes using a block and a convolutional code
    • H03M13/2936Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes using a block and a convolutional code comprising an outer Reed-Solomon code and an inner convolutional code
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B20/00Signal processing not specific to the method of recording or reproducing; Circuits therefor
    • G11B20/10Digital recording or reproducing
    • G11B20/18Error detection or correction; Testing, e.g. of drop-outs
    • G11B20/1833Error detection or correction; Testing, e.g. of drop-outs by adding special lists or symbols to the coded information
    • G11B2020/1836Error detection or correction; Testing, e.g. of drop-outs by adding special lists or symbols to the coded information using a Reed Solomon [RS] code
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/13Linear codes
    • H03M13/15Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/13Linear codes
    • H03M13/15Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
    • H03M13/151Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes using error location or error correction polynomials
    • H03M13/1515Reed-Solomon codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/13Linear codes
    • H03M13/15Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes
    • H03M13/151Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes using error location or error correction polynomials
    • H03M13/152Bose-Chaudhuri-Hocquenghem [BCH] codes

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Probability & Statistics with Applications (AREA)
  • Theoretical Computer Science (AREA)
  • Signal Processing (AREA)
  • Error Detection And Correction (AREA)
  • Detection And Correction Of Errors (AREA)

Description

本発明は、復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法に関し、特に、環R上線形符号により符号化した符号化データを復号する場合に用いて好適な、復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法に関する。
近年、例えば、移動体通信や深宇宙通信といった通信分野、及び地上波又は衛星ディジタル放送といった放送分野の研究が著しく進められているが、それに伴い、誤り訂正符号化及び復号の効率化を目的として符号理論に関する研究も盛んに行われている。
符号性能の理論的限界としては、いわゆるシャノン(C. E. Shannon)の通信路符号化定理によって与えられるシャノン限界が知られている。符号理論に関する研究は、このシャノン限界に近い性能を示す符号を開発することを目的として行われている。近年では、シャノン限界に近い性能を示す符号化方法として、例えば、並列連接畳み込み符号(PCCC(Parallel Concatenated Convolutional Codes))や、縦列連接畳み込み符号(SCCC(Serially Concatenated Convolutional Codes))といった、いわゆるターボ符号化(Turbo coding)と呼ばれる手法が開発されている。また、これらのターボ符号が開発される一方で、古くから知られる符号化方法である低密度パリティ検査符号(Low Density Parity Check codes)(以下、LDPC符号という)が脚光を浴びつつある。
LDPC符号は、R. G. Gallagerによる「R. G. Gallager, "Low Density Parity Check Codes", Cambridge, Massachusetts: M. I. T. Press, 1963」において最初に提案されたものであり、その後、「D. J. C. MacKay, "Good error correcting codes based on very sparse matrices", Submitted to IEEE Trans. Inf. Theory, IT-45, pp. 399-431, 1999」や、「M. G. Luby, M. Mitzenmacher, M. A. Shokrollahi and D. A. Spielman, "Analysis of low density codes and improved designs using irregular graphs", in Proceedings of ACM Symposium on Theory of Computing, pp. 249-258, 1998」等において再注目されるに至ったものである。
LDPC符号は、近年の研究により、ターボ符号等と同様に、符号長を長くしていくにしたがって、シャノン限界に近い性能が得られることがわかりつつある。また、LDPC符号は、最小距離が符号長に比例するという性質があることから、その特徴として、ブロック誤り確率特性がよく、さらに、ターボ符号等の復号特性において観測される、いわゆるエラーフロア現象が殆ど生じないことも利点として挙げられる。
以下、このようなLDPC符号について具体的に説明する。なお、LDPC符号は、線形符号であり、必ずしも2元である必要はないが、ここでは、2元であるものとして説明する。
LDPC符号は、そのLDPC符号を定義する検査行列(parity check matrix)が疎なものであることを最大の特徴とするものである。ここで、疎な行列とは、行列のコンポーネントの"1"の個数が非常に少なく構成されるものであり、疎な検査行列をHで表すものとすると、そのような検査行列としては、例えば、図1に示されるHLDPCように、各行のハミング重み("1"の数)(weight)が"2"であり、且つ、各列のハミング重みが"4"であるもの等がある。
このように、各行及び各列のハミング重みが一定である検査行列Hによって定義されるLDPC符号は、レギュラーLDPC符号と称される。一方、各行及び各列のハミング重みが一定でない検査行列Hによって定義されるLDPC符号は、イレギュラーLDPC符号と称される。
このようなLDPC符号による符号化は、検査行列Hに基づいて生成行列Gを生成し、この生成行列Gを2元の情報メッセージに対して乗算することによって符号語を生成することで実現される。具体的には、LDPC符号による符号化を行う符号化装置は、まず、検査行列Hの転置行列HTとの間に、式GHT=0が成立する生成行列Gを算出する。ここで、生成行列Gが、k×n行列である場合には、符号化装置は、生成行列Gに対してkビットからなる情報メッセージ(ベクトルu)を乗算し、nビットからなる符号語c(=uG)を生成する。この符号化装置によって生成された符号語は、値が"0"の符号ビットが"+1"に、値が"1"の符号ビットが"1"にといったようにマッピングされて送信され、所定の通信路を介して受信側において受信されることになる。
一方、LDPC符号の復号は、Gallagerが確率復号(Probabilistic Decoding)と称して提案したアルゴリズムであって、バリアブルノード(variable node(メッセージノード(message node)ともいう。))と、チェックノード(check node)とからなる、いわゆるタナーグラフ(Tanner graph)上での確率伝播(belief propagation)によるメッセージ・パッシング・アルゴリズムによって行うことが可能である。ここで、以下、適宜、バリアブルノードとチェックノードを、単に、ノードともいう。
例えば、図1に示されるパリティ検査行列HLDPCは、図2に示されるようなタナーグラフによって表される。図2のタナーグラフは、図1のパリティ検査行列HLDPCの各列をバリアブルノード、各行をチェックノードとし、パリティ検査行列HLDPCの値が「1」のi行j列の要素に対して、j番目のバリアブルノードとi番目のチェックノードをエッジ(edge)としてつないでいる。
しかしながら、確率復号においては、各ノード間で受け渡されるメッセージが実数値であることから、解析的に解くためには、連続した値をとるメッセージの確率分布そのものを追跡する必要があり、非常に困難を伴う解析を必要とすることになる。そこで、Gallagerは、LDPC符号の復号アルゴリズムとして、アルゴリズムA又はアルゴリズムBを提案している。
LDPC符号の復号は、一般的には、図3に示すような手順にしたがって行われる。なお、ここでは、受信値(受信した符号系列)をU0(u0i)とし、チェックノードから出力されるメッセージをujとし、バリアブルノードから出力されるメッセージをviとする。また、ここでは、メッセージとは、値の"0"らしさを、いわゆる対数尤度比(log likelihood ratio)で表現した実数値である。
まず、LDPC符号の復号においては、図3に示すように、ステップS1において、受信値U0(u0i)が受信され、メッセージujが"0"に初期化されるとともに、繰り返し処理のカウンタとしての整数をとる変数kが"0"に初期化され、ステップS2に進む。ステップS2において、受信値U0(u0i)に基づいて、式(1)に示す演算(バリアブルノードの演算)を行うことによってメッセージviが求められ、さらに、このメッセージviに基づいて、式(2)に示す演算(チェックノードの演算)を行うことによってメッセージujが求められる。
Figure 0004432902
ここで、式(1)と式(2)におけるdvとdcは、それぞれ、検査行列Hの縦方向(列)と横方向(行)の"1"の個数を示す任意に選択可能とされるパラメータであり、例えば、(3,6)符号の場合には、dv=3,dc=6となる。
なお、式(1)または(2)の演算においては、それぞれ、メッセージを出力しようとする枝(edge)(バリアブルノードとチェックノードとを結ぶ線)から入力されたメッセージを、和または積演算のパラメータとしては用いないことから、和または積演算の範囲が、1乃至dv-1または1乃至dc-1となっている。また、式(2)に示す演算は、実際には、2入力v1,v2に対する1出力で定義される式(3)に示す関数R(v1,v2)のテーブルを予め作成しておき、これを式(4)に示すように連続的(再帰的)に用いることによって行われる。
Figure 0004432902
ステップS2では、さらに、変数kが"1"だけインクリメントされ、ステップS3に進む。ステップS3では、変数kが所定の繰り返し復号回数Nよりも大きいか否かが判定される。ステップS3において、変数kがNよりも大きくないと判定された場合、ステップS2に戻り、以下、同様の処理が繰り返される。
また、ステップS3において、変数kがNよりも大きいと判定された場合、ステップS4に進み、式(5)に示す演算を行うことによって最終的に出力する復号結果としてのメッセージviが求められて出力され、LDPC符号の復号処理が終了する。
Figure 0004432902
ここで、式(5)の演算は、式(1)の演算とは異なり、バリアブルノードに接続している全ての枝からの入力メッセージを用いて行われる。
このようなLDPC符号の復号は、例えば(3,6)符号の場合には、図4に示すように、各ノード間でメッセージの授受が行われる。なお、図4における"="で示すノード(バリアブルノード)では、式(1)に示した演算が行われ、"+"で示すノード(チェックノード)では、式(2)に示した演算が行われる。特に、アルゴリズムAにおいては、メッセージを2元化し、"+"で示すノードにて、dc-1個の入力メッセージの排他的論理和演算を行い、"="で示すノードにて、受信値Rに対して、dv-1個の入力メッセージが全て異なるビット値であった場合には、符号を反転して出力する。
また、一方で、近年、LDPC符号の復号の実装法に関する研究も行われている。実装方法について述べる前に、まず、LDPC符号の復号を摸式化して説明する。
図5は、(3,6)LDPC符号(符号化率1/2、符号長12)の検査行列(parity check matrix)の例である。LDPC符号の検査行列は、図6のように、タナーグラフを用いて書き表すことができる。ここで、図6において、"+"で表されるのが、チェックノードであり、"="で表されるのが、バリアブルノードである。チェックノードとバリアブルノードは、それぞれ、検査行列の行と列に対応する。チェックノードとバリアブルノードとの間の結線は、枝(edge)であり、検査行列の"1"に相当する。即ち、検査行列の第j行第i列のコンポーネントが1である場合には、図6において、上からi番目のバリアブルノード("="のノード)と、上からj番目のチェックノード("+"のノード)とが、枝により接続される。枝は、バリアブルノードに対応する符号ビットが、チェックノードに対応する拘束条件を持つことを表わす。なお、図6は、図5の検査行列のタナーグラフとなっている。
LDPC符号の復号方法としては、サムプロダクトアルゴリズム(Sum Product Algorithm)がある(例えば、「和田山正、”低密度パリティ検査符号とsum-productアルゴリズムについて"、[online]、平成13年6月22日、岡山県立大学、[平成15年5月19日検索]、インターネット,<URL:http://vega.c.oka-pu.ac.jp/~wadayama/pdf/LDPC.pdf>」参照)。
このサムプロダクトアルゴリズムでは、バリアブルノードの演算とチェックノードの演算とが繰り返し行われる。
バリアブルノードでは、図7のように、式(1)の演算(バリアブルノード演算)を行う。すなわち、図7において、計算しようとしている枝に対応するメッセージviは、バリアブルノードに繋がっている残りの枝からのメッセージu1およびu2と、受信情報u0iを用いて計算される。他の枝に対応するメッセージも同様に計算される。
次に、チェックノードの演算について説明する前に、式(2)を、式a×b=exp{ln(|a|)+ln(|b|)}×sign(a)×sign(b)の関係を用いて、式(6)のように書き直す。但し、sign(x)は、x≧0のとき1であり、x<0のとき-1である。
Figure 0004432902
更に、x≧0において、φ(x)=ln(tanh(x/2))と定義すると、φ-1(x)=2tanh-1(e-x)であるから、式(6)は、式(7)のように書くことができる。
Figure 0004432902
チェックノードでは、図8のように、式(7)の演算(チェックノード演算)を行う。すなわち、図8において、計算しようとしている枝に対応するメッセージujは、チェックノードに繋がっている残りの枝からのメッセージv1,v2,v3,v4,v5を用いて計算される。他の枝に対応するメッセージも同様に計算される。
なお、関数φ(x)は、φ(x)=ln((ex+1)/(ex-1))とも表すことができ、x>0において、φ(x)=φ-1(x)である。関数φ(x)およびφ-1(x)をハードウェアに実装する際には、LUT(Look Up Table)を用いて実装される場合があるが、両者共に同一のLUTとなる。
サムプロダクトアルゴリズムをハードウェアに実装する場合、式(1)で表されるバリアブルノード演算および式(7)で表されるチェックノード演算とを、適度な回路規模と動作周波数で繰り返し行うことが必要である。
また、このようなサムプロダクトアルゴリズムを適用したLDPC符号の演算コストの算出方法も広く知られている(例えば、「Matthew C.Davey, David J C MacKay"Low Density Parity Check Codes over GF(q)"」参照)。
以上のようにサムプロダクトアルゴリズム(SPA)を適応して良い復号性能を得るには、パリティ検査行列が低密度である必要がある。
また、その他の一般の線形符号、例えば、リードソロモン(Reed Solomon)符号等のパリティ検査行列Hは、定義体の原始根をαとした場合、図9のように表される。図9に示されるように、線形符号のパリティ検査行列Hは、一般に低密度ではない。このような低密度でないリードソロモン符号には、ユークリッド(Euclid)のアルゴリズム等を用いた復号(以下、通常復号と称する)が行われる。
図10は、リードソロモン符号を用いて誤り訂正を行う誤り訂正システムの構成例を示すブロック図である。図10に示される誤り訂正システムは、例えば、ディジタルテレビ等のディジタル通信システムに用いられるシステムである。
図10の誤り訂正システムにおいては、送信側である符号化装置10より送信されたディジタル情報が、例えばインターネットに代表される通信路21を介して、受信側である復号装置30に供給される。
符号化装置10は、外部より供給された送信用のディジタル情報を、リードソロモン符号を用いて符号化するリードソロモン符号化部11、符号化されたディジタル情報の並べ替えを行うインタリーバ12、畳み込み符号化を行う畳み込み符号化部13、並びに、通信路21を介して、復号装置30と通信を行う通信処理部14からなる。
また、復号装置30は、通信路21を介して供給された送信語を取得する通信処理部31、取得した送信語に畳み込み復号を行う畳み込み復号部32、並べ替えられた情報を元の順番に戻すデインタリーバ33、並びに、リードソロモン復号(通常復号)を行うリードソロモン復号部34からなる。
符号化装置10の外部より供給された送信用のディジタル情報は、符号化装置10のリードソロモン符号化部11において、リードソロモン符号化された後、インタリーバ12に供給される。インタリーバ12は、主に通信路21において発生するバースト的誤りを拡散させるために、情報の並べ替え(インタリービング)を行う。リードソロモン符号は、複数ビットを1シンボルとする誤り訂正を行うので、インタリーバ12は、シンボル単位でバースト的誤りを拡散するシンボルインタリービングを行う。
並べ替えが行われた送信用のディジタル情報は、さらに、畳み込み符号化部13において、複数の情報ブロックに基づいて逐次的に符号系列が定まる畳み込み符号が行われる。例えば、拘束長Kの畳み込み符号化部13は、インタリーバ12よりディジタル情報がkビットの情報ブロック毎に供給されると、今回供給された情報ブロックだけでなく、過去に供給された情報ブロックも含めたK個の情報ブロックに基づいて、nビットの符号ブロックに符号化する。
そして、畳み込み符号化されたディジタル情報は、通信処理部14において、送信可能なデータ形式に変換され、通信路21を介して復号装置30に供給される。
復号装置30は、通信処理部31において、有線または無線の通信路21を介して供給された送信語を取得する。取得された送信語は、畳み込み復号部32により、畳み込み復号が行われる。デインタリーバ33は、畳み込み復号された情報を取得すると、符号化装置10のインタリーバ12において行われたインタリービングに対応した方法で情報の並び替えを行い、並び替えられた情報を元の順序に戻す処理(デインタリービング)を行う。リードソロモン復号部34は、元の順序に戻されたディジタル情報に、通常復号によるリードソロモン復号処理を行い、符号化される前のディジタル情報を再現し、その情報を復号装置30の外部に出力する。
以上のようにして、図10の誤り訂正システムは、通信の際に発生した誤りを訂正し、より正確な通信を行えるようにする。
図11は、リードソロモン符号を用いて誤り訂正を行う誤り訂正システムを適用した記録再生装置の構成例を示すブロック図である。図11に示される記録再生装置は、例えば、DVD(Digital Versatile Disc)レコードプレーヤ等のディジタル記録媒体記録再生装置である。
図11の記録再生装置50は、外部より供給されたディジタル情報を、符号化処理部60において符号化し、記録再生処理部70において記録媒体72に記録する。また、記録再生装置50は、記録媒体72に記録されているディジタル情報を、記録再生処理部70において再生し、復号処理部80において復号処理を行って元のディジタル情報を取得し、その情報を外部に出力する。
符号化処理部60は、ディジタル情報に互いに異なる次元に関するリードソロモン符号を行う第1リードソロモン符号化部61−1乃至第nリードソロモン符号化部61−nからなる。
記録再生処理部70は、符号化処理部60より供給された情報を記録媒体72に記録する記録部71、例えば光ディスク等の記録媒体72、記録媒体72に記録されている情報を再生する再生部73からなる。
また、復号処理部80は、符号化処理部60に対応する復号器であり、ディジタル情報に互いに異なる次元に関するリードソロモン復号(通常復号)を行う第1リードソロモン復号部81−1乃至第nリードソロモン復号部81−nからなる。
符号化処理部60の外部より供給されたディジタル情報は、第1リードソロモン符号化部61−1において1次元目に関するリードソロモン符号化が行われる。続いて、ディジタル情報は、第2リードソロモン符号化部61−2乃至第nリードソロモン符号化部61−nの各部において、2次元目乃至n次元目までの各次元目に関するリードソロモン符号が行われる。第nリードソロモン符号化部61−nによる符号化が終了すると、符号化処理部60は、符号化されたディジタル情報を記録再生処理部70に供給する。記録再生処理部70の記録部71は、符号化処理部60より供給されたディジタル情報を記録媒体72に記録する。
記録再生処理部70の再生部73は、記録媒体72に記録されているディジタル情報(符号化されたディジタル情報)を再生し、復号処理部80に供給する。
復号処理部80は、第1リードソロモン復号部81−1乃至第nリードソロモン復号部81−nの各部において、再生部73より供給されたディジタル情報に、各次元目に関するリードソロモン復号(通常復号)を行い、元のディジタル情報を復元する。なお、復号処理部80は、符号化処理部60の場合と逆に、まず、第nリードソロモン復号部81−nにおいて第n次元目に関するリードソロモン復号から行い、n−1次元目、n−2次元目と順に次元数を下げるようにリードソロモン復号を行い、最後に第1次元目に関するリードソロモン復号を行う。復号処理部80は、復元した元のディジタル情報を記録再生装置50の外部に出力する。
以上のようにして、図11の記録再生装置50は、情報の記録や再生の際に発生した情報の誤りを訂正する。
以上のようなリードソロモン符号やBCH(Bose-Chaudhuri-Hocquenghem)符号等に対する通常復号は、受信した値を「0」または「1」のみで推定する硬判定の受信語に対して行う復号方法である。
しかしながら、軟判定の受信語が得られる場合、通常、軟判定受信語を用いての復号性能に比べて、硬判定受信語を用いての復号性能は劣るので、軟判定受信語が得られるシステムにおいて、上述したようにリードソロモン符号を通常復号するようにした場合、その復号性能が良くならないという課題があった。
そこで、上述したようなサムプロダクトアルゴリズムを用いて復号する方法が考えられるが、一般の線形符号のパリティ検査行列は、通常、低密度ではないため、復号性能は良くならないという課題があった。また、仮に、与えられたパリティ検査行列が低密度であるとしても、大きな有限体上でのサムプロダクトアルゴリズムは、非常に複雑であり、その演算コストも大きくなってしまうという課題もあった。
本発明はこのような状況に鑑みてなされたものであり、一般の線形符号に対する復号方法としてサムプロダクトアルゴリズムを適用した場合に、容易に、性能の良い復号処理を行うことができるようにするものである。
本発明の復号装置は、環R上の線形符号の検査行列の各行の線形結合を計算する線形結合計算手段と、線形結合計算手段により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成手段と、検査行列作成手段により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号手段とを備えることを特徴とする。
前記環は、素数のべき乗を元とする有限体であることができる。
前記線形符号は、有限体上のBCH符号またはリードソロモン符号を含むことができる。
前記有限体上の検査行列を、有限体の部分体上に所定の次元で展開する展開手段をさらに備え、線形結合計算手段は、展開手段により展開された検査行列の各行の線形結合を計算することができる。
畳み込み符号化された線形符号を軟判定復号する軟判定復号手段をさらに備え、線形結合計算手段は、軟判定復号手段により軟判定復号された線形符号の検査行列の各行の線形結合を計算することができる。
前記軟判定復号手段による軟判定復号、線形結合計算手段による計算および検査行列作成手段による新たな検査行列の作成、並びに、復号手段による復号を繰り返し実行することができる。
本発明の復号方法は、環R上の線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、線形結合計算ステップの処理により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、検査行列作成ステップの処理により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号ステップとを含むことを特徴とする。
本発明の第1のプログラムは、環R上の線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、線形結合計算ステップの処理により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、検査行列作成ステップの処理により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号ステップとをコンピュータに実行させることを特徴とする。
本発明の記録再生装置は、環R上の線形符号を記録媒体に記録する記録手段と、記録手段により記録された線形符号を再生する再生手段と、再生手段により再生された線形符号の検査行列の各行の線形結合を計算する線形結合計算手段と、線形結合計算手段により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成手段と、検査行列作成手段により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号手段とを備えることを特徴とする。
本発明の記録再生方法は、環R上の線形符号の、記録媒体への記録を制御する記録制御ステップと、記録制御ステップの処理により記録が制御された線形符号の、再生を制御する再生制御ステップと、再生制御ステップの処理により再生が制御された線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、線形結合計算ステップの処理により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、検査行列作成ステップの処理により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号ステップとを含むことを特徴とする。
本発明の第2のプログラムは、環R上の線形符号の、前記記録媒体への記録を制御する記録制御ステップと、前記記録制御ステップの処理により記録が制御された前記線形符号の、再生を制御する再生制御ステップと、前記再生制御ステップの処理により再生が制御された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、線形結合計算ステップの処理により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップとをコンピュータに実行させることを特徴とする。
本発明の再生装置は、記録手段により記録された、環R上の線形符号を再生する再生手段と、再生手段により再生された線形符号の検査行列の各行の線形結合を計算する線形結合計算手段と、線形結合計算手段により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成手段と、検査行列作成手段により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号手段とを備えることを特徴とする。
本発明の再生方法は、記録媒体に記録された、環R上の線形符号の再生を制御する再生制御ステップと、再生制御ステップの処理により再生が制御された線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、線形結合計算ステップの処理により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、検査行列作成ステップの処理により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号ステップとを含むことを特徴とする。
本発明の第3のプログラムは、記録媒体に記録された、環R上の線形符号の再生を制御する再生制御ステップと、再生制御ステップの処理により再生が制御された線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、線形結合計算ステップの処理により計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、検査行列作成ステップの処理により作成された新たな検査行列を用いて、線形符号をサムプロダクトアルゴリズムにより復号する復号ステップとをコンピュータに実行させることを特徴とする。
本発明の復号装置および方法、並びにプログラムにおいては、環R上の線形符号の検査行列の各行の線形結合が計算され、その計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合が抽出され、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列が作成されることにより、値が1である要素の密度が低密度化され、そのように作成された新たな検査行列が用いられ、線形符号がサムプロダクトアルゴリズムにより復号される。
また本発明の記録再生装置および方法、並びにプログラムにおいては、環R上の線形符号が記録媒体に記録され、その記録された線形符号が再生され、その再生された線形符号の検査行列の各行の線形結合が計算され、その計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合が抽出され、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列が作成されることにより、値が1である要素の密度が低密度化され、このように作成された新たな検査行列が用いられて、線形符号がサムプロダクトアルゴリズムにより復号される。
さらに本発明の再生装置および方法、並びにプログラムにおいては、記録媒体に記録された、環R上の線形符号が再生され、その再生された線形符号の検査行列の各行の線形結合が計算され、その計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合が抽出され、ベクトル部分集合の全ベクトルを行成分とする新たな検査行列が作成されることにより、値が1である要素の密度が低密度化され、このように作成された新たな検査行列が用いられて、線形符号がサムプロダクトアルゴリズムにより復号される。
本発明によれば、一般の線形符号の復号処理を行うことができる。特に、一般の線形符号に対する復号方法としてサムプロダクトアルゴリズムを適用した場合に、容易に、性能の良い復号処理を行うことができる。
以下、本発明の実施の形態について説明するが、最初に本発明が適用される技術の例について説明する。
図12は、本発明を適用した復号装置の構成例を示すブロック図である。
図12において、復号装置100は、例えばBCH符号に対応する復号装置であり、環R上の(または有限体上の)受信語のパリティ検査行列を十分低密度な行列に変換する低密度化処理部110および低密度化されたパリティ検査行列を用いて、受信語を復号するLDPC復号部121からなる。
低密度化処理部110は、パリティ検査行列の行の線形結合を計算する線形結合計算部111、線形結合された行を用いて、十分疎なパリティ検査行列を作成するパリティ検査行列作成部112、および作成されたパリティ検査行列のランクが元のパリティ検査行列のランクと同じであるか否かを判定する判定処理部113により構成される。
線形結合計算部111は、取得した受信語に含まれるパリティ検査行列の各行の線形結合を、全ての組み合わせについて計算する。すなわち、線形結合計算部111は、n行のパリティ検査行列に対して、2n通りの組み合わせで線形結合を計算する。線形結合計算部111は、計算結果および受信語をパリティ検査行列作成部112に供給する。
パリティ検査行列作成部112は、線形結合計算部111より供給された計算結果、すなわち、線形結合された行の中から、所定の条件に従って行を抽出し、その抽出した行により構成されるパリティ検査行列を作成する。パリティ検査行列作成部112は、例えば、線形結合された行の中から、値が「1」の要素の数が所定の数以下の行を抽出する等、作成したパリティ検査行列の密度が疎になるように条件を設定し、その条件に該当する行を抽出する。パリティ検査行列作成部112は、作成したパリティ検査行列および受信語を判定処理部113に供給する。なお、後述するように、判定処理部113において、作成したパリティ検査行列のランクが元のパリティ検査行列のランクと異なると判定された場合、パリティ検査行列作成部112は、再度、行の抽出を行い、新たなパリティ検査行列を作成する。その際、パリティ検査行列作成部112は、前回行った行の抽出の条件を変更し、前回作成されたパリティ検査行列と異なる行で構成されるパリティ検査行列を作成する。
判定処理部113は、パリティ検査行列作成部112において作成されたパリティ検査行列のランク(階数)が、元のパリティ検査行列のランクと一致するか否かを判定する。ランクが一致すると判定した場合、判定処理部113は、受信語と、作成されたパリティ検査行列をLDPC復号部121に供給する。ランクが一致しないと判定した場合、判定処理部113は、処理をパリティ検査行列作成部112に戻し、新たなパリティ検査行列を作成させる。
以上のように、低密度化処理部110は、受信語に含まれるBCH符号のパリティ検査行列の密度を低密度化させ、その低密度化されたパリティ検査行列を受信語とともにLDPC復号部121に供給する。
LDPC復号部121は、取得した低密度化されたパリティ検査行列を用いて、受信語をサムプロダクトアルゴリズムにより復号し、復号された受信語を復号装置100の外部に出力する。
以上のように、低密度化処理部110が受信語のパリティ検査行列を低密度化させることにより、LDPC復号部121は、その低密度のパリティ検査行列を用いて、サムプロダクトアルゴリズムを用いた復号処理を行うことができ、性能の良い復号処理を行うことができる。また、低密度化処理部110が受信語のパリティ検査行列を、線形結合を用いて低密度化させるので、LDPC復号部121は、部分体上の復号を行うことができ、演算コストを削減することもできる。すなわち、サムプロダクトアルゴリズムを用いた復号処理を行う前に、パリティ検査行列の密度を、線形結合により低密度化させることにより、復号装置100は、容易に、性能の良い復号処理を行うことができる。
次に、以上のような復号装置による復号処理について、図13のフローチャートを参照して説明する。
最初に、復号装置100の低密度化処理部110は、ステップS21において、パリティ検査行列低密度化処理を実行し、取得した受信語に含まれるパリティ検査行列の密度を疎にする。パリティ検査行列低密度化処理の詳細については、図14のフローチャートを参照して後述する。
そして、ステップS22において、LDPC復号部121は、ステップS21の処理により低密度化されたパリティ検査行列を利用し、サムプロダクトアルゴリズム(SPA)を用いた復号処理を行う。ステップS22の処理が終了すると、LDPC復号部121は、その受信語に対する復号処理を終了する。なお、復号装置100は、上述した復号処理を受信語毎(ブロック毎)に実行する。
次に、図14のフローチャートを参照して、図13のステップS21において実行されるパリティ検査行列低密度化処理の詳細を説明する。
最初に、ステップS41において、低密度化処理部110の線形結合計算部111は、取得した受信語に含まれるパリティ検査行列の各行を用いて、全ての組み合わせで線形結合を行い、結合結果を計算する。
線形結合を計算した線形結合計算部111は、ステップS42において、後述するように行の抽出条件となる変数nの値を、例えば「1」等の初期値に設定する。そして、線形結合計算部111は、受信語、線形結合の計算結果、および変数nをパリティ検査行列作成部112に供給し、ステップS43に処理を進める。
ステップS43において、パリティ検査行列作成部112は、取得した線形結合結果のそれぞれについて値が「1」の要素の数weightを算出し、全ての線形結合結果の中から、値が「1」の要素の数weightが変数n以下であるものを抽出し、それらを行とする新たな低密度のパリティ検査行列を作成する。
すなわち、パリティ検査行列作成部112は、線形結合計算部111において計算された線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、ベクトル部分集合の全ベクトルを行成分とする新たなパリティ検査行列を作成する。
新たなパリティ検査行列を作成したパリティ検査行列作成部112は、ステップS44に処理を進め、変数nの値に「1」を加算し、受信語、作成したパリティ検査行列、および、変数nを判定処理部113に供給する。
受信語、作成したパリティ検査行列、および、変数nを供給された判定処理部113は、ステップS45において、受信語に含まれる元のパリティ検査行列に関する情報に基づいて、元のパリティ検査行列のランク(階数)と、低密度のパリティ検査行列のランク(階数)とが一致するか否かを判定する。
例えば、低密度のパリティ検査行列のランクが低く、元のパリティ検査行列と一致しないと判定した場合、判定処理部113は、ステップS43に処理を戻し、それ以降の処理を繰り返す。すなわち、判定処理部113は、パリティ検査行列作成部112にその判定結果を供給し、再度、パリティ検査行列作成部112に低密度のパリティ検査行列を作成させる。その際、線形結合結果より抽出する条件となる変数nの値が前回の処理の時と異なるので、パリティ検査行列作成部112は、前回と異なる行を有する(前回と要素が異なる)低密度のパリティ検査行列を作成することができる。
ステップS45において、元のパリティ検査行列のランク(階数)と、低密度のパリティ検査行列のランク(階数)とが一致すると判定した場合、判定処理部113は、ステップS46に処理を進め、受信語、および、作成された低密度のパリティ検査行列をLDPC復号部121に出力し、図13のステップS22に処理を戻す。
以上のように、復号処理、およびパリティ検査行列低密度化処理を実行することにより、復号装置100は、サムプロダクトアルゴリズムを用いた復号処理を行う前に、パリティ検査行列の密度を線形結合により低密度化させるので、容易に、性能の良い復号処理を行うことができる。
次に、以上の復号装置100を用いた具体的な低密度化の例について説明する。
以下においては、有限体を素数のべき乗を元とする有限体GF(24)(GF(2)の4次拡大体)とし、線形符号Cとして、符号長15、情報長7の(15,7)-BCH符号を復号する場合について説明する。
線形符号Cのパリティ検査行列Hが、例えば、図15のように与えられるとする。図15に示されるパリティ検査行列Hは8行15列の行列であり、このパリティ検査行列Hに対応するタナーグラフは図16のように表される。図16のタナーグラフは、図15に示されるパリティ検査行列Hの各列を「=」で示されるバリアブルノードで表し、各行を「+」で示されるチェックノードで表したグラフであり、バリアブルノードとチェックノードを結ぶエッジ(edge)の密度が高くなっており、図15のパリティ検査行列Hが低密度の行列でないことを示している。
図12の低密度化処理部110は、上述したように、この8行を用いて線形結合を行い、「1」の密度が少ない28=256個の行ベクトルを作成する。そして、低密度化処理部110は、「1」の個数が4以下の行ベクトルを15個抽出し、15元ベクトルを縦に並べて作成した、図17に示されるような新しい行列Hsp4を作成する。図17に示される行列Hsp4に対応するタナーグラフは、図18に示されるようになる。図17に示される行列Hsp4の行数および列数がともに15であるので、図18に示されるタナーグラフのバリアブルノードおよびチェックノードの数がともに15個になり、図16の場合と比較して、バリアブルノードとチェックノードを結ぶエッジ(edge)の密度が低くなっている。
低密度化処理部110は、この行列Hsp4をパリティ検査行列とし、LDPC復号部121に供給する。LDPC復号部121は、図17に示される低密度のパリティ検査行列Hsp4を用いて、受信語に対して、サムプロダクトアルゴリズムを適用した復号を行う。
図19は、このようなパリティ検査行列を有するBCH符号をビタビ(Viterbi)復号により最尤復号した場合と、図17に示されるような低密度パリティ検査行列Hsp4を用いてサムプロダクトアルゴリズムによる復号を行った場合の復号性能の比較を示すグラフである。
図19において、曲線131は、サムプロダクトアルゴリズム(SPA)による復号結果の、ビットエラーレート(BER)を示しており((2)bch 15 7(wgt4) SPA BER)、曲線132は、ビタビ復号による復号結果のビットエラーレート(BER)を示している((1)bch 15 7 ML BER)。また、点133によりプロットされたデータは、サムプロダクトアルゴリズムによる復号結果のフレームエラーレート(FER)を示しており((2)bch 15 7(wgt4) SPA FER)、点134によりプロットされたデータは、ビタビ復号による復号結果のフレームエラーレート(FER)を示している((1)bch 15 7 ML FER)。
最尤復号(図19の曲線132)は、サムプロダクトアルゴリズムの様な確率的復号を用いた場合の性能限界であるが、図19に示されるように本発明を用いた曲線131は、その性能限界に迫る性能をあげている。
以上のように、復号装置100は、BCH符号に対して、サムプロダクトアルゴリズムを用いた復号処理を行う前に、パリティ検査行列の密度を線形結合により低密度化させるので、容易に、性能の良い復号処理を行うことができる。
なお、以上においては、BCH符号に対する復号処理について説明したが、これに限らず、例えば、リードソロモン符号等のように、一般的な線形符号であればどのような符号方法であってもよい。以下に、リードソロモン符号に対してサムプロダクトアルゴリズムを適用した復号を行う場合について説明する。
図20は、本発明を適用した復号装置の他の構成例を示すブロック図である。
図20において、復号装置150は、例えばリードソロモン符号に対応する復号装置であり、受信語のパリティ検査行列を展開する展開処理部161、展開されたパリティ検査行列を十分低密度な行列に変換する低密度化処理部170、および低密度化されたパリティ検査行列を用いて、受信語を復号するLDPC復号部181からなる。
展開処理部161は、パリティ検査行列の低密度化処理の前処理として、取得した受信語に含まれるパリティ検査行列の各要素をその行列の有限体の次元に応じて、それぞれ所定の次数に展開する。すなわち、展開処理部161は、素数のべき乗を元とする有限体上のパリティ検査行列を、その有限体の部分体上に所定の次元で展開する。展開処理部161は、その展開されたパリティ検査行列および受信語を低密度化処理部170に供給する。
低密度化処理部170は、パリティ検査行列の行の線形結合を計算する線形結合計算部171、線形結合された行を用いて十分疎なパリティ検査行列を作成するパリティ検査行列作成部172、および作成されたパリティ検査行列のランクが元のパリティ検査行列のランクと同じであるか否かを判定する判定処理部173により構成される。これらの各部の構成および動作は、それぞれ、図12に示される復号装置100の低密度化処理部110の場合と同様であるので、それらの説明は省略する。すなわち、低密度化処理部170を構成する線形結合計算部171乃至判定処理部173は、図12に示される線形結合計算部111乃至判定処理部113にそれぞれ対応する。ただし、低密度化処理部170は、展開処理部161より供給された、展開されたパリティ検査行列に対して低密度化処理を行う。
低密度化処理部170は、展開処理部161により展開されたリードソロモン符号のパリティ検査行列の密度を低密度化させ、その低密度化されたパリティ検査行列を受信語とともにLDPC復号部181に供給する。
LDPC復号部181は、取得した低密度化されたパリティ検査行列を用いて、受信語をサムプロダクトアルゴリズムにより復号し、復号された受信語を復号装置150の外部に出力する。
以上のように、低密度化処理部170がパリティ検査行列を低密度化させる前に、展開処理部161によりパリティ検査行列の展開を行うことにより、LDPC復号部181による、低密度化されたパリティ検査行列Hsp24を用いたサムプロダクトアルゴリズムによる復号処理の演算コストは、以下に示される式(8)のように、受信語に含まれるパリティ検査行列Hを用いてサムプロダクトアルゴリズムによる復号処理を行った場合と比べて、約4分の1に削減される。
Figure 0004432902
従って、復号装置150は、容易に、性能の良い復号処理を容易に行うことができる。
次に、以上のような復号装置150による復号処理について、図21のフローチャートを参照して説明する。
最初に、復号装置150の展開処理部161は、ステップS61において、取得した受信語に含まれるパリティ検査行列をその有限体の次元に合わせて展開する。そして、展開処理部161は、展開したパリティ検査行列および受信語を低密度化処理部170に供給し、処理をステップS62に進める。
低密度化処理部170は、ステップS62において、パリティ検査行列低密度化処理を実行し、展開されたパリティ検査行列の密度を疎にする。パリティ検査行列低密度化処理の詳細については、図14のフローチャートを参照して説明した場合と同様であるのでその詳細な説明は省略する。ただし、この場合のパリティ検査行列低密度化処理において、低密度化処理部170は、上述したように展開処理部161により展開されたパリティ検査行列を低密度化させるように処理を行う。
そして、ステップS63において、LDPC復号部181は、ステップS62の処理により低密度化されたパリティ検査行列を利用し、サムプロダクトアルゴリズム(SPA)を用いた復号処理を行う。ステップS63の処理が終了すると、LDPC復号部121は、その受信語に対する復号処理を終了する。なお、復号装置150は、上述した復号処理を受信語毎(ブロック毎)に実行する。
以上のように、復号処理を実行することにより、復号装置150は、低密度化処理を行う前に、パリティ検査行列の各要素を展開させるので、容易に、性能の良い復号処理を行うことができる。
次に、以上の復号装置150を用いた具体的な展開の例について説明する。
以下においては、有限体をGF(24)とし、線形符号Cとして、符号長15、情報長11の(15,11)-リードソロモン符号を復号する場合について説明する。なお、GF(24)の原始根をαとし、その原始根αからなる原始多項式を式(9)とし、符号の生成多項式を式(10)とする。
Figure 0004432902
このときの線形符号Cのパリティ検査行列は、図22に示されるように与えられる。図22に示されるパリティ検査行列Hは4行15列の行列である。ところで、有限体GF(24)は、GF(2)の4次拡大体であることから、有限体GF(24)上の元、行列を全て4次元に展開することが可能である。復号装置150の展開処理部161は、図22に示されるパリティ検査行列Hを展開し、図23に示されるような16行60列のパリティ検査行列Hexpに変換する。この場合、展開処理部161は、図22に示されるパリティ検査行列Hの各要素を4×4の要素群に展開することで、図23に示されるパリティ検査行列Hexpを生成する。
復号装置150の低密度化処理部170は、この展開されたパリティ検査行列Hexpに対して低密度化処理を行い、LDPC復号部181は、低密度化されたパリティ検査行列Hexpを用いて、サムプロダクトアルゴリズムによる復号処理を行う。
図24は、このようなパリティ検査行列を有するリードソロモン符号を通常復号した場合と、図23の展開されたパリティ検査行列Hexpを低密度化したパリティ検査行列Hsp24を用いてサムプロダクトアルゴリズムによる復号を行った場合の復号性能の比較を示すグラフである。
図24において、曲線191は、低密度化したパリティ検査行列Hsp24を用いてサムプロダクトアルゴリズム(SPA)による復号を行った場合の復号結果の、ビットエラーレート(BER)を示しており((4)RS wgt24 SPA BER)、曲線192は、通常復号による復号結果のビットエラーレート(BER)を示している((3)RS ORD BER)。また、点193によりプロットされたデータは、低密度化したパリティ検査行列Hsp24を用いてサムプロダクトアルゴリズムによる復号を行った場合の復号結果のフレームエラーレート(FER)を示しており((4)RS wgt24 SPA FER)、点194によりプロットされたデータは、通常復号による復号結果のフレームエラーレート(FER)を示している((3)RS ORD FER)。
図24に示されるように、本発明を用いた復号の復号結果である曲線191(点193)は、通常復号の場合の復号結果である曲線192(点194)と比較して、より良い性能が得られている。
以上のように、復号装置150は、リードソロモン符号に対して、サムプロダクトアルゴリズムを用いた復号処理を行う前に、パリティ検査行列の密度を線形結合により低密度化させるので、容易に、性能の良い復号処理を行うことができる。また、復号装置150は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、演算コストを低く抑えることができる。
図25は、本発明を適用した、リードソロモン符号を用いた誤り訂正システムの構成例を示すブロック図である。図25に示される誤り訂正システムは、例えば、ディジタルテレビ等のディジタル通信システムに用いられるシステムである。
図25の誤り訂正システムにおいては、送信側である符号化装置210より送信されたディジタル情報が、例えばインターネットに代表される通信路221を介して、受信側である復号装置230に供給される。
符号化装置210は、外部より供給された送信用のディジタル情報を、リードソロモン符号を用いて符号化するリードソロモン符号化部211、符号化されたディジタル情報の並べ替えを行うインタリーバ212、畳み込み符号化を行う畳み込み符号化部213、並びに、通信路221を介して、復号装置230と通信を行う通信処理部214からなる。
リードソロモン符号化部211は、符号化装置210の外部より供給されたディジタル情報に対して、リードソロモン符号を用いた符号化処理を行い、符号化されたディジタル情報をインタリーバ212に供給する。インタリーバ212は、その符号化されたディジタル情報を、主に通信路221において発生するバースト的誤りを拡散させるために、情報の並べ替え(インタリービング)を行う。リードソロモン符号は複数ビットを1シンボルとする誤り訂正を行うので、インタリーバ212は、シンボル単位でバースト的誤りを拡散するシンボルインタリービングを行う。情報の並べ替えを終了したインタリーバ212は、その並び替えられたディジタル情報を畳み込み符号化部213に供給する。
畳み込み符号化部213は、並び替えられたディジタル情報に対して、過去に符号化した情報を参照し、複数の情報ブロックに基づいて、逐次的に符号系列が定まる畳み込み符号を行う。例えば、拘束長Kの畳み込み符号化部213は、インタリーバ212よりディジタル情報がkビットの情報ブロック毎に供給されると、今回供給された情報ブロックだけでなく、過去に供給された情報ブロックも含めたK個の情報ブロックに基づいて、nビットの符号ブロックに符号化する。畳み込み符号化が完了すると、畳み込み符号化部213は、畳み込み符号化されたディジタル情報を通信処理部214に供給する。
通信処理部214は、通信制御処理を行い、所定のプロトコルに基づいて、供給されたディジタル情報を送信語として、通信路221を介して復号装置230に送信する。
符号化装置210より出力されたディジタル情報は、通信路221を介して復号装置230に供給される。
復号装置230は、通信路221を介して供給されたディジタル情報を、受信語として受信する通信処理部231、通信処理部231が取得した受信語に対して、畳み込み復号処理を行う畳み込み復号部232、畳み込み復号された受信語を元の順序に並び替えるデインタリーバ233、並びに、元の順序に戻されたディジタル情報に、サムプロダクトアルゴリズムによる復号処理を行い、リードソロモン符号化される前のディジタル情報を復元するリードソロモンSPA復号部234からなる。
通信処理部231は、通信路221を介して符号化装置210の通信処理部214と通信を行い、所定のプロトコルに基づいて、通信処理部214より供給されたディジタル情報を受信語として取得する。通信処理部231は、取得した受信語を畳み込み復号部232に供給する。
畳み込み復号部232は、符号化装置210の畳み込み符号化部213による符号化方法に対応した方法で、送信処理部231より供給された受信語を復号する。すなわち、畳み込み復号部232は、受信語に対して、例えば、事後確率最大化復号(MAP復号(Maximum a posteriori probability decoding))を実現するBCJR(Bahl, Cocke, Jelinek, and Raviv)アルゴリズムやSOVA(soft output Viterbi algorithm)等を用いて、軟判定復号を行う。そして、畳み込み復号部232は、この軟判定復号された受信語をデインタリーバ233に供給する。
デインタリーバ233は、供給された受信語に対して、符号化装置210のインタリーバ212において行われたインタリービングに対応した方法で情報の並び替えを行い、並び替えられた情報を元の順序に戻す処理(デインタリービング)を行い、元の順序に並び替えられた受信語を、リードソロモンSPA復号部234に供給する。
リードソロモンSPA復号部234は、図20に示される復号装置150と基本的に同様の構成であり、基本的に同様の動作を行い、復号装置150の場合と同様に、図20のブロック図、および図21に示されるフローチャートを適用することができるので、その詳細な説明を省略する。
リードソロモンSPA復号部234は、リードソロモン符号化された受信語に対して、そのパリティ検査行列を展開するとともに低密度化し、そのパリティ検査行列を用いて、サムプロダクトアルゴリズムによる復号処理を行い、符号化される前の元のディジタル情報を復元する。リードソロモンSPA復号部234は、復号したディジタル情報を復号装置230の外部に出力する。
以上のようにして、図25の誤り訂正システムは、容易に、性能の良い復号処理を行うことができ、より正確な通信を行うことができる。また、復号装置230は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、復号処理の演算コストを低く抑えることができる。
なお、以上においては、誤り訂正システムは、リードソロモン符号を復号するように説明したが、これに限らず、例えば、BCH符号を復号するようにしてもよい。
図26は、本発明を適用した、リードソロモン符号を用いた誤り訂正システムの他の構成例を示すブロック図である。図26に示される誤り訂正システムは、例えば、ディジタルテレビ等のディジタル通信システムに用いられるシステムである。図25に示される場合と同様の部分については同一の符号を付しており、その説明を省略する。
図26の誤り訂正システムにおいては、送信側である符号化装置210において符号化されたディジタル情報が、例えばインターネットに代表される通信路221を介して、受信側である復号装置240に供給される。
復号装置240は、通信路221を介して供給されたディジタル情報を、受信語として受信する通信処理部241、通信処理部241が取得した受信語に対して、畳み込み復号処理を行う畳み込み復号部242、畳み込み復号された受信語を元の順序に並び替えるデインタリーバ243、元の順序に戻されたディジタル情報に、サムプロダクトアルゴリズムによる復号処理を行い、リードソロモン符号化される前のディジタル情報を復元するリードソロモンSPA復号部244、並びに、符号化装置210のインタリーバ212と同様に、ディジタル情報の並び替えを行うインタリーバ245からなる。
通信処理部241は、図25の通信処理部231の場合と同様に、通信路221を介して符号化装置210の通信処理部214と通信を行い、所定のプロトコルに基づいて、通信処理部214より供給されたディジタル情報を受信語として取得する。通信処理部241は、取得した受信語を畳み込み復号部242に供給する。
畳み込み復号部242は、図25の畳み込み復号部232の場合と同様に、符号化装置210の畳み込み符号化部213による符号化方法に対応した方法で、送信処理部241より供給された受信語を復号する。すなわち、畳み込み復号部242は、受信語に対して、例えば、BCJRアルゴリズムやSOVA等を用いて、軟判定復号を行う。そして、畳み込み復号部242は、この軟判定復号された受信語をデインタリーバ243に供給する。また、畳み込み復号部242には、インタリーバ245より、サムプロダクトアルゴリズムによる復号が行われた受信語が再度並び替えられて供給される。畳み込み復号部242は、この受信語に対しても、通信処理部241より供給された受信語の場合と同様に、例えば、BCJRアルゴリズムやSOVA等を用いて、軟判定復号を行い、デインタリーバ243に供給する。
デインタリーバ243は、図25のデインタリーバ233の場合と同様に、畳み込み復号部242より供給された受信語に対して、符号化装置210のインタリーバ212において行われたインタリービングに対応した方法で情報の並び替えを行い、並び替えられた情報を元の順序に戻す処理(デインタリービング)を行い、元の順序に並び替えられた受信語を、リードソロモンSPA復号部244に供給する。なお、上述したように、畳み込み復号部242より供給される受信語には、通信処理部241から畳み込み復号部242を介して供給される受信語の他に、インタリーバ245から畳み込み復号部242を介して供給される受信語も含まれる。
リードソロモンSPA復号部244は、図25のリードソロモンSPA復号部244の場合と同様に、図20に示される復号装置150と基本的に同様の構成であり、基本的に同様の動作を行い、復号装置150の場合と同様に、図20のブロック図、および図21に示されるフローチャートを適用することができる。
リードソロモンSPA復号部244は、デインタリーバ243より取得した受信語に対して、その受信語に含まれるパリティ検査行列を展開するとともに低密度化し、そのパリティ検査行列を用いてサムプロダクトアルゴリズムによる復号処理を行い、符号化される前の元のディジタル情報を復元する。リードソロモンSPA復号部244は、復号したディジタル情報を復号装置240の外部に出力する。また、リードソロモンSPA復号部244は、その復号したディジタル情報をインタリーバ245に供給する。
インタリーバ245は、符号化装置210のインタリーバ212と同様に、取得したディジタル情報を所定の順番に並び替える。このインタリーバ245による並び替えのパターンは、インタリーバ212と同様である。このようにして並び替えられたディジタル情報は、畳み込み復号部242に供給される。
以上のように、復号装置240は、通信処理部241において取得した受信語に対して、デインタリーバ243とインタリーバ245を介しながら、畳み込み復号部242による軟判定復号と、リードソロモンSPA復号部244によるサムプロダクトアルゴリズムを用いた復号とを繰り返し行い、復号処理における復号誤り確率を小さくしていく。なお、この復号の繰り返し回数は、予め定められていてもよいし、例えば、誤り訂正する箇所の数等のような所定の条件に基づいて、繰り返しを中止するか否かが判定されるようにしてもよい。
このようにすることで、復号装置240は、容易に性能の良い復号処理を行うことができ、図26の誤り訂正システムは、より正確な通信を行うことができる。また、復号装置240は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、復号処理の演算コストを低く抑えることができる。
なお、以上において、リードソロモンSPA復号部244は、復号したディジタル情報を復号装置240の外部に出力するとともにインタリーバ245に供給するように説明したが、これに限らず、例えば、復号を繰り返している間は、インタリーバ245にのみ復号したディジタル情報を供給するようにし、復号の繰り返しが終了した場合に、ディジタル情報の出力先をインタリーバ245から復号装置240の外部に切り替えて、復号したディジタル情報を出力するようにしてもよい。
なお、以上においては、誤り訂正システムは、リードソロモン符号を復号するように説明したが、これに限らず、例えば、BCH符号を復号するようにしてもよい。
図27は、本発明を適用した、リードソロモン符号を用いて誤り訂正を行う誤り訂正システムを適用した記録再生装置の構成例を示すブロック図である。図27に示される記録再生装置は、例えば、DVDレコードプレーヤ等のディジタル記録媒体記録再生装置である。
図27の記録再生装置250は、外部より供給されたディジタル情報を、符号化処理部260において符号化し、記録再生処理部270において記録媒体272に記録する。また、記録再生装置250は、記録媒体272に記録されているディジタル情報を、記録再生処理部270において再生し、復号処理部280において復号処理を行って元のディジタル情報を取得し、その情報を外部に出力する。
符号化処理部260は、ディジタル情報に互いに異なる次元に関するリードソロモン符号を行う第1リードソロモン符号化部261−1乃至第nリードソロモン符号化部261−nからなる。
符号化処理部260の外部より供給されたディジタル情報は、第1リードソロモン符号化部261−1において1次元目に関するリードソロモン符号化が行われる。続いて、ディジタル情報は、第2リードソロモン符号化部261−2乃至第nリードソロモン符号化部261−nの各部において、2次元目乃至n次元目までの各次元目に関するリードソロモン符号が順に行われる。第nリードソロモン符号化部261−nによる符号化が終了すると、符号化処理部260は、符号化されたディジタル情報を記録再生処理部270に供給する。
記録再生処理部270は、符号化処理部260より供給された情報を記録媒体272に記録する記録部271、例えば光ディスク等の記録媒体272、記録媒体272に記録されている情報を再生する再生部273からなる。
記録再生処理部270の記録部271は、符号化処理部260より供給されたディジタル情報をNRZI(Non Return to Zero Invert)変換(NRZI符号化)するなどして記録媒体272に記録する。また、記録再生処理部270の再生部273は、記録媒体272に記録されているディジタル情報(リードソロモン符号化されたディジタル情報)を再生し、そのディジタル情報に施されたNRZI変換を元に戻し(復号し)、そのディジタル情報を復号処理部280に供給する。
復号処理部280は、符号化処理部260に対応する復号器であり、ディジタル情報に互いに異なる次元に関して、サムプロダクトアルゴリズムによる復号処理を行う第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nからなる。
第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nは、それぞれ、符号化処理部260の第1リードソロモン符号化部261−1乃至第nリードソロモン符号化部261−nに対応し、各次元に関するリードソロモン符号に対して、サムプロダクトアルゴリズムによる復号を行う。第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nは、それぞれ、図20に示される復号装置150と基本的に同様の構成であり、基本的に同様の動作を行う。従って、第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nは、それぞれ、復号装置150の場合と同様に、図20のブロック図、および図21に示されるフローチャートを適用することができる。
復号処理部280は、第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nの各部において、再生部273より供給されたディジタル情報に対して、パリティ検査行列の各要素、行列を展開し、そのパリティ検査行列を低密度化して、各次元目に関するサムプロダクトアルゴリズムによる復号処理を行う。その際、復号処理部280は、図27に示されるように、符号化処理部260の場合と逆に、まず、第nリードソロモンSPA復号部281−nにおいて第n次元目に関するサムプロダクトアルゴリズムによる復号処理から行い、続いて、直列に接続される各リードソロモンSPA復号部において、それぞれ、n−1次元目、n−2次元目と順に次元数を下げるようにサムプロダクトアルゴリズムによる復号処理を行い、最後に第1リードソロモンSPA復号部281−1において第1次元目に関するサムプロダクトアルゴリズムによる復号処理を行う。復号処理部280は、このようにして復元した元のディジタル情報を記録再生装置250の外部に出力する。
このようにすることにより、復号処理部280は、容易に性能の良い復号処理を行うことができ、記録再生装置250は、より正確にディジタル情報の記録および再生を行うことができる。また、復号処理部280は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、復号処理の演算コストを低く抑えることができる。
なお、以上においては、記録再生装置250は、リードソロモン符号を復号するように説明したが、これに限らず、例えば、BCH符号を復号するようにしてもよい。
以上においては、ディジタル情報の記録および再生を行う記録再生装置の例について説明したが、この記録再生装置250の、ディジタル情報を記録媒体に記録する記録機能と、記録媒体に記録されているディジタル情報を再生する再生機能とが別体として構成されるようにしてもよい。
図28は、図27の記録再生装置250と同様の記録機能を有する記録装置の構成例を示すブロック図である。なお、図27に示される場合と同様の部分については同一の符号を付しており、その説明を省略する。
図28の記録装置300は、第1リードソロモン符号化部261−1乃至第nリードソロモン符号化261−nからなる符号化処理部260、並びに、記録部271および記録媒体272からなる記録処理部310を有する。記録装置300の符号化処理部260の外部より供給されたディジタル情報は、最初に、第1リードソロモン符号化部261−1において1次元目に関するリードソロモン符号化が行われる。続いて、その1次元目に関して符号化されたディジタル情報は、第2リードソロモン符号化部261−2乃至第nリードソロモン符号化部261−nの各部に順に供給され、各部において、2次元目乃至n次元目までの各次元目に関するリードソロモン符号が行われる。第nリードソロモン符号化部261−nによる符号化が終了すると、符号化処理部260は、符号化されたディジタル情報を記録処理部310に供給する。
記録処理部310は、符号化処理部260より供給された情報を記録媒体272に記録する記録部271、および、例えば光ディスク等の記録媒体272を含む。記録処理部310の記録部271は、符号化処理部260より供給されたディジタル情報をNRZI変換(NRZI符号化)するなどして記録媒体272に記録する。
すなわち、記録装置300は、図27の記録再生装置250と同様に、符号化処理部260においてディジタル情報をリードソロモン符号化し、記録処理部310の記録部271の制御により、そのリードソロモン符号化されたディジタル情報を記録媒体272に記録する。
このような記録装置300に対応する再生装置を図29に示す。なお、図27に示される場合と同様の部分については同一の符号を付しており、その説明を省略する。
図29の再生装置350は、図28に示される記録装置300に対応する再生装置であり、第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nからなる復号処理部280、並びに、記録媒体272および再生部273からなる再生処理部360を有する。再生処理部360の再生部273は、記録媒体272に記録されているディジタル情報(リードソロモン符号化されたディジタル情報)を再生し、そのディジタル情報に施されたNRZI変換を元に戻し(復号し)、そのディジタル情報を復号処理部280に供給する。
復号処理部280は、第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−nの各部において、再生部273より供給されたディジタル情報に対して、パリティ検査行列の各要素、行列を展開し、そのパリティ検査行列を低密度化して、各次元目に関するサムプロダクトアルゴリズムによる復号処理を行う。その際、復号処理部280は、図29に示されるように、符号化処理部260の場合と逆に、まず、第nリードソロモンSPA復号部281−nにおいて第n次元目に関するサムプロダクトアルゴリズムによる復号処理から行い、続いて、直列に接続される各リードソロモンSPA復号部において、それぞれ、n−1次元目、n−2次元目と順に次元数を下げるようにサムプロダクトアルゴリズムによる復号処理を行い、最後に第1リードソロモンSPA復号部281−1において第1次元目に関するサムプロダクトアルゴリズムによる復号処理を行う。復号処理部280は、このようにして復元した元のディジタル情報を再生装置350の外部に出力する。
このようにすることにより、復号処理部280は、容易に性能の良い復号処理を行うことができ、再生装置350は、より正確にディジタル情報の再生を行うことができる。また、復号処理部280は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、復号処理の演算コストを抑制することができる。
なお、以上においては、記録装置300は、リードソロモン符号を復号するように説明したが、これに限らず、例えば、BCH符号を復号するようにしてもよい。
図30は、本発明を適用した、リードソロモン符号を用いて誤り訂正を行う誤り訂正システムを適用した記録再生装置の構成例を示すブロック図である。図30に示される記録再生装置400は、例えば、DVDレコードプレーヤ等のディジタル記録媒体記録再生装置である。なお、図27に示される場合と同様の部分については同一の符号を付しており、その説明を省略する。
図30の記録再生装置400は、外部より供給されたディジタル情報を、符号化処理部260において符号化し、記録再生処理部270において記録媒体272に記録する。また、記録再生装置400は、記録媒体272に記録されているディジタル情報を、記録再生処理部270において再生し、復号処理部410において復号処理を行って元のディジタル情報を取得し、その情報を外部に出力する。
復号処理部410は、符号化処理部260に対応する復号器であり、それぞれが、図27に示される復号処理部280と同様の構成であり、同様の復号処理を行う、直列に接続されたm個の復号部である第1復号部420−1乃至第m復号部420−mからなる。
第1復号部420−1は、図27の復号処理部280と同様に、符号化処理部260の第1リードソロモン符号化部261−1乃至第nリードソロモン符号化部261−nに対応し、各次元に関するリードソロモン符号に対して、サムプロダクトアルゴリズムによる復号を行う、直列に接続されたn個の復号部である第1リードソロモンSPA復号部421−1−1乃至第nリードソロモンSPA復号部421−1−nにより構成される。この第1リードソロモンSPA復号部421−1−1乃至第nリードソロモンSPA復号部421−1−nは、それぞれ、図20に示される復号装置150と基本的に同様の構成であり、基本的に同様の動作を行う。従って、これらの、第1リードソロモンSPA復号部421−1−1乃至第nリードソロモンSPA復号部421−1−nは、それぞれ、復号装置150の場合と同様に、図20のブロック図、および図21に示されるフローチャートを適用することができる。
第2復号部420−2乃至第m復号部420−mも、それぞれ、第1復号部420−1と同様の構成であり、第1復号部420−1と同様の動作を行う。例えば、第2復号部420−2は、直列に接続されたn個の復号部である第1リードソロモンSPA復号部421−2−1乃至第nリードソロモンSPA復号部421−2−nにより構成され、第m復号部420−mも直列に接続されたn個の復号部である第1リードソロモンSPA復号部421−m−1乃至第nリードソロモンSPA復号部421−m−nにより構成される。なお、これらの第2復号部420−2乃至第m復号部420−mを構成する第1リードソロモンSPA復号部乃至第nリードソロモンSPA復号部は全て、それぞれ、図20に示される復号装置150と基本的に同様の構成であり、基本的に同様の動作を行うので、それぞれ、復号装置150の場合と同様に、図20のブロック図、および図21に示されるフローチャートを適用することができる。
復号処理部410は、まず、再生部273より供給されたディジタル情報に対して、第1復号部420−1の第1リードソロモンSPA復号部421−1−1乃至第nリードソロモンSPA復号部421−1−nの各部において、パリティ検査行列の各要素、行列を展開し、そのパリティ検査行列を低密度化して、各次元目に関するサムプロダクトアルゴリズムによる復号処理を行う。
その際、第1復号部420−1は、符号化処理部260の場合と逆に、まず、第nリードソロモンSPA復号部421−1−nにおいて第n次元目に関するサムプロダクトアルゴリズムによる復号処理から行い、続いて、直列に接続される各リードソロモンSPA復号部において、それぞれ、n−1次元目、n−2次元目と順に次元数を下げるようにサムプロダクトアルゴリズムによる復号処理を行い、最後に第1リードソロモンSPA復号部421−1−1において第1次元目に関するサムプロダクトアルゴリズムによる復号処理を行う。
復号処理が終了すると、第1復号部420−1は、復号されたディジタル情報を第2復号部420−2に供給する。第2復号部420−2は、第1の復号部420−1の場合と同様に、第1リードソロモンSPA復号部421−2−1乃至第nリードソロモンSPA復号部421−2−nを用いて、次元数を1つずつ下げるような順番でサムプロダクトアルゴリズムによる復号処理を行い、復号されたディジタル情報を次の復号部に供給する。このようにして、順に第m復号部420−mまで復号処理が続けられる。第m復号部420−mにおける復号処理が完了すると、復号処理部410は、復号されたディジタル情報を記録再生装置400の外部に出力する。
このようにすることにより、復号処理部410は、容易に性能の良い復号処理を行うことができ、記録再生装置400は、より正確にディジタル情報の記録および再生を行うことができる。また、復号処理部410は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、復号処理の演算コストを低く抑えることができる。
なお、以上においては、記録再生装置400は、リードソロモン符号を復号するように説明したが、これに限らず、例えば、BCH符号を復号するようにしてもよい。
なお、以上においては、ディジタル情報の記録および再生を行う記録再生装置の例について説明したが、この記録再生装置400の、ディジタル情報を記録媒体に記録する記録機能と、記録媒体に記録されているディジタル情報を再生する再生機能とが別体として構成されるようにしてもよい。その場合、図30の記録再生装置400と同様の記録機能を有する記録装置は、図28に示される記録装置300と同様の構成であり、同様の動作を行うので、図28のブロック図を適用することができ、その説明を省略する。
このような図30の記録再生装置400と同様の記録機能を有する記録装置である記録装置300に対応する再生装置を図31に示す。なお、図30に示される場合と同様の部分については同一の符号を付しており、その説明を省略する。
図31の再生装置450は、図28に示される記録装置300に対応する再生装置であり、第1復号部420−1乃至第m復号部420−mからなる復号処理部410、並びに、記録媒体272および再生部273からなる再生処理部460を有する。再生装置450の再生部273は、記録媒体272に記録されているディジタル情報(リードソロモン符号化されたディジタル情報)を再生し、そのディジタル情報に施されたNRZI変換を元に戻し(復号し)、そのディジタル情報を復号処理部410に供給する。
復号処理部410は、まず、再生部273より供給されたディジタル情報に対して、第1復号部420−1において、パリティ検査行列の各要素、行列を展開し、そのパリティ検査行列を低密度化して、サムプロダクトアルゴリズムによる復号処理を各次元に対して行う。続いて、復号処理部410は、ディジタル情報を、直列に接続される第2復号部420−2乃至420−mに、順に供給し、各部においてサムプロダクトアルゴリズムによる復号処理を行う。第m復号部420−mにおける復号処理が完了すると、復号処理部410は、復号されたディジタル情報を記録再生装置400の外部に出力する。
このようにすることにより、復号処理部410は、容易に性能の良い復号処理を行うことができ、再生装置450は、より正確にディジタル情報の再生を行うことができる。また、復号処理部410は、パリティ検査行列を低密度化させる前に、パリティ検査行列の各要素、行列を展開するので、復号処理の演算コストを抑制することができる。
なお、以上においては、BCH符号またはリードソロモン符号に対する復号に本発明を適用する場合について説明したが、これに限らず、本発明は、一般の線形符号であればどのような符号に対応する復号に本発明を適用するようにしてもよい。
また、以上においては、再生装置450は、リードソロモン符号を復号するように説明したが、これに限らず、例えば、BCH符号を復号するようにしてもよい。
さらに、以上においては、例えば、図12に示される復号装置100、図20に示される復号装置150、図25に示されるリードソロモンSPA復号部234、図26に示されるリードソロモンSPA復号部244、図27に示される第1リードソロモンSPA復号部281−1乃至第nリードソロモンSPA復号部281−n、並びに、図30に示される第1復号部420−1乃至第m復号部420−mのような、本発明を適用した復号装置または復号部は、一般の線形符号に対する復号方法として、検査行列を低密度化し、その低密度化した検査行列を用いて、線形符号を復号するように説明したが、これに限らず、例えば、他の装置または他の処理部において、検査行列を予め低密度化しておくようにしてもよい。その場合、復号装置(または復号部)は、その予め低密度化された検査行列を用いて、符号化装置等より供給される線形符号の復号を行う。すなわち、例えば、図25に示される復号装置230、図26に示される復号装置240、図27に示される記録再生装置250、図29に示される再生装置350、図30に示される記録再生装置400、または、図31に示される再生装置450の外部において検査行列が予め低密度化されるようにし、各装置が、その予め低密度化された検査行列を用いて、供給される線形符号の復号を行うようにしてもよい。
上述した一連の処理は、ハードウエアにより実行させることもできるし、ソフトウエアにより実行させることもできる。ソフトウエアにより実行される場合、上述した画像処理装置は、図32に示されるようなパーソナルコンピュータにより構成される。
図32において、パーソナルコンピュータ500のCPU(Central Processing Unit)501は、ROM(Read Only Memory)502に記憶されているプログラム、または記憶部513からRAM(Random Access Memory)503にロードされたプログラムに従って各種の処理を実行する。RAM503にはまた、CPU501が各種の処理を実行する上において必要なデータなども適宜記憶される。
CPU501、ROM502、およびRAM503は、バス504を介して相互に接続されている。このバス504にはまた、入出力インタフェース510も接続されている。
入出力インタフェース510には、キーボード、マウスなどよりなる入力部511、CRT(Cathode Ray Tube)、LCD(Liquid Crystal display)などよりなるディスプレイ、並びにスピーカなどよりなる出力部512、ハードディスクなどより構成される記憶部513、モデムなどより構成される通信部514が接続されている。通信部514は、インターネットを含むネットワークを介しての通信処理を行う。
入出力インタフェース510にはまた、必要に応じてドライブ515が接続され、磁気ディスク、光ディスク、光磁気ディスク、或いは半導体メモリなどのリムーバブルメディア921が適宜装着され、それらから読み出されたコンピュータプログラムが、必要に応じて記憶部513にインストールされる。
一連の処理をソフトウエアにより実行させる場合には、そのソフトウエアを構成するプログラムが、ネットワークや記録媒体からインストールされる。
この記録媒体は、図32に示されるように、装置本体とは別に、ユーザにプログラムを提供するために配布される、プログラムが記録されている磁気ディスク(フロッピディスクを含む)、光ディスク(CD-ROM(Compact Disk-Read Only Memory),DVD(Digital Versatile Disk)を含む)、光磁気ディスク(MD(Mini-Disk)を含む)、もしくは半導体メモリなどよりなるリムーバブルメディア521により構成されるだけでなく、装置本体に予め組み込まれた状態でユーザに提供される、プログラムが記録されているROM502や、記憶部513に含まれるハードディスクなどで構成される。
なお、本明細書において、記録媒体に記録されるプログラムを記述するステップは、記載された順序に沿って時系列的に行われる処理はもちろん、必ずしも時系列的に処理されなくとも、並列的あるいは個別に実行される処理をも含むものである。
また、本明細書において、システムとは、複数の装置により構成される装置全体を表すものである。
低密度パリティ検査行列の例を示す図である。 図1のパリティ検査行列に対応するタナーグラフを説明する図である。 LDPC符号の復号手順を説明するフローチャートである。 メッセージの流れを説明する図である。 LDPC符号の検査行列の例を示す図である。 検査行列のタナーグラフを示す図である。 バリアブルノードを示す図である。 チェックノードを示す図である。 リードソロモン符号の検査行列の例を示す図である。 従来の誤り訂正システムの構成例を閉めす図である。 従来の記録再生装置の構成例を示す図である。 本発明を適用した復号装置の構成例を示す図である。 図12の復号装置による復号処理を説明するフローチャートである。 図13のステップS21において実行されるパリティ検査行列低密度化処理を説明するフローチャートである。 BCH符号のパリティ検査行列の例を示す図である。 図15のパリティ検査行列に対応するタナーグラフを示す図である。 展開されたパリティ検査行列の例を示す図である。 図17のパリティ検査行列に対応するタナーグラフを示す図である。 復号性能を比較するためのグラフである。 本発明を適用した復号装置の他の構成例を示す図である。 図20の復号装置による復号処理を説明するフローチャートである。 リードソロモン符号におけるパリティ検査行列の例を示す図である。 展開されたパリティ検査行列の例を示す図である。 復号性能を比較するためのグラフである。 本発明を適用した誤り訂正システムの構成例を示すブロック図である。 本発明を適用した誤り訂正システムの他の構成例を示すブロック図である。 本発明を適用した記録再生装置の構成例を示すブロック図である。 記録装置の構成例を示すブロック図である。 本発明を適用した再生装置の構成例を示すブロック図である。 本発明を適用した記録再生装置の他の構成例を示すブロック図である。 本発明を適用した再生装置の他の構成例を示すブロック図である。 本発明を適用したコンピュータの一実施の形態の構成例を示すブロック図である。
符号の説明
100 復号装置,110 低密度化処理部, 111 線形結合計算部, 112 パリティ検査行列作成部, 113 判定処理部, 121 LDPC復号部, 161 展開処理部, 210 符号化装置, 230 復号装置, 231 通信処理部, 232 畳み込み復号部, 233 デインタリーバ, 234 リードソロモンSPA復号部, 240 復号装置, 244 リードソロモンSPA復号部, 245 インタリーバ, 250 記録再生装置, 260 符号化処理部, 270 記録再生処理部, 280 復号処理部, 281−1 第1リードソロモンSPA復号部, 300 記録装置, 310 記録処理部, 350 再生装置, 360 再生処理部, 400 記録再生装置, 410 復号処理部, 420−1 第1復号部, 420−1−1 第1リードソロモンSPA復号部, 450 再生装置, 460 再生処理部

Claims (14)

  1. 環R上の線形符号の復号装置であって、
    前記線形符号の検査行列の各行の線形結合を計算する線形結合計算手段と、
    前記線形結合計算手段により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成手段と、
    前記検査行列作成手段により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号手段と
    を備えることを特徴とする復号装置。
  2. 前記環は、素数のべき乗を元とする有限体である
    ことを特徴とする請求項1に記載の復号装置。
  3. 前記線形符号は、前記有限体上のBCH符号またはリードソロモン符号を含む
    ことを特徴とする請求項2に記載の復号装置。
  4. 前記有限体上の前記検査行列を、前記有限体の部分体上に所定の次元で展開する展開手段をさらに備え、
    前記線形結合計算手段は、前記展開手段により展開された前記検査行列の各行の線形結合を計算する
    ことを特徴とする請求項に記載の復号装置。
  5. 畳み込み符号化された線形符号を軟判定復号する軟判定復号手段をさらに備え、
    前記線形結合計算手段は、前記軟判定復号手段により軟判定復号された前記線形符号の検査行列の各行の線形結合を計算する
    ことを特徴とする請求項1に記載の復号装置。
  6. 前記軟判定復号手段による前記軟判定復号、前記線形結合計算手段による計算および前記検査行列作成手段による新たな検査行列の作成、並びに、前記復号手段による前記復号を繰り返し実行する
    ことを特徴とする請求項に記載の復号装置。
  7. 環R上の線形符号の復号方法であって、
    前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、
    前記線形結合計算ステップの処理により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、
    前記検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップと
    を含むことを特徴とする復号方法。
  8. 環R上の線形符号の復号をコンピュータに行わせるプログラムにおいて、
    前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、
    前記線形結合計算ステップの処理により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、
    前記検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップと
    を含む処理をコンピュータに実行させることを特徴とするプログラム。
  9. 記録媒体に情報を記録し、前記記録媒体に記録された前記情報を再生する記録再生装置であって、
    環R上の線形符号を前記記録媒体に記録する記録手段と、
    前記記録手段により記録された前記線形符号を再生する再生手段と、
    前記再生手段により再生された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算手段と、
    前記線形結合計算手段により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成手段と、
    前記検査行列作成手段により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号手段と
    を備えることを特徴とする記録再生装置。
  10. 記録媒体に情報を記録し、前記記録媒体に記録された前記情報を再生する記録再生装置の記録再生方法であって、
    環R上の線形符号の、前記記録媒体への記録を制御する記録制御ステップと、
    前記記録制御ステップの処理により記録が制御された前記線形符号の、再生を制御する再生制御ステップと、
    前記再生制御ステップの処理により再生が制御された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、
    前記線形結合計算ステップの処理により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、
    前記検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップと
    を含むことを特徴とする記録再生方法。
  11. 記録媒体に情報を記録し、前記記録媒体に記録された前記情報を再生する処理をコンピュータに行わせるプログラムにおいて、
    環R上の線形符号の、前記記録媒体への記録を制御する記録制御ステップと、
    前記記録制御ステップの処理により記録が制御された前記線形符号の、再生を制御する再生制御ステップと、
    前記再生制御ステップの処理により再生が制御された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、
    前記線形結合計算ステップの処理により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、
    前記検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップと
    を含む処理をコンピュータに実行させることを特徴とするプログラム。
  12. 記録媒体に記録された情報を再生する再生装置であって、
    前記記録媒体に記録された、環R上の線形符号を再生する再生手段と、
    前記再生手段により再生された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算手段と、
    前記線形結合計算手段により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成手段と、
    前記検査行列作成手段により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号手段と
    を備えることを特徴とする再生装置。
  13. 記録媒体に記録された情報を再生する再生装置の再生方法であって、
    前記記録媒体に記録された、環R上の線形符号の再生を制御する再生制御ステップと、
    前記再生制御ステップの処理により再生が制御された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、
    前記線形結合計算ステップの処理により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、
    前記検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップと
    を含むことを特徴とする再生方法。
  14. 記録媒体に記録された情報を再生する処理をコンピュータに行わせるプログラムにおいて、
    前記記録媒体に記録された、環R上の線形符号の再生を制御する再生制御ステップと、
    前記再生制御ステップの処理により再生が制御された前記線形符号の検査行列の各行の線形結合を計算する線形結合計算ステップと、
    前記線形結合計算ステップの処理により計算された前記線形結合によって得られるベクトルの集合の中から、符号補空間を張る、より重みの低いベクトル部分集合を抽出し、前記ベクトル部分集合の全ベクトルを行成分とする新たな検査行列を作成することにより、値が1である要素の密度を低密度化させる検査行列作成ステップと、
    前記検査行列作成ステップの処理により作成された新たな検査行列を用いて、前記線形符号をサムプロダクトアルゴリズムにより復号する復号ステップと
    を含む処理をコンピュータに実行させることを特徴とするプログラム。
JP2005506568A 2003-05-30 2004-05-28 復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法 Expired - Fee Related JP4432902B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
JP2003153927 2003-05-30
JP2003153927 2003-05-30
PCT/JP2004/007747 WO2004107585A1 (ja) 2003-05-30 2004-05-28 復号方法および復号装置、プログラム、記録再生装置および方法、並びに、再生装置および方法

Publications (2)

Publication Number Publication Date
JPWO2004107585A1 JPWO2004107585A1 (ja) 2006-07-20
JP4432902B2 true JP4432902B2 (ja) 2010-03-17

Family

ID=33487304

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2005506568A Expired - Fee Related JP4432902B2 (ja) 2003-05-30 2004-05-28 復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法

Country Status (8)

Country Link
US (1) US7607063B2 (ja)
EP (1) EP1524771B1 (ja)
JP (1) JP4432902B2 (ja)
KR (1) KR101143732B1 (ja)
CN (1) CN100546204C (ja)
DE (1) DE602004030869D1 (ja)
ES (1) ES2356912T3 (ja)
WO (1) WO2004107585A1 (ja)

Families Citing this family (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20050044963A (ko) * 2003-11-08 2005-05-16 삼성전자주식회사 q차 제곱 잉여류를 이용한 준순환 저밀도 패러티 검사부호 생성 방법
JP4534128B2 (ja) * 2004-03-05 2010-09-01 ソニー株式会社 符号化方法および装置
US7581157B2 (en) 2004-06-24 2009-08-25 Lg Electronics Inc. Method and apparatus of encoding and decoding data using low density parity check code in a wireless communication system
US7752521B2 (en) * 2004-10-12 2010-07-06 Nortel Networks Limited Low density parity check (LDPC) code
US7996746B2 (en) 2004-10-12 2011-08-09 Nortel Networks Limited Structured low-density parity-check (LDPC) code
CN100583651C (zh) 2004-12-22 2010-01-20 Lg电子株式会社 用于使用信道代码解码的装置和方法
US7958424B2 (en) * 2005-06-22 2011-06-07 Trident Microsystems (Far East) Ltd. Multi-channel LDPC decoder architecture
US11327674B2 (en) 2012-06-05 2022-05-10 Pure Storage, Inc. Storage vault tiering and data migration in a distributed storage network
KR101119111B1 (ko) 2006-05-04 2012-03-16 엘지전자 주식회사 Ldpc 부호를 이용한 데이터 재전송 방법
US7814398B2 (en) 2006-06-09 2010-10-12 Seagate Technology Llc Communication channel with Reed-Solomon encoding and single parity check
US8689092B2 (en) 2006-09-18 2014-04-01 Availink, Inc. Family of LDPC codes for video broadcasting applications
WO2008034289A1 (en) * 2006-09-18 2008-03-27 Juntan Zhang Bit mapping scheme for an ldpc coded 32apsk system
WO2008034287A1 (en) 2006-09-18 2008-03-27 Juntan Zhang An interleaving scheme for an ldpc coded 32apsk system
US8230299B2 (en) 2006-09-18 2012-07-24 Availink, Inc. Interleaving scheme for an LDPC coded QPSK/8PSK system
US20110173509A1 (en) * 2006-09-18 2011-07-14 Availink, Inc. Bit mapping scheme for an ldpc coded 16apsk system
US7900126B2 (en) 2006-09-28 2011-03-01 Via Telecom, Inc. Systems and methods for reduced complexity LDPC decoding
KR101221911B1 (ko) * 2006-11-17 2013-01-15 엘지전자 주식회사 Ldpc 부호를 이용하여 재전송을 수행하는 방법
JP4858335B2 (ja) * 2007-07-10 2012-01-18 ソニー株式会社 符号化方法および符号化装置
KR101493999B1 (ko) * 2007-09-06 2015-02-17 삼성전자주식회사 선형 부호 생성 장치 및 방법
US8301979B2 (en) * 2008-10-07 2012-10-30 Sandisk Il Ltd. Low density parity code (LDPC) decoding for memory with multiple log likelihood ratio (LLR) decoders
US8135015B2 (en) * 2009-03-27 2012-03-13 Qualcomm Incorporated System and method of transmitting and receiving data frames
US8443255B2 (en) * 2010-08-26 2013-05-14 Qualcomm Incorporated Parity check matrix optimization and selection for iterative decoding
US8756473B1 (en) * 2010-12-23 2014-06-17 Sk Hynix Memory Solutions Inc. Solid state device coding architecture for chipkill and endurance improvement
US8918705B1 (en) 2012-01-11 2014-12-23 Sk Hynix Memory Solutions Inc. Error recovery by modifying soft information
US8739008B2 (en) * 2012-02-22 2014-05-27 Silicon Motion, Inc. Method for determining parity check matrix utilized in flash memory system and related flash memory system thereof
US9613052B2 (en) * 2012-06-05 2017-04-04 International Business Machines Corporation Establishing trust within a cloud computing system
US9183095B1 (en) 2013-06-28 2015-11-10 Sk Hynix Memory Solutions Inc. Recovering from a program failure by combining write data
FR3032571B1 (fr) * 2015-02-11 2017-03-10 Commissariat Energie Atomique Methode de decodage iteratif de sequences lfsr a faible probabilite de fausse alarme
US9973212B2 (en) * 2015-09-08 2018-05-15 Storart Technology Co. Ltd. Decoding algorithm with enhanced parity check matrix and re-encoding scheme for LDPC code
CN111988112A (zh) * 2019-05-23 2020-11-24 华为技术有限公司 通信方法和装置
JP2023539208A (ja) * 2020-08-31 2023-09-13 マサチューセッツ インスティテュート オブ テクノロジー ネットワークコーディングベースのセキュア通信

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3818442A (en) * 1972-11-08 1974-06-18 Trw Inc Error-correcting decoder for group codes
US6789227B2 (en) * 2001-07-05 2004-09-07 International Business Machines Corporation System and method for generating low density parity check codes using bit-filling
US6895547B2 (en) 2001-07-11 2005-05-17 International Business Machines Corporation Method and apparatus for low density parity check encoding of data
US7000167B2 (en) * 2001-08-01 2006-02-14 International Business Machines Corporation Decoding low density parity check codes
JP3833545B2 (ja) * 2002-02-13 2006-10-11 三菱電機株式会社 通信システム、受信機、送信機および通信方法
JP3893383B2 (ja) * 2002-02-28 2007-03-14 三菱電機株式会社 Ldpc符号用検査行列生成方法および検査行列生成装置
US7103818B2 (en) 2002-09-30 2006-09-05 Mitsubishi Electric Research Laboratories, Inc Transforming generalized parity check matrices for error-correcting codes
KR20040033554A (ko) 2002-10-15 2004-04-28 삼성전자주식회사 에러 정정 부호화 장치 및 그 방법

Also Published As

Publication number Publication date
JPWO2004107585A1 (ja) 2006-07-20
EP1524771A4 (en) 2007-09-05
CN1698272A (zh) 2005-11-16
CN100546204C (zh) 2009-09-30
EP1524771B1 (en) 2011-01-05
KR101143732B1 (ko) 2012-05-09
KR20060014020A (ko) 2006-02-14
US20060015791A1 (en) 2006-01-19
EP1524771A1 (en) 2005-04-20
ES2356912T3 (es) 2011-04-14
DE602004030869D1 (de) 2011-02-17
WO2004107585A1 (ja) 2004-12-09
US7607063B2 (en) 2009-10-20

Similar Documents

Publication Publication Date Title
JP4432902B2 (ja) 復号装置および方法、プログラム、記録再生装置および方法、並びに、再生装置および方法
JP4595574B2 (ja) 復号装置および方法、並びにプログラム
US8078936B2 (en) Encoding method, encoding apparatus, and program
JP4224777B2 (ja) 復号方法および復号装置、並びにプログラム
JP5068537B2 (ja) レプリカ結合グループシャッフル反復デコーダ及びこの生成方法
US7751505B1 (en) LDPC encoder and encoder and method thereof
US8996969B2 (en) Low density parity check decoder with miscorrection handling
US7590929B2 (en) Record reproduction method, apparatus, and circuit for using error correcting code
US7536628B2 (en) Decoding apparatus, decoding method and program
JP4858335B2 (ja) 符号化方法および符号化装置
US20070245217A1 (en) Low-density parity check decoding
JP4412401B2 (ja) 復号装置、復号方法、受信装置、および記憶媒体再生装置
US9048873B2 (en) Systems and methods for multi-stage encoding of concatenated low density parity check codes
US6832042B1 (en) Encoding and decoding system in an optical disk storage device
JP2005051469A (ja) 符号化装置および符号化方法、並びにプログラム
JP2004088449A (ja) 符号化装置及び符号化方法、並びに復号装置及び復号方法
Han et al. Dual-mode decoding of product codes with application to tape storage
JP2010028408A (ja) 情報処理装置、情報処理方法、およびプログラム
JP5288222B2 (ja) 符号化方法および符号化装置
JP4288582B2 (ja) 復号装置および復号方法、並びにプログラム
JP2010041628A (ja) 符号化装置、符号化方法および符号化プログラム
JP2009027302A (ja) 復号装置および復号方法

Legal Events

Date Code Title Description
A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20070528

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20070528

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20070528

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20090908

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20091102

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20091201

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20091214

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130108

Year of fee payment: 3

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

LAPS Cancellation because of no payment of annual fees