JP2014099944A - ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置 - Google Patents

ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置 Download PDF

Info

Publication number
JP2014099944A
JP2014099944A JP2014044504A JP2014044504A JP2014099944A JP 2014099944 A JP2014099944 A JP 2014099944A JP 2014044504 A JP2014044504 A JP 2014044504A JP 2014044504 A JP2014044504 A JP 2014044504A JP 2014099944 A JP2014099944 A JP 2014099944A
Authority
JP
Japan
Prior art keywords
node
bit
check
check node
message
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.)
Pending
Application number
JP2014044504A
Other languages
English (en)
Inventor
Erich F Haratsch
エフ. ハラッシュ エリック
Ruwan Ratnayake
ラトナヤケ ルワン
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.)
Agere Systems LLC
Original Assignee
Agere Systems LLC
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 Agere Systems LLC filed Critical Agere Systems LLC
Publication of JP2014099944A publication Critical patent/JP2014099944A/ja
Pending 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/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/1131Scheduling of bit node or check node processing
    • 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/65Purpose and implementation aspects
    • H03M13/6566Implementations concerning memory access contentions

Landscapes

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

Abstract

【課題】相互に接続されたビット・ノードおよび検査ノードを有する2部グラフを用いて記述されることが可能な符号を復号する方法および装置を提供する。
【解決手段】検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの絶対値が計算され、この絶対値は、ビット・ノードiおよび検査ノードjについての、ビット・ノードから検査ノードへのメッセージの変換された絶対値を除く、検査ノードjに接続された複数のビット・ノードについての、ビット・ノードから検査ノードへのメッセージの変換された絶対値の和に基づく。検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの正負符号を計算することも、ビット・ノードから検査ノードへのメッセージの正負符号の積Sと、ビット・ノードiおよび検査ノードjについての、ビット・ノードから検査ノードへのメッセージの正負符号とを掛け合わせることにより、可能である。
【選択図】図4

Description

本発明は、主に符号化および復号の技術に関し、特に、符号化された信号の復号に用いられる復号器のアルゴリズムおよびアーキテクチャに関する。
符号化は、デジタル情報の伝送において、ビットおよびパケットのエラー確率を低減するために広く用いられている。多くの用途において、この目的のために畳み込み符号が用いられている。畳み込み符号は、符号化されるべき入力ビットによって状態遷移が決定される状態機械により定義される。畳み込み符号、または畳み込み符号をベースとする符号を復号するアルゴリズムとして最も一般的な2つが、ビタビ・アルゴリズムおよび最大事後確率(maximum a−posteriori probability)(MAP)アルゴリズムである。
より強力なエラー訂正能力を必要とする用途では、ターボ符号またはLDPC符号が使用されることが多い。連接符号(ターボ符号など)の復号は、ある符号トレリスの復号の結果を次の符号トレリスの復号の入力とし、その後の符号トレリスについても同様にすることが必要である。ターボ符号の復号アルゴリズムの反復性は、実装に関して重大な課題を提示する。
LDPC符号は、前途有望な次世代エラー訂正符号であり、符号化利得に関してはターボ符号をしのぐ可能性がある。LDPC符号の並列または直列の復号に関しては、多くの技術が提案されている。たとえば、A.J.Blanksby、C.J.Howland、「A 690−mW 1−Gb/s 1024−b,Rate−1/2 Low−Density Parity−Check Decoder」、IEEE J.Solid−State Circuits、Vol.37、404〜412頁(2002年3月)、および米国特許第6,539,367号(Blanksbyら)には、低密度パリティ検査(Low Density Parity Check)(LDPC)符号のブロック並列復号についての記述がある。
LDPC復号器の直列実装は、一部のハードウェアを共用できるので、並列の復号方法と比較して、必要な計算素子の数を少なくすることが可能であり、また、必要なルーティング機構を簡単にすることが可能である。しかしながら、直列方法は、2部グラフのエッジに沿うすべてのメッセージを保存する必要があるために、一般に追加メモリを必要とし、また、直列実装は、符号のブロックを復号するために、より多くのクロック・サイクルを費やすので、スループットが制限される。一般に、2部グラフは、LDPC符号で用いられるパリティ検査行列のグラフィカル表現である。典型的な必要メモリ量は、符号内のエッジの数の2倍に比例し、サイクル数は、一般に、符号内のビット・ノードおよび検査ノードの数の和に比例する。
たとえば、Zining WuとGregory Burdは、LDPC復号器がチャネル検出器と連結される通信システムのための直列アーキテクチャを提案している。この開示されたアーキテクチャは、従来の直列実装より必要メモリ量が少ない。Z.Wu、G.Burd、「Equation Based LDPC Decoder for Intersymbol Interference Channels」、IEEE Proc.of Acoustics,Speech,and Signal Processing 2005(ICASSP ’05)、Vol.5,757〜60頁、(2005年3月18〜23日)を参照されたい。D.E.Hocevarは、やはり従来の直列実装より必要メモリ量が少ないスタンドアロンLDPC復号器のための直列アーキテクチャを提案している。D.E.Hocevar、「LDPC Code Construction With Flexible Hardware Implementation」、IEEE Int’l Conf.on Comm.(ICC),Anchorage,AK、2708〜2712頁(2003年5月)を参照されたい。
必要メモリ量または一反復当たりのサイクル数(またはその両方)、ならびにビット・エラー・レート性能において、並列および直列実装の両方に対して、さらなる改善を示す直列LDPC復号アーキテクチャが、スタンドアロンLDPC復号器についても、連結LDPC復号器についても、依然として必要とされている。
米国特許第6,539,367号(Blanksbyら)
A.J.Blanksby、C.J.Howland、「A 690−mW 1−Gb/s 1024−b,Rate−1/2 Low−Density Parity−Check Decoder」、IEEE J.Solid−State Circuits、Vol.37、404〜412頁(2002年3月) Z.Wu、G.Burd、「Equation Based LDPC Decoder for Intersymbol Interference Channels」、IEEE Proc.of Acoustics,Speech,and Signal Processing 2005(ICASSP ’05)、Vol.5,757〜60頁、(2005年3月18〜23日) D.E.Hocevar、「LDPC Code Construction With Flexible Hardware Implementation」、IEEE Int’l Conf.on Comm.(ICC),Anchorage,AK、2708〜2712頁(2003年5月) E.Yeoら、「VLSI Architectures for Iterative Decoders in Magnetic Recording Channels」、IEEE Trans.On Magnetics、Vol.37、No.2、748〜755頁(2001年3月)
主として、相互に接続されたビット・ノードおよび検査ノードを有する2部グラフを用いて記述されることが可能な符号(LDPC符号など)を復号する方法および装置を提供する。2部グラフは、たとえば、パリティ検査行列のグラフィカル表現であることが可能である。本発明の一態様によれば、検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの絶対値が計算され、この絶対値は、ビット・ノードiおよび検査ノードjについての、ビット・ノードから検査ノードへのメッセージの変換された絶対値を除く、検査ノードjに接続された複数のビット・ノードについての、ビット・ノードから検査ノードへのメッセージの変換された絶対値の和に基づく。検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの正負符号を計算することも、検査ノードjに接続された複数のビット・ノードの中の、ビット・ノードから検査ノードへのメッセージの正負符号の積Sと、ビット・ノードiおよび検査ノードjについての、ビット・ノードから検査ノードへのメッセージの正負符号とを掛け合わせることにより、可能である。
本発明の連結実施形態では、検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの絶対値が計算され、この絶対値は、ビット・ノードiについてのアプリオリ情報値の変換された絶対値を除く、検査ノードjに接続された複数のビット・ノードについてのアプリオリ情報値の変換された絶対値の和に基づく。検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの正負符号を計算することも、検査ノードjに接続された複数のビット・ノードについてのアプリオリ情報値の正負符号の積Sと、ビット・ノードiについてのアプリオリ情報値の正負符号とを掛け合わせることにより、可能である。これらの計算は、軟出力検出器に連結されたLDPC復号器によって実行されることが可能である。アプリオリ情報値は、軟出力検出器によって生成されるか、軟出力検出器によって与えられる軟出力に基づいて計算される。
本発明のさらなる態様によれば、相互に接続されたビット・ノードおよび検査ノードを有する2部グラフを用いて記述されることが可能な符号を復号する復号器アーキテクチャが開示される。本開示の復号器は、スタンドアロン形式で実装されるか、軟出力検出器と連結されることが可能である。本開示の復号器は、ビット・ノード更新ユニットと、ビット・ノード更新ユニットに接続された、複数の並列の、検査ノード更新ユニットとを備えて、複数の、検査ノードからビット・ノードへのメッセージを計算する。
スタンドアロン実施形態では、検査ノード更新ユニットは、ビット・ノードから検査ノードへのメッセージの、ある1つの変換された絶対値を除く、複数の、ビット・ノードから検査ノードへのメッセージの変換された絶対値の和に基づいて、検査ノードからビット・ノードへのメッセージの絶対値を計算する。連結実施形態では、検査ノード更新ユニットは、ビット・ノードのアプリオリ情報値の、ある1つの変換された絶対値を除く、複数のビット・ノードについてのアプリオリ情報値の変換された絶対値の和に基づいて、検査ノードからビット・ノードへのメッセージの絶対値を計算する。
メモリに接続される、いくつかの回路ユニットが開示される。それらの回路ユニットは、加算器、減算器、またはXORゲートのようなデジタル論理素子と、読み出し回路または読み出し/書き込み回路からなる。本開示の回路ユニットは、スタンドアロン実施形態における、複数の、ビット・ノードから検査ノードへのメッセージの変換された絶対値および正負符号に対して、ならびに、連結実施形態におけるアプリオリ情報値の変換された絶対値および正負符号に対して、様々な動作を実行する。
以下の詳細説明および図面を参照することにより、本発明、ならびに本発明のさらなる特徴および利点について、より深い理解が得られるであろう。
LDPC行列Hの一般構造を示す図である。 LDPC符号の例示的な2部グラフ表現を示す図である。 例示的なハードウェア共用LDPC復号器アーキテクチャのブロック図である。 本発明の機能を組み込んだLDPC復号器のブロック図である。 LDPC復号器が軟入力軟出力(SISO)検出器と連結された、典型的な通信システムのブロック図である。 SISO検出器と連結されたLDPC復号器のブロック図である。
本発明は、ハードウェア共用および直列和積(sum−product)アーキテクチャを用いるLDPC復号の方法および装置を提供する。本開示のLDPC復号器は、従来の実装に比べて少ないメモリおよび少ないクロック・サイクルを用いる和積復号アルゴリズムを実行する。
低密度パリティ検査符号
以下の、LDPC符号およびLDPC復号の背景説明は、参照によって本明細書に組み込まれている、A.J.Blanksby、C.J.Howland、「A 690−mW 1−Gb/s 1024−b,Rate−1/2 Low−Density Parity−Check Decoder」、IEEE J.Solid−State Circuits、Vol.37、404〜412頁(2002年3月)に基づく。詳細については、Blanksby、Howlandの論文の全文を参照されたい。
LDPC符号の行列表現
LDPC符号は、線形ブロック符号である。すべての符号語x∈Cの集合は、次のように、パリティ検査行列Hのヌル空間を張る。
Hx=0 ∀x∈C (1)
LDPC符号のパリティ検査行列は、2値の疎行列である。
図1は、LDPC行列Hの一般構造100を示す。図1に示すように、パリティ検査行列Hの各行は、パリティ検査に対応し、集合要素hjiは、データ・ビットiがパリティ検査jに関与することを示す。nビットのブロックには、m個の冗長パリティ・ビットがある。符号レートは、次式で与えられる。
r=(n−m)/n (2)
パリティ検査行列Hの行および列の集合要素は、行および列の所望の重みプロファイルを満たすように選択され、行および列の重みは、それぞれ、所与の行および列にある集合要素の数として定義される。正則LDPC符号では、すべての行が一様の重みを有し、すべての列も同様である。行および列が一様の重みでない場合、そのLDPC符号は、非正則であると言われる。
LDPC符号のグラフ表現
LDPC符号は、2部グラフでも表現可能であり、その場合は、一方の集合のノードがパリティ検査制約を表し、他方の集合がデータ・ビットを表す。図2は、LDPC符号の例示的な2部グラフ表現200である。パリティ検査行列は、グラフの接続行列であり、その場合、Hのエントリhjiがセットされていれば(非ゼロであれば)、Hの列iに対応するビット・ノードiが、Hの行jに対応する検査ノードjに接続される。
LDPC符号の復号に用いられるアルゴリズムは、和積(sum−product)アルゴリズムとして知られる。このアルゴリズムで良好な復号性能を得るためには、LDPC符号のグラフ表現におけるサイクルの長さを、可能な限り長くすることが重要である。図2の例示的表現では、長さ4の例示的な短いサイクルが示されている。図2に示された長さ4のサイクルのような短いサイクルは、和積アルゴリズムの性能を低下させる。
和積アルゴリズム
和積アルゴリズムは、LDPC符号を復号する反復アルゴリズムである。和積アルゴリズムは、メッセージ・パッシング・アルゴリズムまたは確率伝搬としても知られる。和積アルゴリズムの詳細については、たとえば、それぞれ参照によって本明細書に組み込まれている、A.J.Blanksby、C.J.Howland、「A 690−mW 1−Gb/s 1024−b,Rate−1/2 Low−Density Parity−Check Decoder」、IEEE J.Solid−State Circuits、Vol.37、404〜412頁(2002年3月)、D.E.Hocevar、「LDPC Code Construction With Flexible Hardware Implementation」、IEEE Int’l Conf.on Comm.(ICC),Anchorage,AK、2708〜2712頁(2003年5月)を参照されたい。
ビット・ノードiから検査ノードjへのメッセージは、次式で与えられる。
Figure 2014099944
本明細書で用いられる表記は、本明細書の末尾にある表において定義されている。検査ノードjからビット・ノードiへのメッセージは、次式で与えられる。
Figure 2014099944
ここで、
Figure 2014099944
事後対数尤度比(log−likelihood ratio)(LLR)とも呼ばれる、ビットiについての事後情報値Λは、次式で与えられる。
Figure 2014099944
LDPC復号器
LDPC符号を復号する和積アルゴリズムを実装する際の重大な課題は、メッセージのパッシングを管理することである。検査ノードおよびビット・ノードの機能性はいずれも比較的単純なので、それらを個々に実現することは、少数のゲートだけで可能である。主たる課題は、機能ノード間のメッセージ・パッシングに必要な帯域幅を実現することである。
ハードウェア共用復号器アーキテクチャ
図3は、例示的なハードウェア共用LDPC復号器アーキテクチャ300のブロック図である。図3に示すように、一般化されたLDPC復号器アーキテクチャ300は、検査ノードまたはビット・ノードの機能性をそれぞれ実現する多数の機能単位310、320と、メッセージを格納してグラフ接続性を実現するメモリ構造350とを備える。制御ロジック330が、メモリ構造350の構成を制御する。ハードウェア共用LDPC復号器アーキテクチャ300の実装の詳細については、たとえば、E.Yeoら、「VLSI Architectures for Iterative Decoders in Magnetic Recording Channels」、IEEE Trans.On Magnetics、Vol.37、No.2、748〜755頁(2001年3月)を参照されたい。
そのようなハードウェア共用アーキテクチャは、復号器の面積を減らすことが確認されている。
修正されたLDPCパリティ検査式
本発明は、前述のLDPCパリティ検査式の各成分を再編成することにより、メモリおよびクロック・サイクルの要件の改善が可能であることを認識している。式(4)で示された検査ノードの計算は、次のように、いくつかの成分に分けることが可能である。
Figure 2014099944
ここで、ρi,jは、したがって、ビット・ノードiと検査ノードjとの間の、ビット・ノードから検査ノードへのメッセージQi,jの変換された絶対値であり、「||」は絶対値の表記である。
σi,j=sign(Qi,j) (6)
したがって、σi,jは、ビット・ノードiと検査ノードjとの間の、ビット・ノードから検査ノードへのメッセージQi,jの正負符号である。
Figure 2014099944
は、検査ノードjに接続されたすべてのビット・ノードについての、ビット・ノードから検査ノードへのメッセージの変換された絶対値の和として、検査ノードjについて計算される。
Figure 2014099944
所与の検査ノードjに対するSは、したがって、検査ノードjに接続されたすべてのビット・ノードについての、ビット・ノードから検査ノードへのメッセージの正負符号の積である。
次に、検査ノードjからビット・ノードiへのメッセージの絶対値および正負符号は、次式で与えられる。
Figure 2014099944
sign(Rj,i)=S・σi,j (10)
したがって、式(4)による、検査ノードからビット・ノードへのメッセージの従来の計算では、現在のビット・ノードiが計算から除外されるが(l∈C、l≠i)、本発明では、検査ノードjに接続されたすべてのビット・ノードlについて、ビット・ノードから検査ノードへのメッセージの変換された絶対値ρl,jの和として、中間値Pが計算され、その後、Pからρi,jを差し引くことにより、検査ノードjからビット・ノードiへのメッセージRj,iの絶対値が計算される。
この例示的実施形態では、ビット・ノードの計算は、2の補数の形で実行され、検査ノードの計算は、符号・絶対値(sign magnitude)(SM)の形で実行される。
直列和積アーキテクチャを有するLDPC復号器
図4は、本発明の機能を組み込んだLDPC復号器400のブロック図を示す。図4に示されたLDPC復号器400の例示的実施形態は、d=3およびB={j1,j2,j3}の場合の例を示す。要素430、435、440、450、470、475、478、および480は、並列の検査ノード更新ユニットを備える検査ノード更新ブロックを形成する。各時間サイクルにおいて、1つのビット・ノードに関係する計算が実行される。したがって、ビット・ノード1からビット・ノードnまでについての計算をすべて実行するには、nサイクルかかる。ビット・ノード1は、1番目の時間サイクルの間に計算されるものとする。そして、(n・(k−1)+i)番目の時間サイクルにおいて、ビット・ノード更新ユニット410は、k番目の反復におけるi番目のビット・ノードに対応するd個のメッセージ
Figure 2014099944
,j∈Bを生成する。これらd個のメッセージは、ステージ430において、2の補数による数表現から、符号・絶対値による数表現に変換される。絶対値部分は、関数φを実行する、並列の変換ユニット435−1〜435−3に送られ、これらのユニット435からの出力は、式(5)で定義されるように、
Figure 2014099944
,j∈Bである。
これらの
Figure 2014099944
,j∈Bは、加算器および読み出し/書き込み回路からなる、d個の変換済み絶対値更新ユニット440に供給され、そこで、検査ノードjに接続されたすべてのビット・ノードにわたる和
Figure 2014099944
が計算され、後で、次の反復のために
Figure 2014099944
が取り出される。並列の変換済み絶対値更新ユニット440は、メモリ460内のm個のメモリ要素のうちの任意のd個の要素にアクセスすることが可能であり、各要素は、qビットを格納し、qは、この例示的実施形態において
Figure 2014099944
を表すために用いられるビットの数である。これらの並列の変換済み絶対値更新ユニット440は、反復の最後(すなわち、(n・k)番目の時間サイクル)に、式(7)において定義される
Figure 2014099944
,j∈1...mがm個のメモリ要素に格納されるように、関係するメモリ要素を更新する。言い換えると、これらのメモリ要素は、関係するρの値の累積和を保持する。
k番目の反復におけるメモリ要素j内の中間値が、i=1...nに対して
Figure 2014099944
で与えられる場合、(n・(k−1)+i)番目の時間インスタンスにおける累積和は、次式で与えられる。
Figure 2014099944
これは、反復の最後(たとえば、(n・k)番目の時間インスタンス)には、次式のようになる。
Figure 2014099944
ビット・ノードから検査ノードへのメッセージ
Figure 2014099944
,j∈Bの正負符号は、式(6)で定義される
Figure 2014099944
,j∈Bであって、以下のように処理される。前述の手順と同様に、
Figure 2014099944
,j∈Bは、別の、XORゲートおよび読み出し/書き込み回路からなる、d個の正負符号更新ユニット450の集合に供給される。これらの並列の正負符号更新ユニットは、反復の最後に、式(8)で定義される
Figure 2014099944
,j∈1...mがm個のメモリ要素に格納されるように、メモリ460内の関係するメモリ要素を更新し、各メモリ要素は、1ビットを格納する。言い換えると、これらのメモリ要素は、正負符号ビットσの値の累積和を保持する。積は、XORゲートによって得られる。前のパラグラフで説明したように、k番目の反復におけるメモリ要素jの中間値が、i=1...nに対して
Figure 2014099944
で与えられる場合、累積積は、次式で与えられる。
Figure 2014099944
これは、反復の最後(たとえば、(n・k)番目の時間インスタンス)には、次式のようになる。
Figure 2014099944
各時間サイクルにおいて計算された
Figure 2014099944
,j∈Bは、先入れ先出し(FIFO)バッファ420−1(図4のバッファ−1)にも送られる。FIFO 420−1は、d・q個の列(この例示的実施形態では、サイクルごとにd個のρの値が生成され、各ρはqビットで表される)と、n個の行とからなる。時間サイクルn・(k−1)+iにおいて、
Figure 2014099944
,j∈Bの集合は、FIFO 420−1の後部に供給され、前の反復からの
Figure 2014099944
,j∈Bの集合は、バッファ420−1の前部から読み出される。(n・k)番目の時間サイクルには、すべての
Figure 2014099944
,j=1...mがメモリ460において使用可能であり、すべての
Figure 2014099944
,i=1...n,j∈Bが第1のFIFOバッファ420−1において使用可能である。そして、FIFO 420−1の最上行が、
Figure 2014099944
,j∈Bを保持し、その次の行が、
Figure 2014099944
,j∈Bを保持し、バッファ420−1の最後の行が、
Figure 2014099944
,j∈Bからなる。
各時間サイクルにおいて計算された
Figure 2014099944
,j∈Bは、別のFIFOバッファバッファ420−2(図4のバッファ−2)に供給される。第2のFIFOバッファ420−2は、d個の1ビット列(各σi,jは1ビットで表されるので)と、n個の行とからなる。
時間サイクルn・(k−1)+iにおいて、
Figure 2014099944
,j∈Bの集合は、FIFO 420−2の後部に供給され、前の反復からの
Figure 2014099944
,j∈Bの集合は、バッファ420−2の前部から読み出される。
次に、前の反復k−1からの、メモリ460に保存された
Figure 2014099944
,j=1...mと、第1のFIFOバッファ420−1に保存された
Figure 2014099944
,j∈Bとから、検査ノードからビット・ノードへのメッセージ
Figure 2014099944
の絶対値の計算の手順を説明する。必要な
Figure 2014099944
,j∈Bは、メモリ460から読み出され、
Figure 2014099944
,j∈Bは、第1のFIFOバッファ420−1から読み出される。次に、並列の、変換された絶対値の減算ユニット470−1〜470−3によって、各j∈Bについての差
Figure 2014099944
が計算され、対応する結果が、関数φを実行する、並列の変換ユニット475−1〜475−3に渡される。これらの変換ユニット475の出力は、(k−1)番目の反復における、d個の検査ノードからi番目のビット・ノードへの対応するメッセージの絶対値、すなわち、式(9)による
Figure 2014099944
,j∈Bである。
(k−1)番目の反復における、検査ノードからビット・ノードへのメッセージの正負符号(sign
Figure 2014099944
)は、同様に計算される。必要な
Figure 2014099944
,j∈Bは、メモリ460から読み出され、
Figure 2014099944
,j∈Bは、第2のFIFOバッファ420−2から読み出される。次に、(この例示的実施形態では、それぞれがXORゲートを用いる)並列の正負符号処理ユニット478−1〜478−3により、各j∈Biについて、積
Figure 2014099944
が計算される。これらの積は、(k−1)番目の反復における、d個の検査ノードからi番目のビット・ノードへの対応するメッセージの正負符号ビット、すなわち、式(10)によるsign
Figure 2014099944
,j∈Bである。
検査ノードからビット・ノードへのメッセージの正負符号および絶対値は、d個の、符号・絶対値から2の補数への変換ユニット480に渡される。これらのユニット480からの結果は、
Figure 2014099944
,j∈Bであり、これが、ビット・ノード更新ユニット410の入力になる。ビット・ノード更新ユニット410は、次式(式(3)も参照)に従って、k番目の反復についての、ビット・ノードから検査ノードへのメッセージ
Figure 2014099944
を計算する。
Figure 2014099944
メモリの必要量およびスループット
例示的な第1のFIFOバッファ420−1のサイズは、n・d・qビットであり、例示的な第2のFIFOバッファ420−2のサイズは、n・dビットである。
(j=1...m)に必要なメモリの量は、2・q・mビットであり、2の倍数は、繰り返しkおよびk−1に関係する値に用いられる。
(j=1...m)に必要なメモリの量は、2・mビットであり、2の倍数は、繰り返しkおよびk−1に関係する値に用いられる。
必要なメモリの総量は、(2・m+n・d)・(q+1)ビットである。
本開示の方法は、各時間サイクルにおいて、d個の、検査ノードからビット・ノードへのメッセージと、d個の、ビット・ノードから検査ノードへのメッセージとを計算する。したがって、1つのビット・ノード更新ユニット410で、1回の反復につき、nブロックの長さのデータを処理するのに、nサイクルかかる。
標準的なLDPC復号アーキテクチャと比較すると、本開示のアーキテクチャは、(2・m+n・d)・(q+1)ビットだけのメモリ空間を必要とし、1回の反復につきnサイクルしかかからない。これに対し、一般的な直列和積アーキテクチャは、2・n・d・(q+1)ビットのメモリ空間を必要とし、1回の反復につきm+nサイクルを必要とする。
直列和積アーキテクチャを有する、連結LDPC復号器
LDPC符号は、符号間干渉(ISI)およびノイズによって損傷したチャネルのビット・エラー・レートを改善するために用いられることが可能である。図5は、典型的な通信システム500を示し、システム500は、LDPC符号化器510、(符号間干渉およびノイズを持ち込む)ISIチャネル520、軟入力軟出力(SISO)検出器615、およびLDPC復号器600を備える。図5では、LDPC復号器600は、後で図6と併せて詳述されるように、SISO検出器615と連結される。SISO検出器615は、チャネル出力値および付帯情報値をLDPC復号器600から取り込み、これらは、アプリオリ情報値として使用される。SISO検出器615は、付帯情報値を出力し、これは、次の反復のためのアプリオリ情報値λとして、LDPC復号器600によって使用される。LDPC復号器からの付帯情報値は、SISO検出器用のアプリオリ情報値として使用され、SISO検出器からの付帯情報値は、LDPC復号器用のアプリオリ情報値として使用される。SISO検出器は、ISIチャネルを考慮に入れて、たとえば、当該技術分野では周知であるMAPアルゴリズムまたは軟出力ビタビ・アルゴリズム(SOVA)を用いて、付帯情報値を計算し、LDPC復号器は、LDPC符号を考慮に入れて、付帯情報値を計算する。このシステムの1回の反復は、SISO検出器615およびLDPC復号器600による、1回のデータの処理からなる。
図6は、本開示の、連結されたSISO検出器およびLDPC復号器のアーキテクチャを詳細に示す。SISO検出器615は、LDPC復号器600からのチャネル出力値および付帯情報値を取り込み、付帯情報値を出力する。この出力された付帯情報値は、次の反復のためのアプリオリ情報値λとして、LDPC復号器600によって使用される。本発明では、LDPC復号器600を通るすべてのパスにおいて、ビット・ノードiからその検査ノードへのd個のメッセージ、すなわち、
Figure 2014099944
,∀j∈Bが、ビット・ノードiのアプリオリ情報値またはアプリオリLLR λと等しいという事実、すなわち、次式が成り立つことを利用する。
Figure 2014099944
検査ノードの計算は、前述と同様に、部分に分割される。
Figure 2014099944
検査ノードjからビット・ノードiへのメッセージの正負符号および絶対値は、次式で与えられる。
Figure 2014099944
これらの
Figure 2014099944
,j∈Bを用いて、LDPC復号器からSISO検出器615に渡される付帯情報値は、付帯情報計算ユニット610によって、次式のように計算されることが可能である。
Figure 2014099944
この付帯情報値は、SISO検出器615によって、アプリオリ情報値として使用される。
図6は、連結システムとして提案されたアーキテクチャ600のブロック図を示す(d=3およびB={j1,j2,j3})。ビット・ノードiに関係する、各アプリオリLLR λは、SISO検出器615から出力される付帯情報値に等しく、2の補数から符号・絶対値への変換ユニット630に渡される。絶対値は、関数Fφを実行する変換ユニット635に送られ、ユニット635の出力は、式(17)で定義される
Figure 2014099944
である。k番目の反復およびi番目のビット・ノードについての変換された絶対値
Figure 2014099944
は、メモリ内の
Figure 2014099944
,∀j∈Bを更新する、d個の、変換済み絶対値更新ユニット640に供給される。同様に、sign
Figure 2014099944
は、別の、メモリ内の
Figure 2014099944
,∀j∈Bを更新する、d個の、正負符号更新ユニット650の集合に渡される。さらに、
Figure 2014099944
および
Figure 2014099944
が、第1のFIFOバッファ620−1および第2のバッファ620−2に、それぞれ供給される。
(k−1)番目の反復についての、検査ノードからビット・ノードへのメッセージ、すなわち、
Figure 2014099944
,j∈Bは、図4と併せて前述された手順と同様に計算される。しかしながら、第1のFIFOバッファ620−1から1つの値だけが使用され(絶対値を得るために
Figure 2014099944
が使用される)、第2のFIFOバッファ620−2から1つの値が使用される(正負符号を得るために
Figure 2014099944
が使用される)。したがって、FIFOバッファ620における必要メモリ量は、図4と併せて前述されたスタンドアロン・アーキテクチャの場合のd分の1である。
メモリの必要量およびスループット
例示的な第1のFIFOバッファ620−1のサイズは、n・qビットであり、例示的な第2のFIFOバッファ620−2のサイズは、nビットである。
(j=1...m)に必要なメモリの量は、2・q・mビットである。
(j=1...m)に必要なメモリの量は、2・mビットである。
必要なメモリの総量は、(2・m+n)(q+1)である。
本開示の方法は、各時間サイクルにおいて、d個の、検査ノードからビット・ノードへのメッセージと、付帯情報値とを計算する。したがって、1回の反復につき、nブロックの長さのデータを処理するのに、nサイクルかかる。
本開示のアーキテクチャは、式(17)〜(23)で定義される和積アルゴリズムを実行する。本開示の方法は、和積アルゴリズムにおいて最小LLR値だけが考慮される、WuとBurdによって提案された、あまり最適でない方法より、良好なエラー・レート性能を有する。さらに、WuとBurdによって提案された方法は、連結LDPC復号器システムにのみ当てはまる。本発明は、(2・m+n)・(q+1)だけのメモリ空間を必要とし、1回の反復につきnサイクルしかかからない。
表記
本明細書では、以下の表記を用いている。
iは、ビット・ノードのインデックスである。
jは、検査ノードのインデックスである。
kは、反復のインデックスである。
i,jは、ビット・ノードiから検査ノードjへのメッセージである。
i,jは、検査ノードjからビット・ノードiへのメッセージである。
λは、ビットiに関するアプリオリ情報値またはアプリオリ対数尤度比(LLR)である。
Λは、ビットiに関する事後情報値または事後LLRである。
Λext,iは、ビットiに関する付帯情報値または付帯LLRである。
は、ビット・ノードiに接続された検査ノードの集合である。
は、検査ノードjに接続されたビット・ノードの集合である。
nは、ビット・ノードの数である。
mは、パリティ検査ノードの数である。
は、パリティ検査行列の行重みである。
は、パリティ検査行列の列重みである。
ビット・ノードは、1...nである。
検査ノードは、1...mである。
本発明の例示的実施形態を、デジタル論理ユニットに関して説明してきたが、当業者であれば自明であるように、様々な機能を、デジタル・ドメインにおいてソフトウェア・プログラムの処理ステップとして、回路素子または状態機械によるハードウェアの形で、またはソフトウェアとハードウェアの組み合わせの形で、実装することが可能である。そのようなソフトウェアは、たとえば、デジタル信号プロセッサ、マイクロコントローラ、または汎用コンピュータの形で用いられることが可能である。そのようなハードウェアおよびソフトウェアは、集積回路内に実装される回路の中で実施されることが可能である。
したがって、本発明の機能は、方法、およびそれらの方法を実行する装置の形で実施される。本発明の1つまたは複数の態様は、たとえば、記憶媒体に格納されるコードであれ、機械にロードされ、かつ/またはその機械によって実行されるコードであれ、あるいは何らかの伝送媒体上を伝送されるコードであれ、プログラム・コードの形で実施されることが可能であり、そのプログラム・コードが、コンピュータのような機械にロードされ、その機械によって実行される場合は、その機械が、本発明を実行する装置になる。プログラム・コード・セグメントは、汎用プロセッサに実装される場合には、プロセッサとの組み合わせで、特定の論理回路と類似の動作を行う装置を提供する。
当該技術分野において知られているように、本明細書で説明された方法および装置は、それ自体が、コンピュータ可読媒体上で実施されるコンピュータ可読コード手段を有するコンピュータ可読媒体を含む、製品として、販売されることが可能である。コンピュータ可読プログラム・コード手段は、コンピュータ・システムと組み合わされて、本明細書で説明された方法を実施するか、本明細書で説明された装置を作成するステップのすべてまたは一部を実行するよう動作可能である。コンピュータ可読媒体は、記録可能媒体(たとえば、フロッピー(登録商標)・ディスク、ハード・ドライブ、コンパクト・ディスク、メモリ・カード、半導体デバイス、チップ、特定用途向け集積回路(ASIC))であってもよく、伝送媒体(たとえば、光ファイバを含むネットワーク、ワールドワイド・ウェブ、ケーブル、または時分割多重アクセス、符号分割多重アクセスなどを用いる無線チャネル、あるいは無線周波数チャネル)であってもよい。コンピュータ・システムでの使用に好適な、情報を記憶することが可能である、周知の、または開発された、任意の媒体を使用することが可能である。コンピュータ可読コード手段は、コンピュータが、磁気媒体上の磁気変動や、コンパクト・ディスクの表面の高さ変動のような、命令およびデータを読み取ることを可能にする、任意のメカニズムである。
メモリおよびバッファは、分散型であっても局所的であってもよく、プロセッサは、分散型であっても単独であってもよい。メモリおよびバッファは、電気的、磁気的、または光学的なメモリとして実装されてもよく、あるいはそれらまたは他のタイプの記憶装置の任意の組み合わせであってもよい。さらに、用語「メモリ」、「バッファ」、および「FIFOバッファ」は、媒体からの読み出し、または媒体への書き込みが可能な任意の情報を包含するのに十分であるよう広く解釈されなければならない。この定義によれば、ネットワーク上の情報も、関連付けられたプロセッサがネットワークから取得できることから、メモリ内にある。
本明細書で図示および説明された実施形態および変形形態は、本発明の原理の例示に過ぎないこと、ならびに、本発明の範囲および趣旨から逸脱することなく、様々な修正が、当業者によって実施可能であることを理解されたい。

Claims (6)

  1. 相互に接続されたビット・ノードおよび検査ノードを有する2部グラフを用いて記述されることが可能な符号を復号する方法であって、
    検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへのメッセージの絶対値を計算するステップであって、前記絶対値は、ビット・ノードiおよび検査ノードjについての、ビット・ノードから検査ノードへのメッセージの変換された絶対値を除く、前記検査ノードjに接続された複数のビット・ノードについての、ビット・ノードから検査ノードへの前記メッセージの変換された絶対値の和に基づき、前記変換された絶対値の各々がビット・ノードから検査ノードへのメッセージの対応する絶対値を当てはめられる非線形関数の結果を含むステップと、
    前記検査ノードjに接続された複数のビット・ノードの中の、ビット・ノードから検査ノードへのメッセージの正負符号の積Sと、ビット・ノードiおよび検査ノードjについての、ビット・ノードから検査ノードへの前記メッセージの符号とを掛け合わせることにより、検査ノードjからビット・ノードiへの、検査ノードからビット・ノードへの前記メッセージの正負符号を計算し、1番目のビット・ノード更新ユニットに接続される複数の並列の検査ノード更新ユニットが前記検査ノードからビット・ノードへのメッセージを計算するステップとを含む方法。
  2. 相互に接続されたビット・ノードおよび検査ノードを有する2部グラフを用いて記述されることが可能な符号を復号する復号器であって、
    1番目のビット・ノード更新ユニットと、
    前記ビット・ノード更新ユニットに接続されて、1つまたは複数の変換された絶対値に基づいて、複数の、検査ノードからビット・ノードへのメッセージを計算する、複数の並列の検査ノード更新ユニットと、を備え、前記変換された絶対値の各々がビット・ノードから検査ノードへのメッセージの対応する絶対値を当てはめられる非線形関数の結果を含む復号器。
  3. ビット・ノードiと検査ノードjの間の前記ビット・ノードから検査ノードへのメッセージQi,jの前記変換された絶対値ρi,jが、
    Figure 2014099944
    但し、記号||は絶対値であることを示す記号である、
    として計算される、請求項1に記載の方法。
  4. 前記非線形関数が、-log tanh(x/2)および
    Figure 2014099944
    の内の、いずれか又は両方を含む、請求項1に記載の方法。
  5. ビット・ノードiと検査ノードjの間の前記ビット・ノードから検査ノードへのメッセージQi,jの前記変換された絶対値ρi,jが、
    Figure 2014099944
    但し、記号||は絶対値であることを示す記号である、
    として計算される、請求項2に記載の復号器。
  6. 前記非線形関数が、-log tanh(x/2)および
    Figure 2014099944
    の内の、いずれか又は両方を含む、請求項2に記載の復号器。
JP2014044504A 2006-07-31 2014-03-07 ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置 Pending JP2014099944A (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/496,121 US7647548B2 (en) 2006-07-31 2006-07-31 Methods and apparatus for low-density parity check decoding using hardware-sharing and serial sum-product architecture
US11/496,121 2006-07-31

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2007198612A Division JP2008035527A (ja) 2006-07-31 2007-07-31 ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置

Publications (1)

Publication Number Publication Date
JP2014099944A true JP2014099944A (ja) 2014-05-29

Family

ID=38973433

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2007198612A Pending JP2008035527A (ja) 2006-07-31 2007-07-31 ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置
JP2014044504A Pending JP2014099944A (ja) 2006-07-31 2014-03-07 ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2007198612A Pending JP2008035527A (ja) 2006-07-31 2007-07-31 ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置

Country Status (5)

Country Link
US (1) US7647548B2 (ja)
JP (2) JP2008035527A (ja)
KR (1) KR101459135B1 (ja)
CN (1) CN101154948B (ja)
DE (1) DE102007035210A1 (ja)

Families Citing this family (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8341506B2 (en) * 2007-03-30 2012-12-25 HGST Netherlands B.V. Techniques for correcting errors using iterative decoding
US8739009B1 (en) * 2007-12-27 2014-05-27 Marvell International Ltd. Methods and apparatus for defect detection and correction via iterative decoding algorithms
US8230312B1 (en) * 2008-01-09 2012-07-24 Marvell International Ltd. Iterative decoder memory arrangement
US8130228B2 (en) * 2008-06-13 2012-03-06 International Business Machines Corporation System and method for processing low density parity check codes using a deterministic caching apparatus
US8429500B2 (en) 2010-03-31 2013-04-23 Lsi Corporation Methods and apparatus for computing a probability value of a received value in communication or storage systems
US8775913B2 (en) 2010-03-31 2014-07-08 Lsi Corporation Methods and apparatus for computing soft data or log likelihood ratios for received values in communication or storage systems
US8504885B2 (en) 2010-03-31 2013-08-06 Lsi Corporation Methods and apparatus for approximating a probability density function or distribution for a received value in communication or storage systems
JP5310701B2 (ja) * 2010-10-29 2013-10-09 株式会社Jvcケンウッド 復号装置および復号方法
US9362933B1 (en) 2011-07-12 2016-06-07 Marvell International Ltd. Noise-predictive detector adaptation with corrected data
US8996952B2 (en) 2012-01-04 2015-03-31 Marvell World Trade Ltd. High-throughput iterative decoding's defect scan in retry mode of storage system channel
US9633740B1 (en) * 2016-02-11 2017-04-25 Seagate Technology Llc Read retry operations where likelihood value assignments change sign at different read voltages for each read retry

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004313170A (ja) * 2002-07-31 2004-11-11 Fuji Oil Co Ltd 大豆ホエー分画物の製造法
WO2006059688A1 (ja) * 2004-12-02 2006-06-08 Mitsubishi Denki Kabushiki Kaisha 復号装置及び通信装置

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6539367B1 (en) * 2000-05-26 2003-03-25 Agere Systems Inc. Methods and apparatus for decoding of general codes on probability dependency graphs
US7246304B2 (en) * 2001-09-01 2007-07-17 Dsp Group Inc Decoding architecture for low density parity check codes
US7178080B2 (en) * 2002-08-15 2007-02-13 Texas Instruments Incorporated Hardware-efficient low density parity check code for digital communications
CN100521553C (zh) * 2003-05-13 2009-07-29 索尼株式会社 解码设备和解码方法
JP4224777B2 (ja) * 2003-05-13 2009-02-18 ソニー株式会社 復号方法および復号装置、並びにプログラム
JP4225163B2 (ja) * 2003-05-13 2009-02-18 ソニー株式会社 復号装置および復号方法、並びにプログラム
JP4296949B2 (ja) 2004-02-03 2009-07-15 ソニー株式会社 復号装置及び方法、並びに情報処理装置及び方法
CN100472972C (zh) * 2004-05-03 2009-03-25 美国博通公司 可操作地将ldpc编码信号解码的解码器
FR2871976B1 (fr) * 2004-06-22 2006-08-11 St Microelectronics Sa Decodeur ldpc
JP4282558B2 (ja) * 2004-06-30 2009-06-24 株式会社東芝 低密度パリティチェック符号復号器及び方法
US7181676B2 (en) * 2004-07-19 2007-02-20 Texas Instruments Incorporated Layered decoding approach for low density parity check (LDPC) codes
US7760880B2 (en) * 2004-10-13 2010-07-20 Viasat, Inc. Decoder architecture system and method
US7451361B2 (en) * 2005-01-27 2008-11-11 General Instrument Corporation Method and apparatus for forward error correction in a content distribution system
JP4526451B2 (ja) * 2005-06-30 2010-08-18 ルネサスエレクトロニクス株式会社 復号装置と方法並びにプログラム

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004313170A (ja) * 2002-07-31 2004-11-11 Fuji Oil Co Ltd 大豆ホエー分画物の製造法
WO2006059688A1 (ja) * 2004-12-02 2006-06-08 Mitsubishi Denki Kabushiki Kaisha 復号装置及び通信装置

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
JPN6012039548; Jun Zheng et al.: 'LDPC-coded MIMO systems with unknown block fading channels: soft MIMO detector design, channel estim' Signal Processing, IEEE Transactions on Volume:54, Issue:4, 200604, pp.1504-1518 *
JPN6013010980; Sedat O.: 'Decoder architecture for array-code-based LDPC codes' Global Telecommunications Conference, 2003. GLOBECOM '03. IEEE Vol.4, 20031205, pp.2046-2050 *
JPN6013057661; Engling Yeo et al.: 'VLSI architectures for iterative decoders in magnetic recording channels' Magnetics, IEEE Transactions on Vol.37, No.2, 200103, pp.748-755 *
JPN6015028067; 和田 知久 他: 'IEEE802.16e対応LDPCデコーダの高性能化に関する検討' 電子情報通信学会技術研究報告 Vol.105, No.644, 20060302, pp.55-60 *

Also Published As

Publication number Publication date
CN101154948A (zh) 2008-04-02
US7647548B2 (en) 2010-01-12
DE102007035210A1 (de) 2008-02-28
US20080052595A1 (en) 2008-02-28
CN101154948B (zh) 2015-12-16
KR101459135B1 (ko) 2014-11-07
JP2008035527A (ja) 2008-02-14
KR20080011631A (ko) 2008-02-05

Similar Documents

Publication Publication Date Title
JP2014099944A (ja) ハードウェア共用および直列和積アーキテクチャを用いる低密度パリティ検査復号の方法および装置
US20230336189A1 (en) Low density parity check decoder
EP1442527B1 (en) Node processors for use in parity check decoders
Yuan et al. Architecture optimizations for BP polar decoders
Abbas et al. High-throughput and energy-efficient belief propagation polar code decoder
Blanksby et al. A 690-mW 1-Gb/s 1024-b, rate-1/2 low-density parity-check code decoder
US8683303B2 (en) Operational parameter adaptable LDPC (low density parity check) decoder
US7219288B2 (en) Running minimum message passing LDPC decoding
US8572463B2 (en) Quasi-cyclic LDPC encoding and decoding for non-integer multiples of circulant size
US8826094B2 (en) Accumulating LDPC (low density parity check) decoder
JP4651600B2 (ja) 低密度パリティ検査復号器における検査ノード更新方法
US20110131462A1 (en) Matrix-vector multiplication for error-correction encoding and the like
EP2573943B1 (en) Power-optimized decoding of linear codes
US20170134048A1 (en) Message-passing based decoding using syndrome information, and related methods
Sarkis et al. Reduced-latency stochastic decoding of LDPC codes over GF (q)
Sarkis et al. Unrolled polar decoders, part ii: Fast list decoders
Chen et al. Partly parallel overlapped sum-product decoder architectures for quasi-cyclic LDPC codes
US10185623B2 (en) Reading and writing to NAND flash memories using charge constrained codes
CN114268325A (zh) 使用索引消息进行ldpc解码的方法和设备
Zarkeshvari Implementation of iterative decoding algorithms on digital VLSI platforms
趙雄心 Research on LDPC Decoder Design Methodology for Error-Correcting Performance and Energy-Efficiency
Chen Modified VLSI designs for error correction codes
Decoders Kiran Gunnam

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20140404

RD03 Notification of appointment of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7423

Effective date: 20140819

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20140917

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20150212

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20150224

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20150515

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20150714

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20151208