JP2007295564A - 低密度のパリティ検査コードを用いた復号器 - Google Patents

低密度のパリティ検査コードを用いた復号器 Download PDF

Info

Publication number
JP2007295564A
JP2007295564A JP2007109807A JP2007109807A JP2007295564A JP 2007295564 A JP2007295564 A JP 2007295564A JP 2007109807 A JP2007109807 A JP 2007109807A JP 2007109807 A JP2007109807 A JP 2007109807A JP 2007295564 A JP2007295564 A JP 2007295564A
Authority
JP
Japan
Prior art keywords
error correction
variable node
data
calculated
items
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
JP2007109807A
Other languages
English (en)
Inventor
Harihara Gopalakrishnan Subramanyam
ハリハラ ゴパラクリシュナン スブラマンヤム
Girish Mariswamy Chandra
ギリッシュ マリスワミー チャンドラ
Venkataratnam Balaramakrishnaiah Nimmagadda
ヴェンカタラットナム バララマクリッシュナイアー ニムマガッダ
Pramod Nanje Gowda
プラモド ナンジェ ゴウダ
Purushothaman Balamuralidhar
プルショタマン バラムラリドハル
Suryanarayana Vishnumurthy Adiga
スリャナラヤナ ヴィシュヌムルティー アディガ
Ravindra Purushothama
ラヴィンドラ プルショータマ
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.)
Tata Consultancy Services Ltd
Original Assignee
Tata Consultancy Services Ltd
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 Tata Consultancy Services Ltd filed Critical Tata Consultancy Services Ltd
Publication of JP2007295564A publication Critical patent/JP2007295564A/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
    • 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
    • H03M13/1134Full parallel processing, i.e. all bit nodes or check nodes are processed in parallel
    • 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/1105Decoding
    • H03M13/1111Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms
    • H03M13/1117Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms using approximations for check node processing, e.g. an outgoing message is depending on the signs and the minimum over the magnitudes of all incoming messages according to the min-sum rule
    • H03M13/112Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms using approximations for check node processing, e.g. an outgoing message is depending on the signs and the minimum over the magnitudes of all incoming messages according to the min-sum rule with correction functions for the min-sum rule, e.g. using an offset or a scaling factor
    • 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
    • H03M13/1117Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms using approximations for check node processing, e.g. an outgoing message is depending on the signs and the minimum over the magnitudes of all incoming messages according to the min-sum rule
    • H03M13/1122Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms using approximations for check node processing, e.g. an outgoing message is depending on the signs and the minimum over the magnitudes of all incoming messages according to the min-sum rule storing only the first and second minimum values per check node
    • 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/65Purpose and implementation aspects
    • H03M13/6577Representation or format of variables, register sizes or word-lengths and quantization
    • H03M13/658Scaling by multiplication or division
    • 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/6577Representation or format of variables, register sizes or word-lengths and quantization
    • H03M13/6583Normalization other than scaling, e.g. by subtraction

Landscapes

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

Abstract

【課題】LDPCを用いた誤り訂正において、複雑性および所要時間の低減。
【解決手段】min-Sumアルゴリズムを半並列で実施し、次の手段を持つ。多重チャネルからチャネル値を抽出するチャネル値抽出手段、チャネル値を尤度値を含むデータに変換する変換装置手段、尤度値を再配置する可変ノードバンク手段、データからブロックを選ぶバンク・セレクタ手段、データからサブブロックを選ぶロケーション・ポインタ手段、可変ノード計算手段、検査ノード計算手段、上記の手段の間のパラメータと一緒にアイテムを転送する切替ネットワーク、検査ノード手段および可変ノード手段の計算エンジン、計算ノード手段および可変ノード手段の比較手段、可変ノードバンク手段から復号データを受信器に移動する移送手段。
【選択図】図3

Description

本発明は情報の復号化のためのシステムに関する。
特に、本発明は低密度のパリティ検査コードを用いた復号化システムに関する。
コンピュータ・ネットワークの使用および実施がきわめて一般に普及するようになった。例えばローカル・エリア・ネットワーク(LAN)、メトロポリタン・エリア・ネットワーク(MAN)、ワイヤレスLAN(WLAN)などのネットワークは、データにアクセスするために広く実行されている。このようなネットワークの使用により、例えばWi‐FiおよびWiMAXのような通信の分野において様々な国際標準の開発に至った。
WiMAXは、ワイヤレスのメトロポリタン・エリア・ネットワーク(MAN)技術である。それは、Wi−Fiホットスポットを互いに、および、インターネットの別の部分に連結し、ケーブルおよびDSLのワイヤレス代替物を提供することができる。WiMAXは、最高50km(31マイル)の直線のサービスエリア範囲を提供し、直接の見通しなしでのユーザ間の接続性を許容する。技術は、WiMAX支持者によれば、1Mbit/秒のDSL‐レベル接続性で同時に60以上の企業および1000以上の家庭をサポートするのに十分な帯域幅である最高70Mbit/秒の共有データ速度を提供することが要求されてきた。現実の世界での試験は、しかしながら、提供された現場の状態次第で500kbit/秒および2Mbit/秒間の実用的な最大データ速度を示す。
またWiMAXはVoIP、ビデオおよびインターネット接続の同時的なブロードバンド・サービス供給のための相互浸透を可能にする。既存の物理的なケーブルまたは電話網のない領域でさえも、WiMAXは、互いに範囲内であるネットワーク間のアクセスを可能にする。WiMAXアンテナは、すでにその場所にあるセル配列の機能を損なわずにセル塔を共有する。WiMAXアンテナはまた、光ファイバ光学ケーブルまたは方向的なマイクロ波リンクを経てインターネット・バックボーンに連結される可能性がある。WiMAXは、様々なデータ集中的な用途のための帯域幅の増加も容易にする。
WiMAXは、固定およびモバイルMAN(メトロポリタン・エリア・ネットワーク)ブロードバンド・ワイヤレス・アクセス(BWA)のための出現した規格であるIEEE 802.16の規格系統と同義になった。本来の802.16および続いて修正された802.16a規格は両方、固定されたBWAのために使用される。BWAがますます住居の用途を満たし、後者は見通しなし(NLOS)用途の要求を満たす。最新の802.16e修正は、WiMAXシステムの移動性(約120km/時での乗物の速度での移動性)を支える。802.16e規格は、Wi‐Fi(ワイファイ)ホットスポットの外にローミングしつつ、ユーザのハードウェア(ノート、パーソナル携帯情報機器(PDA))が高速インターネットにアクセスするのを可能にする。802.16の規格は、様々なチャネル符号化オプションで高速のデータ速度(約70Mbpsまで)を支える。必須の方式は、畳み込み符号である。回旋状のターボ・コード、ターボ製品コードおよびLDPCコードは、任意である。これらの任意のコードは、極端に弱まるチャネルの堅固性を保証するために使用することができる。
LDPCコードは、1960年代初期にギャラガーによって元々提案された直線のブロック・コードである。それらのパリティ検査マトリクスは、希薄であり、低い密度を有する。本来のコードは、均一の縦列およびパリティ検査マトリクスの低い重さを有する規則的なコードであった。近年これらのコードは、容量接近性能を有して、ターボ・コードの競争者として出現した。LDPCコードのより良好な性能は、符号および復号化信号処理の適当な選択によって達成される。アルゴリズムを復号化している普及しているLDPCは、また、sum−productアルゴリズムと称する信念伝播アルゴリズムである。sum−productアルゴリズムは、パリティ検査マトリクスを表わす二部に分かれたグラフであり、可変ノードおよび検査ノードから構成されるタナー・グラフで機能するメッセージ通過アルゴリズムである。二部に分かれたグラフは特別なグラフであり、ここで、頂点の集合は、同じ集合の2つの頂点が決して端を共有しないで、2つの共通の要素をもたない集合に分割されることができる。
従来技術
LDPC符号復号器ハードウェア実施の主な挑戦は、反復的な信念伝播(BP)復号化の間、効果的にメッセージを通過させることである。復号化のシステムおよび装置は、通常3つの方式を使用する:(1)並列、(2)直列、および、(3)半分並列。
完全に並列の復号器は、ハードウェアにLDPC符号の二部に分かれたグラフのインスタンスを直接生成する。各々の個別的な可変ノードまたは検査ノードは、ノードの機能単位として物理的に実行され、すべての単位体は、二部に分かれたグラフ接続性を反映している相互接続ネットワークで連結される。中心の記憶ブロックがメッセージを格納する必要性はない。それらは、処理ユニット近くにラッチされることができる。このような完全に並列の復号器は、ビット/秒に関してきわめて高い復号化スループットを達成することができる。しかしながら、すべての処理ユニットおよび相互接続ルート割当て物理的な実施に起因する実施の領域により、大きいブロック長のためのこの方法が実行不可能になる。さらに、並列のハードウェア設計は、特定のパリティ検査マトリクスに固定する。これは、符号のブロック長または率が変化する場合に必要とされる再構成可能性を禁止する。
1つの可変ノードの計算の単位(VCU)および1つの検査ノードの計算の単位(CCU)のみを有するのに十分であるので、完全に直列のアーキテクチャはより小さい領域を有する。完全に直列の方法は、ほんの少数の機能単位だけが使用のために得られるデジタル・シグナル・プロセッサのために適切である。しかしながら、復号化の速度は、直列復号器においてきわめて低い。
sum−productアルゴリズムを使用する従来技術システムまたは装置は、タナー・グラフを使用するように適応する手段を組み込む。装置は初期化および手段のためのメカニズムを有し、ここで、各々の繰り返しメッセージ通過は、反復の前半において各々の検査ノードからすべての隣接した可変ノードまで発生し、反復の後半において各々の可変ノードからその隣接した検査ノードまで発生する。装置はまた、いくつかの停止基準を有してメッセージの繰り返しの反復がグラフの端に沿って通過するメカニズムを有する。
sum−productアルゴリズムの実施に関与するステップは、以下において符号の大きさの処理形状のために提供される:
初期設定: T(0)n,m = In; E(0) n,m = 0
反復:
反復カウンタ: l=1, 2, …… lmax,
検査ノードの改訂規定:
Figure 2007295564
可変ノードの改訂規定:
Figure 2007295564
最新の可変ノードの改訂規定:
Figure 2007295564
上記の式において、Tn,mは、可変ノードnによってその連結された検査ノードmに送られた情報である。En,mは、検査ノードmから連結された可変ノードnまで通されるメッセージ(ビットn上のパリティ検査mによって提供される情報)である。M(n)は、可変ノードnに連結される検査ノードの集合である。N(m)は、x>0で、
Figure 2007295564
において検査ノードmに連結される可変部分ノードの集合である。
は、チャネル尤度比であり、チャネルに従って得ることができる(例えば加算性ホワイトガウスノイズ(AWGN))。「\」は、通常の排除符号である。「l」は、反復の数であるlmaxを有する反復数を示す。検査ノードの計算過程はより複雑であることが観察される。非線形関数
Figure 2007295564
は、ルックアップ・テーブル(LUT)を使用して実行される。
しかしながら、復号化するための和積ステップを用いた従来技術装置の使用は、以下に要約されることができる多くの不都合を有する:
(i) 反復するごとに、装置はルックアップ・テーブルの参照を必要とする。
(ii) 反復するごとに、装置は尤度比を計算する必要がある。
(iii) 装置は、尤度比の計算ための計算手段を必要とする。
(iv) 装置は、計算されるすべての尤度比に関する値を格納するための格納手段を必要とする。
(v) 装置は、すべての反復に関連があるノイズ相違値を計算する他の計算手段を必要とする。
上述した不都合のため、LDPCコード復号化のために必要とされる複雑性および時間は相当に増加する。
米国特許第7,137,060号は、低密度のパリティ検査マトリクスにより生じた符号化ビットを複合化する順方向誤り訂正の方法を開示している。方法は、各々の符号化ビットの尤度比値への変換および変換された値の可変ノードへの適用;可変ノードに適用されるメッセージの検査ノードへの供給、メッセージの中の最小値を有するメッセージの点検、および最小値を有するメッセージの符号の決定;検査ノードにおける更新されたメッセージの受容、受容したメッセージの符号および初期のメッセージの符号の加算、すべての符号が同一の場合、1の重み係数の適用、および、すべての符号が同一でない場合、重み係数を適用することによる可変ノードのメッセージの更新;初期の入力値のLLR値の決定;および可変ノードの値の明確な決定、明確な決定値上でのパリティ検査の実行、および、誤りが発生しない場合、復号化の停止からなる。本出願において必要とされる処理時間は、関係する計算の複雑性および数のため、より長い。
本発明は、従来技術の制限を克服する目的を有する。
本発明の目的は、WiMAXのためのLDPCコードの復号化するための半並列処理方法を用いて復号化装置およびシステムを提供することである。
本発明の他の目的は、802.16/802.16a規格において提案されるように、異なるブロック長および異なるコード率のために使われることができる再構成可能な構成を得ることである。
他の目的は、順番にタナー・グラフ接続性を達成するのを助けることができる「ロケーション・ポインタ」および「バンク・セレクタ」のための入力を得る手段を提供することである。
本発明の別の目的は、ビット誤り率およびフレーム誤り率を減少するシステムを提供することである。
本発明の別の目的は、ルックアップ・テーブルの使用を取り除き、したがってメモリ必要条件を減少させるシステムを提供することである。
本発明は、多重チャネルにおいて復号化伝達されたデータのための誤り訂正システムを認識する。
本発明によれば、多重チャネルにおいて復号化伝達されたデータのためのシステムのための誤り訂正システムが提供される。
一般的に、チャネル値抽出手段は、前記多重チャンネルで伝達されたデータからチャネル値を抽出し、前記チャネル値を中継するために提供される。
一般的に、変換装置手段は、前記チャネル値を受容し、前記チャネル値を尤度比値を含むデータへ変換するために提供される。
一般的に、可変ノードバンク手段は、前記変換装置手段から一組の尤度比値を受容し、第2のデータを形成する別々に番号をつけられたブロックおよびサブブロックにおいて指定されたパラメータを有するアイテムとして前記値を再配置するように適応する。
一般的に、バンク・セレクタ手段は、所定の方法で前記第2のデータからブロックを選ぶように適応する。
一般的に、ロケーション・ポインタ手段は、所定の方法で前記第2のデータからサブブロックを選ぶように適応する。
一般的に、可変ノードの計算手段は、格納手段および計算エンジンを有して提供される。
一般的に、検査ノード計算手段は、格納手段および計算過程エンジンを有して提供される。
一般的に、切替ネットワーク手段は、所定の方法で、可変ノードバンク手段、可変ノード計算手段、検査ノード計算手段、および、検査ノードバンク手段間で、それらのパラメータと共に一組のアイテムを転送するように適応する。
一般的に、検査ノード計算手段の前記計算エンジンは、前記選択されたアイテムおよび指定されたパラメータを受容するように適応し、さらに所定の方法で第1の計算されたパラメータを有する一組の第1の計算されたアイテムを含む第1の計算された出力を計算するように適応する。
一般的に、第1の比較手段は、所定の方法で、一組の結果として生じるアイテムを有する結果として生じる出力を提供するため、指定されたパラメータに関する第1の計算されたパラメータと前記検査ノード計算手段での格納のため結果として生じるパラメータを比較するために提供される。
一般的に、可変ノード計算手段の前記計算エンジンは、第2の計算されたパラメータを有する第2の計算されたアイテムの集合を有する第2の計算された出力を所定の方法で計算するため、結果として生じるパラメータを有する結果として生じるアイテムの前記集合を受容するように適応する。
一般的に、第2の比較手段は、所定の方法で、第2の計算されたパラメータおよび指定されたパラメータ間の誤りを比較し、誤りのない復号化データを形成するため、前記可変ノード計算手段から前記可変ノードバンク手段へのアイテムの誤りのない通過を選択的に許容するように適応する。
一般的に、移送手段は、前記可変ノードバンク手段から誤りのない修正データを受信器へ移動するために提供される。
一般的に、ロード手段は、可変ノードバンク手段に連続的に前記尤度比値をロードするために提供される。
一般的に、同期手段は、データを1つの場所から時限式に他の場所まで集合的に移動するために提供される。
一般的に、反復手段は、誤りのない復号化データを得るために計算の全体の集合を反復するように適応する。
一般的に、切替ネットワークは、前記アイテムを1つの場所から他の場所まで並列に移動するように適応する。
一般的に、切替ネットワークは、所定の方法で、1つのクロックサイクルにおいて可変ノードバンク手段から可変ノード計算手段までアイテムを移動するように適応する。
一般的に、切替ネットワークは、所定の方法で、1つのクロックサイクルにおいて可変ノード計算手段から検査ノード計算手段までアイテムを移動するように適応する。
一般的に、切替ネットワークは、所定の方法で、複数クロックサイクルにおいて検査ノード計算手段から検査ノードバンク手段までアイテムを移動するように適応する。
一般的に、切替ネットワークは、所定の方法で、複数クロックサイクルにおいて検査ノードバンク手段から可変ノード計算手段までアイテムを移動するように適応する。
一般的に、指定されたパラメータは、アイテムのアドレスを含む。
一般的に、切替ネットワークは、すべてのサイクルにおいてブロックおよびサブブロック内の前記第2のデータの第1の集合を検査ノード計算手段に移動するように適応する。
一般的に、アイテムの結果として生じるパラメータは、次の構成からなる:
i.第1の最小データ値;
ii.第2の最小データ値;
iii.第1の最小データ値のアドレス;
iv.すべてのデータ値の符号;
v.すべてのデータ値の符号の積;
vi. 第1の最小データ値の符号;
vii.第2の最小データ値の符号。
一般的に、可変ノード計算手段の前記計算エンジンは、結果として生じるパラメータを受容するように適応し、第2の計算されたパラメータの部分を形成する各々の第2の計算されたアイテムの符号を計算するようにさらに適応する。
一般的に、可変ノード計算手段の前記計算エンジンは、結果として生じるパラメータを受容するように適応し、第2の計算されたパラメータの部分を形成する各々の第2の計算されたアイテムの大きさを計算するようにさらに適応する。
一般的に、ブロックおよびサブブロックは、それぞれフレームおよびサブフレームである。
一般的に、音声データはブロックおよびサブブロックにおいて伝達され、ビデオ・データはフレームおよびサブフレームにおいて伝達される。
一般的に、伝達の間、データの損失を妨げるための誤り訂正システムのための方法は、次のステップからなる:
i.多重チャンネル伝達データからのチャネル値の抽出;
ii.前記チャネル値の尤度比値を含むデータへの変換;
iii.格納手段への前記尤度比値のロード;
iv.指定されたパラメータを有するアイテムを形成するため、一組の尤度チャネル値の再配置、および、第2のデータを形成するため、別々に番号をつけられたブロックおよびサブブロックにおける指定されたパラメータを有する前記アイテムの格納;
v.前記第2のデータブロックの特定のサブブロックにおけるアイテムおよびそれらの指定されたパラメータの所定の方法での選択;
vi.第1の計算されたパラメータを有する一組の第1の計算されたアイテムを含む第1の計算された出力を提供するため、前記アイテムおよびそれらの指定されたパラメータを用いた所定の方法での演算;
vii.結果として生じるパラメータを有する一組の結果として生じるアイテムを有する結果として生じる出力を提供するため、指定されたパラメータと第1の計算されたパラメータとの所定の方法での比較;
viii.第2の計算されたパラメータを有する第2の計算されたアイテムの集合を有する第2の計算された出力を提供するため、結果として生じるアイテムおよび結果として生じるパラメータを用いた所定の方法での演算;
ix.一組の誤りのない復号化データを提供するため、第2の計算された出力の第2の計算されたパラメータと指定されたパラメータとの所定の方法での比較;
x.誤りのない復号化データの受信器への通過の選択的な許容。
一般的に、尤度比値は、前記可変ノードバンク手段に連続的に移動する。
一般的に、前記アイテムは、前記誤り訂正システムにおいて、1つの場所から他の場所まで並列に移動する。
一般的に、前記ブロックの選択は、次の式を用いて実行される:
Figure 2007295564
ここで、Iは前記可変ノードバンク手段におけるアイテムのアドレスであり、zは前記可変ノードバンク手段のブロックの数である。
一般的に、前記サブブロックの選択は、次の式を用いて実行される:
Figure 2007295564
Cは前記検査ノードバンク手段のアイテムの終点アドレスであり、zは前記可変ノードバンク手段のブロックの数である。
一般的に、第1の計算されたパラメータを有する第1の計算された出力は、次の式によって計算される:
Figure 2007295564
ここで、En,mは、ブロックから通される第1の計算された出力であり、mはブロックのための検査ノードバンク手段であり、nは連結された可変ノードバンク手段である。Tn,mはブロックから送られるアイテムであり、nはブロックのための可変ノードバンク手段であり、mは次の式によって得られるその連結された検査ノードバンク手段である:
Figure 2007295564
および、
Figure 2007295564
ここで、
Inは、チャネル尤度比値である。
一般的に、第2の計算された出力の符号は、次の式を用いて算出される:
Figure 2007295564
ここで、En,mは、ブロックから通される第1の計算された出力であり、mはブロックのための検査ノードバンク手段であり、nは連結された可変ノードバンク手段である。Tn,mはブロックから送られるアイテムであり、nはブロックのための可変ノードバンク手段であり、mは次の式によって得られるその連結された検査ノードバンク手段である:
Figure 2007295564
および
Figure 2007295564
Inは、チャネル尤度比値である。
一般的に、第2の計算された手段は、min‐sum式に従って計算される。
一般的に、第2の計算された手段は、0.75の重量の割合を有するmin‐sum式に従って計算される。
添付の図面の図1は、一般の送受信システムを図示する。伝送器(T)の符号器は、伝達される情報をコード化する。この情報は、復号化手段が情報を復号化する受信器(R)に通信経路を経て通される。誤り訂正手段(C)は、伝達された情報が受容された情報と同じであるかどうか、および、データの損失がないかを検査する。検査手段は、伝達されたデータを受容するための入力手段、データのいかなる損失または変化があったかどうか検査するためにデータを処理する処理手段(P)、および、受信器(R)にデータを通過させるための出力手段(O)からなる。
添付の図面の図2は、本発明による誤り訂正システムのブロック図を図示する。可変ノードバンク手段(VNBM)は、尤度比値の形で入力データを受容し、処理の前に指定されたパラメータを有する第2のデータを形成するため、別々に番号をつけられたブロックおよびサブブロックにそれを格納する。バンク・セレクタ手段(BSM)は、指定されたパラメータでデータのアイテムを選ぶためにサブブロックを選ぶブロックおよびロケーション・ポインタ手段(LPM)を選ぶ。可変ノード計算手段(VNCM)は、可変ノードバンク手段(VNBM)からデータのクロックサイクルの選択されたアイテムを並列に受容する。可変ノード計算手段(VNCM)は、データの一時的な格納のための格納手段(SM)、結果として生じるデータの結果として生じるパラメータを得るための計算エンジン(CE)、可変ノードバンク手段(VNBM)への選択的なデータの通過を可能にするため、指定されたパラメータと結果として生じるデータの特定のパラメータを比較する比較手段(CM)からなる。同様に、検査ノード計算手段(CNCM)は、データの一時的な格納のための格納手段(SM)、結果として生じるデータの結果として生じるパラメータを得るための計算エンジン(CE)、検査ノードバンク手段(CNBM)へのデータの通過を可能にするため、指定されたパラメータと結果として生じるデータの特定のパラメータを比較する比較手段(CM)からなる。切替ネットワークは、データを1つの場所から他の場所まで移動する。同期化手段(SNCM)は、システムにおいて1つの場所から他の場所へのデータ転送を集合的に計時するように提供される。
添付の図面の図3は、本発明による誤り訂正システムのための構成を図示する;
示される復号器は、レート1/2およびブロック長2304において一般的である。
復号器は:
(i) 可変ノードバンク手段(10);
(ii) 検査ノードバンク手段(12);
(iii)置換/切替ネットワーク手段(14);
(iv) バンク・セレクタ手段(16);
(v) ロケーション・ポインタ手段(18);
(vi) 検査ノード計算手段(20);
(vii) 可変ノード計算手段(22)からなる。
設計は、コードの周期的動作に基づいてある。
メモリバンクの数および各々のバンクに格納されるアドレスの数は、異なる長さおよび異なるレートのためにアドレス指定が行われる再構成可能性が出る間、必要とされる。
検査ノードおよび可変ノードの隣のアドレスは、レートに依存した因子「z」に関連がある。一般的に、N=2304およびレート1/2のため、値96を有するレートに依存した因子が選ばれる。0番目のノードから始まりz-1ノードまでの一組のzノードの始動において連結される対応したノードにおける増加が存在し、z検査ノードのすべての集合のため、可変ノードのアドレス値は、1増加する。同様にすべてのz可変ノードのための可変ノードでは、検査ノードのアドレスは、1増加する。一般的に、レート1/2のために、第0のノードから第95のノードへの96の検査ノードの第1の集合において、第1のノードのための可変ノードのアドレスは、第0のノードのそれの増加した値である。得られたアドレスが96である場合、それはゼロになり、アドレスが192である場合、それは96などになる。すなわち、96の減分が存在する。この観察に基づいて、それは、直並列構成において、問題周辺の配慮をする接続メカニズムでVN(可変ノード)およびCN(検査ノード)処理のためそれぞれ96の要素を使用すると決定される。
メモリバンクにおいて示されるエントリは、可変ノードの手段(10)および検査ノード(12)におけるアイテムのアドレスである。一般的に、96の処理ユニットは、並列に作用し、選択されたバンク/ブロック内でサブブロックの場所を提案するバンク/ブロックおよびロケーション・ポインタ手段(18)を選ぶバンク・セレクタ手段(16)において提供されるエントリに基づいて、入力を1つずつ引き出す。ブロックのアドレスの数は、レートに依存する。
添付の図面の図3は、レート1/2およびブロック長2304に一般的であるアドレスを示す。したがって、一般的に、2304の可変ノードおよび1152の検査ノードが存在する。ロケーション・ポインタ手段(18)およびレートの依存から離れたバンク・セレクタ手段(16)のエントリの数は、反復手順の間、変化する。示されるエントリは、最初の96の検査ノードの処理動作のものである;この集合の検査ノードは図3に示すように、0、1、2、…95である。次の96(96、97、…、191)のためには、異なるエントリが、これらのレジスタにロードされることを必要とする。さらに反復手順を念入りに仕上げるため、2304の受容された値の全体のブロックは、適切な尤度比値(LLRs)を得るために測定され、およびアドレスによって提案されるように、バンクまたはブロックに格納されると仮定される。検査ノードの計算手段(20)ユニットは、それから処理を始める。検査ノード計算手段(20)は、順番に6または7の値を得る。例えば、検査ノード0のための6値は、第94のバンクの第1の場所、第73のバンクの第2の場所などから得られる。96の検査ノード計算手段(20)は、この方法で値を得ることができる。処理が完了されるならば、検査ノード計算ユニット(20)は入力と同じ出力数を生成し、出力は、それぞれのアドレスにおける検査ノード手段(12)のメモリバンクに配置される。次の96の検査ノードのための処理は、バンク・セレクタおよびロケーション・ポインタに異なる関連したエントリをロードすることによってそれから始められることができる。
バンク・セレクタおよびロケーション・ポインタの入力は、次のタイプの式から得られる:
Figure 2007295564
ここで、Iは、特定のパリティ検査ノードに連結される可変ノードのアドレスである。エントリは、群のいかなるパリティ検査ノードを選ぶことによって計算される。さらに、上記の式は、ブロック・セレクタ値を提供する。
すべての検査ノードの処理が完了されるならば、96の可変ノードの処理を開始する可変ノードは一度に処理され、可変ノード・メモリバンクから値を引き出す。演算ロケーション・ポインタ値のための式は次の通りである:

Figure 2007295564

ここで、Cは検査ノードのアドレスであり、
Figure 2007295564
はブロック・セレクタ値である。これは、復号器構成設計を完了させ、実施において、制御装置は、すべてのユニットが同期することを確認するために必要とされる。
LLRを得るためにメモリ要求およびLUT計算を減少するため、min‐Sumアルゴリズムは、普及している選択である。一般的に、このアルゴリズムで検査ノードの(12)だけが、以下に表現される規則的なsum−productアルゴリズムと異なる法則を更新する。
検査ノードの更新法則:
Figure 2007295564
min‐Sumアルゴリズムは、次の特性を有し、有用である:
(a)検査ノードの(12)更新は、最小入力値の選択によって置き換えられる。
(b)それぞれのパリティ検査式のために2つの絶対値のみがセーブされることが必要とされる。
(c)固有の情報を計算するためにノイズ相違を推定する必要がない。
Min‐Sumの単純性は、ビット誤り率に関してパフォーマンスに不利な条件と関連している。性能に不利な条件は、(通常の和積と比較して)外部情報のオーバーエスティメーションのためであることが公知であり、およびしたがって、減算(相殺)または乗算(正常化)に関する補正が提案される。本発明により実行される広範囲なシミュレーション調査に基づいて、可変ノードの0.75の乗算の因子は、通常のsum−productアルゴリズムのそれに近い(補正された)min‐sumアルゴリズムの性能の結果を出力することが明らかになった。この因子は、VCU(22)において、出力に0.5および0.25を(両方ともシフト動作である)逓倍し、補正された値を得るために計算結果を加えることによって、単純に実行されることができる。
提案された復号器におけるmin‐Sumアルゴリズムの半並列での実施は、次のステップからなる:
ステップ1:チャネル値抽出手段は、多重チャンネル伝達データからチャネル値を抽出し、変換装置手段にチャネル値を中継する。変換装置手段は、尤度比値を含んでいるデータに前記チャネル値を変換する。可変ノードバンク手段(10)は、前記変換装置手段から一組の尤度比値を受容するために適応し、第2のデータを形成するため、別々に番号をつけられたブロックおよびサブブロックにおいて指定されたパラメータを有するアイテムとして前記値を再配置する。このステップは、連続的な処理である。
ステップ2:バンク・セレクタ手段(16)は、所定の方法で、前記第2のデータからブロックを選択するために適応し、ロケーション・ポインタ手段(18)は、所定の方法で、更新される検査ノード・メモリバンク手段(12)に連結される可変ノード・メモリバンク手段(10)に存在する前記第2のデータからサブブロックを選択するために適応する。一般的に96の分離したメモリバンクが存在するので、並列な96値が引き出され、切替ネットワーク(14)に入力として提供される。
ステップ3:切替ネットワーク(14)は、すべての96の可変ノード・メモリバンク(10)から値を取り、更新される検査ノード(12)に連結される可変ノード(10)のアドレスに依存して適当なシフト動作を実行する。切替えは、96の入力値で並列にクロックサイクルの範囲内で実行され、その入力値のシフトされた別方式を提供する。切替ネットワーク(14)の出力(96の入力値のシフトされた別方式である96値)は、96の検査ノード演算器(20)に提供される。
ステップ4:検査ノード計算手段(20)の計算エンジンは、選択されたアイテムおよび指定されたパラメータを受容するのに適応し、所定の方法で、第1の計算されたパラメータを有する一組の第1の計算されたアイテムを含む第1の計算された出力計算するためにさらに適応する。第1の比較手段は、所定の方法で、一組の結果として生じるアイテムを有する結果として生じる出力を提供するため指定されたパラメータに関する第1の計算されたパラメータと前記検査ノード計算手段(12)における格納のため、結果として生じるパラメータとを比較するために提供される。
それぞれの検査ノードの演算器(20)は、すべてのクロックサイクルで1つの入力値を取り、計算を実行する。更新される検査ノードの(12)の等級が「k」である場合、検査ノードの演算器(20)は、その出力を提供するために「k」クロックサイクルを取る。個別的な演算器のためのそれぞれの入力値は、順番に提供される。96の演算器が得られるので、すべての演算器の96の出力が「k」クロックサイクルにおいて得ることができる。それぞれの演算器の出力は、その入力の中の第1の最小値、その入力の中の第2の最小値、第1の最小のアドレス、すべての入力値の符号、および、すべての入力値の符号の積から構成される。
検査ノード計算手段(20)は、それぞれのクロックサイクルにおいて順番に同時に1つの入力を取る。それぞれの値は、Tである。それぞれの検査ノード計算手段(20)は、可変ノード(10)メモリバンク(それぞれの1つのクロックサイクルにおいて)および、第1の最小値(min1)、第2最小値(min2)第1の最小アドレス(min1address)、すべての入力値の符号、およびすべての入力値の符号の積から構成される1つの全体の関連した検査ノードの(12)値からT値のk数を引き出す。これらは、次のようにEn,m値を生成するために使用することができる。
検査ノード計算のユニット(20)は、min1addressを現在のT値が引き出される可変ノード(10)アドレスと比較する。それが適合する場合、min2はEn,mの実際の絶対値であり、他の点では、min1は実際の絶対値と考えられる。それの符号は、先の反復の符号情報で全体の符号を逓倍することによって得られる。これにより、+min1または‐min1、または+min2または‐min2に達する。すべての検査ノード(12)で開始するため、メモリバンク値はゼロ(ゼロは、正符号に対応する)に初期化される。分離したバスは、可変ノード(10)および検査ノードの(12)メモリバンクからそれぞれTおよびEn,m値を引き出すため、検査ノードの演算器(20)に提供される。それで、TおよびEn,mの両方は、並列に引き出されることができる。それぞれのクロックサイクルで、En,m値は、Tn,mを得るためにTから減じられる:
Figure 2007295564
ステップ5:すべての96の演算器の出力は、96の検査ノードの(12)メモリバンクに並列に書き込まれる。これは、96の検査ノードの(12)の1つの集合の更新を完了する。これらの96の検査ノードの演算器(20)は、96の検査ノード(12*96=1152)の12の集合の更新を完了するため、12回繰り返し作動され、検査ノードの(12)処理(最初の半分の反復)を完了する。それは、多くともk*12クロックサイクルを必要とする。
ステップ6:検査ノードの(12)処理の完了の後、次のステップは、可変ノード(10)処理のために必要とされる検査ノードの(12)メモリバンクから値を引き出すことである。
可変ノード計算手段(22)の計算エンジンは、所定の方法で、第2の計算されたパラメータを持つ一組の第2の計算されたアイテムを有する第2の計算された出力を計算するため、結果として生じるパラメータを有する一組の結果として生じるアイテムを受容するために適応する。第2の比較手段は、所定の方法で、第2の計算されたパラメータおよび指定されたパラメータ間の誤りを比較し、誤りのない復号化データを形成するため、前記可変ノード計算手段(22)から前記可変ノードバンク手段(10)へのアイテムの誤りのない選択的な通過を許容するために適応する。
検査ノード(12)処理に類似して、可変ノード(10)の処理においても、96値は、96の検査ノードのメモリ(12)バンクから、並列に引き出され、切替ネットワーク手段(14)に提供される。
ステップ7:切替ネットワーク(14)(入力値のシフトされた別方式)の出力は、可変ノード演算器(22)に提供される。
ステップ8:それぞれの個別の可変ノード演算器(22)は、順番にそれぞれ入力し、計算を実行し、「x」が更新される可変ノードの度合いである場合、クロックサイクルの「x」数において出力を提供する。
可変ノード演算器(22)は、検査ノードの(12)メモリバンクから「x」数の入力値を順番に(1つずつ)取る。それは、検査ノードの(12)処理で説明されたのと同じ方法で、+min1または‐min1、または、+min2または−min2を検査ノードの(12)メモリ値から導く。すなわち、可変ノード(10)プロセッサは、min1addrを更新される可変ノード(10)アドレスと比較する。それが適合する場合、En,mの絶対値がmin2、別の方法ではmin1と考えられる。En,mの符号は、検査ノード(12)メモリにおけるその関連した個別の符号情報で全体の符号を逓倍することによって得られる。
得られた値En,mは、その可変ノード(10)の固有の情報によって蓄積され、結果は可変ノード(10)メモリバンクに格納される。対応している可変ノード(10)メモリロケーションへの可変ノード演算器(22)の結果の書き込みは、その特定の可変ノード(10)の更新を表す。
ステップ9:96のこのような演算器が構成に存在するので、すべての96の可変ノード演算器(22)の出力は、に96の可変ノード(10)メモリバンクに並列書き込まれる。
ステップ10:これらの96の演算器は、可変ノード(10)処理(後半の反復)を完了するために24回一般的に作動される。
ステップ11:この検査ノードの(12)処理および可変ノード(10)処理は、最大数の反復のために繰り返される。
図4から図17は、一組のシミュレーション結果を視覚的に図示する。
シミュレーション調査は、レート1/2、2/3および3/4に関してと同様、ブロック長576、1440および2304(規格うちの最低、中間および最大)で実行された。典型的ないくつかのシミュレーション結果は、ビット誤り率(BER)およびフレーム誤り率(FER)の両方がビットあたりのエネルギE/Nに対してプロットされることを示している。AWGNの場合では、結果はオールゼロ符号語のためのものであった。
この結果は、フレーム長が提供されたレートおよび提供された長さ増加すると性能は改善し、性能はレートの減少で改善するという事実を確認した。λ‐Minアルゴリズムのために、λの値は3が選ばれる。λ‐minおよびΑ‐minアルゴリズムの両方は、通常のsum‐productアルゴリズムのように実行されるが、min‐sumより多くの複雑性を有することが観察された。min‐sumアルゴリズムは、約0.5dBのいくつかのパフォーマンスに不利な条件を有した。上述したように、0.75の補正因子が使用される場合、min‐sumアルゴリズムの性能は、添付の図面の図13、14、15、16に示すように、通常のBPアルゴリズムにより近くに導かれることができる。類似した結果は、ランダムに生成された符号語によって観察された。
図4は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=1/2(一般的にメガビット/秒)のグラフを図示する;
図5は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=2/3A(一般的にメガビット/秒)のグラフを図示する;ここで、Aは第1の重み係数である;
図6は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=2/3B(一般的にメガビット/秒)のグラフを図示する;ここで、Bは第2の重み係数である;
図7は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=3/4A(一般的にメガビット/秒)のグラフを図示する;ここで、Aは第1の重み係数である;
図8は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=3/4B(一般的にメガビット/秒)のグラフを図示する;ここで、Bは第2の重み係数である;
図9は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=1/2(一般的にメガビット/秒)のグラフを図示する;
図10は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=2/3A(一般的にメガビット/秒)のグラフを図示する;ここで、Aは第1の重み係数である;
図11は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=2/3B(一般的にメガビット/秒)のグラフを図示する;ここで、Bは第2の重み係数である;
図12は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=3/4A(一般的にメガビット/秒)のグラフを図示する;ここで、Aは第1の重み係数である;
図13は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=3/4B(一般的にメガビット/秒)のグラフを図示する;ここで、Bは第2の重み係数である;
図14は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=1/2(一般的にメガビット/秒)のグラフを図示する;
図15は、ビット誤り率(BER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304]および、レートr=1/2およびr=2/3A(一般的にメガビット/秒)のグラフを図示する;ここで、Aは第1の重み係数である;
図16は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304/1440/576]および、レートr=1/2(一般的にメガビット/秒)のグラフを図示する;
図17は、フレーム誤り率(FER)Vs dBのビットあたりのエネルギ(Eb/No)、ブロック長n=[2304]および、レートr=1/2および2/3A(一般的にメガビット/秒)のグラフを図示する;ここで、Aは第1の重み係数である;
添付の図面の図18および19は、新規な構成のフィールドプログラマブル・ゲート・アレイ(FPGA)の実施例を図示する。機能的な確認シミュレーションに関連する波形は、図18および図19において示され、ここにおいて、図18は入力波形を図示し、図19は出力波形(10の反復の後)を図示する。波形は、16ビット量子化で3.5dBのE/Nのためのものである(1符号ビット、4整数ビットおよび11分数ビット)。
新規な構成のFPGAの実施例は、フレーム長576および符号レート1/2で実行される。使用された復号化アルゴリズムは、補正されたmin‐Sumアルゴリズムであった。次の表は、研究所において使われたターゲット装置(FPGA)の詳細を提供する。

Figure 2007295564

復号器の検査ノードの部分の構成は、検査ノードのRAMおよび検査ノードプロセッサ(計算ユニット)からなる。同様に、可変ノード部分は、可変ノードRAMおよび可変ノードプロセッサからなる。
検査ノードプロセッサによって更新される検査ノードの値は、検査ノードのRAMに格納される。この記憶ブロックは、検査ノードの値(例えばmin1、min2、min1addrおよび符号ビット)についての情報を格納する。検査ノードのRAMもまた、その深さが符号レートに次第であるメモリバンクから構成される。検査ノードプロセッサは、可変ノード・メモリバンクから並行してそれらの入力値を引き出し、それら上での動作を実行する。すべてのこれらのプロセッサの結果は、検査ノードのRAMに並行して格納される。ロケーション・ポインタおよびバンク・セレクタ値は、その値が計算の間使われるいずれのプロセッサにも提供される。実施例におけるその主な構成要素がバレル・シフターである切替ネットワークは、RAMおよび処理要素間の接続の配慮をする。ロケーション・ポインタ・エントリ(アドレス)は、メモリバンクから値を引き出すために使われ、それらの引き出された値は切替ネットワークに入力として提供される。バンク・セレクタのコンテンツは、バレル・シフターのマルチプレクサの選択ビットに、入力として提供される。バレル・シフターの選択ビットに提供されるアドレスに従って、シフト動作はしたがって実行され、バレル・シフターのシフトされた入力情報の結果は切替ネットワークの出力ラッチに格納される。
可変ノードRAMは、その深さがコード・ブロック長次第であるメモリバンクから構成される。各々のバンクからのポート・バスは、切替ネットワークに連結される。個別のメモリバンクから引き出されるデータは、ロケーション・ポインタ値に依存している。復号化工程の開始の前に、メモリバンクは、チャネル値がロードされる。復号化工程の開始の後、これらは、可変ノードプロセッサによって得られた結果がロードされる。可変ノードプロセッサの連結している記述は、検査ノードプロセッサにきわめて類似している。
以下では、(FPGAの)資源利用およびタイミングについての詳細が提供される。
資源利用:
設計のための完全に同等のゲート・カウント:5,715,703
次の表は、FPGAの設計の資源利用の概要を提供する。
Figure 2007295564

タイミング概要:
最小の期間:8.127ns(ナノ秒)
クロック前の最小の入力到着時間:7.888ns
クロック後の最大出力動作必要時間:4.961ns
最大の組合せの経路遅延:2.485ns
設計の動作の最大周波数は、123.047Mhzであることが明らかになった。
本願明細書において好適な実施例の様々な構成要素に相当な重点が置かれた一方で、多くの変更が作成され、多くの修正が発明の原理から逸脱することなく、好適な実施例において作成されることができることはいうまでもない。発明の別の実施例と同様、好適な実施例のこれらのおよび他の変化は本願明細書における開示から当業者には明白であり、それによって、前述の記述的な事柄は単に発明を図示し、制限する意図は有さないと解釈されることは明確に理解される。
発明は、次に好適な実施例に関して詳述される。この実施例への参照は、発明の範囲を制限しない。
一般の伝達-受信システムを図示する。 本発明による誤り訂正システムのブロック図を図示する。 本発明による誤り訂正システムの構成を図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムのための一組のシミュレーション結果を視覚的に図示する。 誤り訂正システムの構成のField Programmable Gate Array(FPGA)の実施例を図示する。 誤り訂正システムの構成のField Programmable Gate Array(FPGA)の実施例を図示する。

Claims (24)

  1. 多重チャネルにおいて伝達されたデータを復号化するための誤り訂正システムであって、前記システムは:
    i.前記多重チャンネルで伝達されたデータからチャネル値を抽出し、前記チャネル値を中継するためのチャネル値抽出手段;
    ii.前記チャネル値を受容し、尤度比値を含むデータに前記チャネル値を変換するための変換装置手段;
    iii.前記変換装置手段から一組の尤度比値を受容し、第2のデータを形成するため、別々に番号をつけられたブロックおよびサブブロックにおいて指定されたパラメータを有するアイテムとして前記値を再配置するように適応する可変ノードバンク手段;
    iv.所定の方法で、前記第2のデータからブロックを選ぶように適応するバンク・セレクタ手段、
    v.所定の方法で、前記第2のデータからサブブロックを選ぶように適応するロケーション・ポインタ手段;
    vi.格納手段および計算エンジンを有する可変ノード計算手段;
    vii.格納手段および計算エンジンを有する検査ノード計算手段;
    viii.所定の方法で、可変ノードバンク手段、可変ノード計算手段、検査ノード計算手段および検査ノードバンク手段間の、それらのパラメータと一緒に一組のアイテムを転送するように適応する切替ネットワーク手段;
    ix.前記選択されたアイテムおよび指定されたパラメータを受容するのに適応し、所定の方法で、第1の計算されたパラメータを有する一組の第1の計算されたアイテムを含む第1の計算された出力を計算するためにさらに適応する検査ノード計算手段の前記計算エンジン;
    x.所定の方法で、一組の結果として生じるアイテムを有する結果として生じる出力を提供するため、指定されたパラメータに関する第1の計算されたパラメータと前記検査ノード計算手段に格納するため、結果として生じるパラメータとを比較するための第1の比較手段;
    xi.所定の方法で、第2の計算されたパラメータを有する一組の第2の計算されたアイテムを有する第2の計算された出力を計算するため、結果として生じるパラメータを有する結果として生じるアイテムの前記集合を受容するために適応する可変ノード計算手段の前記計算エンジン;
    xii.所定の方法で、第2の計算されたパラメータおよび指定されたパラメータ間の誤りを比較し、誤差のない復号化データを形成するため、前記可変ノード計算手段から前記可変ノードバンク手段への誤りのないアイテムの通過を選択的に許容するように適応する第2の比較手段;
    xiii.前記可変ノードバンク手段から誤りのない復号化データを受信器へ移動する移送手段、からなるシステム。
  2. 請求項1に記載の誤り訂正システムであって、ロード手段は、可変ノードバンク手段に前記尤度比値を連続的にロードするために提供されるシステム。
  3. 請求項1に記載の誤り訂正システムであって、同期手段は、1つの場所から他の場所に時限式にアイテムを集合的に移動するために提供されるシステム。
  4. 請求項1に記載の誤り訂正システムであって、反復的な手段が、誤りのない復号化データを得るため、計算の全体の集合を反復するように適応するシステム。
  5. 請求項1に記載の誤り訂正システムであって、前記切替ネットワークが前記アイテムを1つの場所から他の場所へ並列に移動するように適応するシステム。
  6. 請求項1に記載の誤り訂正システムであって、前記切替ネットワークは、所定の方法で、1つのクロックサイクルにおいて前記可変ノードバンク手段から前記可変ノード計算手段までアイテムを移動するように適応するシステム。
  7. 請求項1に記載の誤り訂正システムであって、前記切替ネットワークは、所定の方法で、1つのクロックサイクルにおいて前記可変ノード計算手段から前記検査ノード計算手段までアイテムを移動するように適応するシステム。
  8. 請求項1に記載の誤り訂正システムであって、前記切替ネットワークは、所定の方法で、複数のクロックサイクルにおいて前記検査ノード計算手段から前記検査ノードバンク手段までアイテムを移動するように適応するシステム。
  9. 請求項1に記載の誤り訂正システムであって、前記切替ネットワークは、所定の方法で、複数のクロックサイクルにおいて前記検査ノードバンク手段から前記可変ノード計算手段までアイテムを移動するように適応するシステム。
  10. 請求項1に記載の誤り訂正システムであって、前記指定されたパラメータは、アイテムのアドレスを含むシステム。
  11. 請求項1に記載の誤り訂正システムであって、切替ネットワークが、前記ブロックおよびサブブロックの範囲内の前記第2のデータの前記第1の集合をすべてのサイクルにおいて検査ノード計算手段に移動するように適応するシステム。
  12. 請求項1に記載の誤り訂正システムであって、アイテムの前記結果として生じるパラメータは:
    i)第1の最小のデータ値;
    ii)第2の最小のデータ値;
    iii)第1の最小のデータ値のアドレス;
    iv)すべてのデータ値の符号;
    v)すべてのデータ値の符号の積;
    vi)第1の最小のデータ値の符号;
    vii)第2の最小のデータ値の符号からなるシステム。
  13. 請求項12に記載の誤り訂正システムであって、前記可変ノード計算手段の前記計算エンジンが、前記結果として生じるパラメータを受容するために適応し、前記第2の計算されたパラメータの部分を形成する前記第2の計算されたアイテムの各々の符号を計算するためにさらに適応するシステム。
  14. 請求項1に記載の誤り訂正システムであって、前記可変ノード計算手段の前記計算エンジンが、前記結果として生じるパラメータを受容するために適応し、前記第2の計算されたパラメータの部分を形成する前記第2の計算されたアイテムの各々の絶対値を計算するためにさらに適応するシステム。
  15. 請求項1に記載の誤り訂正システムであって、前記ブロックおよび前記サブブロックは、それぞれフレームおよびサブフレームであるシステム。
  16. 多重チャネルにおいて伝達されたデータを復号化するための誤り訂正の方法であって、以下のステップ:i.多重チャンネルの伝達されたデータからのチャネル値の抽出;
    ii.尤度比値を含むデータへの前記チャネル値の変換;
    iii.格納手段への前記尤度比値のロード;
    iv.指定されたパラメータを有するアイテムを形成するため、前記尤度比値の再配置、および、第2のデータを形成するため別々に番号をつけられたブロックおよびサブブロックにおける指定されたパラメータを有する前記アイテムの格納;
    v.前記第2のデータのブロックの特定のサブブロックにおける所定の方法でのアイテムおよびそれらの指定されたパラメータの選択;
    vi.第1の計算されたパラメータを有する一組の第1の計算されたアイテムを含む第1の計算された出力を提供するため、前記アイテムおよびそれらの指定されたパラメータを用いた所定の方法での演算;
    vii.結果として生じるパラメータを有する一組の結果として生じるアイテムを有する結果として生じる出力を提供するため、前記指定されたパラメータと前記第1の計算されたパラメータとの所定の方法での比較;
    viii.第2の計算されたパラメータを有する一組の第2の計算されたアイテムを有する第2の計算された出力を提供するため、結果として生じるアイテムおよび結果として生じるパラメータを用いた所定の方法での演算;
    ix.一組の誤りのない復号化データを提供するため、前記指定されたパラメータと前記第2の計算された出力の前記第2の計算されたパラメータとの所定の方法での比較;
    x.誤りのない復号化データの受信器への通過の選択的な許容からなる方法。
  17. 請求項16に記載の誤り訂正の方法であって、前記尤度比値は、前記可変ノードバンク手段に連続的に移動される方法。
  18. 請求項16に記載の誤り訂正の方法であって、前記アイテムは、前記誤り訂正システムにおいて1つの場所から他の場所へ並列に移動される方法。
  19. 請求項16に記載の誤り訂正の方法であって、ブロックの前記選択は、式
    Figure 2007295564
    を用いて実行され:
    ここで、Iは前記可変ノードバンク手段のアイテムのアドレスであり、zは前記可変ノードバンク手段のブロックの数である方法。
  20. 請求項16に記載の誤り訂正の方法であって、サブブロックの前記選択は、式
    Figure 2007295564
    を用いて実行され:
    Cは、前記検査ノードバンク手段のアイテムの終点アドレスであり、zは前記可変ノードバンク手段のブロックの数である方法。
  21. 請求項16に記載の誤り訂正の方法であって、前記第2の計算された出力は、min‐sum式に従って計算される方法。
  22. 請求項16に記載の誤り訂正の方法であって、前記第2の計算された出力は、0.75の重量でmin‐sum式に従って計算される方法。
  23. 添付の図面に関して本願明細書において記載される多重チャネルにおいて伝達されたデータを復号化するための誤り訂正システム。
  24. 添付の図面に関して本願明細書において記載される多重チャネルにおいて伝達されたデータを復号化するための誤り訂正の方法。
JP2007109807A 2006-04-19 2007-04-18 低密度のパリティ検査コードを用いた復号器 Pending JP2007295564A (ja)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
IN613MU2006 2006-04-19

Publications (1)

Publication Number Publication Date
JP2007295564A true JP2007295564A (ja) 2007-11-08

Family

ID=38765676

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2007109807A Pending JP2007295564A (ja) 2006-04-19 2007-04-18 低密度のパリティ検査コードを用いた復号器

Country Status (3)

Country Link
US (1) US7941737B2 (ja)
JP (1) JP2007295564A (ja)
KR (1) KR100910420B1 (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009075143A1 (ja) * 2007-12-13 2009-06-18 Nec Corporation 復号装置、データ蓄積装置、データ通信システム、および復号方法
US9088302B2 (en) 2012-04-19 2015-07-21 Samsung Electronics Co., Ltd. Low-density parity-check code decoder and decoding method
US10141950B2 (en) 2007-05-01 2018-11-27 The Texas A&M University System Low density parity check decoder

Families Citing this family (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080028282A1 (en) * 2006-07-25 2008-01-31 Legend Silicon receiver architecture having a ldpc decoder with an improved llr update method for memory reduction
US20090070659A1 (en) * 2007-09-11 2009-03-12 Legend Silicon Corp. Ldpc decoder with an improved llr update method using a set of relative values free from a shifting action
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
CN101803205B (zh) * 2008-08-15 2013-12-18 Lsi公司 近码字的ram列表解码
US8560917B2 (en) 2009-01-27 2013-10-15 International Business Machines Corporation Systems and methods for efficient low density parity check (LDPC) decoding
US8291299B2 (en) 2009-03-05 2012-10-16 Lsi Corporation Turbo-equalization methods for iterative decoders
JP5432367B2 (ja) 2009-04-21 2014-03-05 アギア システムズ インコーポレーテッド 書込み検証を使用した符号のエラーフロア軽減
US8418019B2 (en) * 2010-04-19 2013-04-09 Lsi Corporation Systems and methods for dynamic scaling in a data decoding system
US8464142B2 (en) 2010-04-23 2013-06-11 Lsi Corporation Error-correction decoder employing extrinsic message averaging
US8499226B2 (en) 2010-06-29 2013-07-30 Lsi Corporation Multi-mode layered decoding
US8458555B2 (en) 2010-06-30 2013-06-04 Lsi Corporation Breaking trapping sets using targeted bit adjustment
US8504900B2 (en) 2010-07-02 2013-08-06 Lsi Corporation On-line discovery and filtering of trapping sets
US8768990B2 (en) 2011-11-11 2014-07-01 Lsi Corporation Reconfigurable cyclic shifter arrangement
RU2012146685A (ru) 2012-11-01 2014-05-10 ЭлЭсАй Корпорейшн База данных наборов-ловушек для декодера на основе разреженного контроля четности
US9294129B2 (en) * 2013-01-16 2016-03-22 Maxlinear, Inc. Low-power low density parity check decoding
KR101698875B1 (ko) 2013-03-14 2017-01-24 한국전자통신연구원 Ldpc 부호의 복호 방법 및 장치
US8930790B1 (en) 2013-09-13 2015-01-06 U-Blox Ag Method and apparatus for identifying selected values from among a set of values
TWI677878B (zh) * 2018-10-12 2019-11-21 慧榮科技股份有限公司 編碼器及相關的編碼方法與快閃記憶體控制器

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6938196B2 (en) * 2001-06-15 2005-08-30 Flarion Technologies, Inc. Node processors for use in parity check decoders
KR100891782B1 (ko) * 2002-06-11 2009-04-07 삼성전자주식회사 고속 데이터 전송 시스템에서 순방향 오류 정정 장치 및방법
KR100762619B1 (ko) * 2004-05-21 2007-10-01 삼성전자주식회사 저밀도 패리티 검사 코드를 이용한 복호화 장치 및 방법
US20050283707A1 (en) 2004-06-22 2005-12-22 Eran Sharon LDPC decoder for decoding a low-density parity check (LDPC) codewords
US7143333B2 (en) * 2004-08-09 2006-11-28 Motorola, Inc. Method and apparatus for encoding and decoding data
KR100703271B1 (ko) * 2004-11-23 2007-04-03 삼성전자주식회사 통합노드 프로세싱을 이용한 저밀도 패리티 검사 코드복호 방법 및 장치

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10141950B2 (en) 2007-05-01 2018-11-27 The Texas A&M University System Low density parity check decoder
US10615823B2 (en) 2007-05-01 2020-04-07 The Texas A&M University System Low density parity check decoder
US10951235B2 (en) 2007-05-01 2021-03-16 The Texas A&M University System Low density parity check decoder
US11368168B2 (en) 2007-05-01 2022-06-21 The Texas A&M University System Low density parity check decoder
US11728828B2 (en) 2007-05-01 2023-08-15 The Texas A&M University System Low density parity check decoder
WO2009075143A1 (ja) * 2007-12-13 2009-06-18 Nec Corporation 復号装置、データ蓄積装置、データ通信システム、および復号方法
US8429486B2 (en) 2007-12-13 2013-04-23 Nec Corporation Decoding device, data storage device, data communication system, and decoding method
US9088302B2 (en) 2012-04-19 2015-07-21 Samsung Electronics Co., Ltd. Low-density parity-check code decoder and decoding method

Also Published As

Publication number Publication date
US20070283218A1 (en) 2007-12-06
KR20070103711A (ko) 2007-10-24
US7941737B2 (en) 2011-05-10
KR100910420B1 (ko) 2009-08-04

Similar Documents

Publication Publication Date Title
JP2007295564A (ja) 低密度のパリティ検査コードを用いた復号器
JP4651600B2 (ja) 低密度パリティ検査復号器における検査ノード更新方法
CN111565051B (zh) 一种用于ldpc码的自学习归一化偏置最小和译码方法
WO2007045961A1 (en) Block serial pipelined layered decoding architecture for structured low-density parity-check (ldpc) codes
CN101212277A (zh) 支持多协议标准的ldpc码译码装置
CN107612560B (zh) 基于部分信息比特似然比的极化码早期迭代停止方法
JPWO2007007801A1 (ja) 通信装置および復号方法
KR102386191B1 (ko) 폴라 코드용의 블록 단위의 병렬 동결 비트 생성
JP5485069B2 (ja) 誤り訂正復号装置及び誤り訂正復号方法
US11483011B2 (en) Decoding method, decoding device, and decoder
CN102611462B (zh) 一种ldpc-cc译码算法及译码器
CN110048805B (zh) 低密度奇偶校验码的译码控制系统及方法、无线通信系统
KR20090012189A (ko) Ldpc 부호의 성능 개선을 위한 스케일링 기반의 개선된min-sum 반복복호알고리즘을 이용한 복호 장치 및그 방법
EP3829088A1 (en) Decoder, decoding method, and computer storage medium
JP2011055168A (ja) 復号化装置及び復号化方法
CN112470405A (zh) 非二进制码的消息传递解码的可变节点处理方法和设备
Huang et al. A Markov chain model for edge memories in stochastic decoding of LDPC codes
Wu et al. Improved MS LDPC decoder based on Jacobian Logarithm
KR20090079007A (ko) 엘디피씨 부호 복호 장치 및 복호 방법
CN113395138B (zh) 基于深度学习的pc-scma联合迭代检测译码方法
US11817879B2 (en) FPGA-based rate-adaptive spatially-coupled LDPC codes for optical communications
CN114553242B (zh) 基于半概率计算的部分并行ldpc译码器
Zhong-xun et al. A BP decoding algorithm based on nodes residual for LDPC codes
Wang et al. High-Performance QC-LDPC Layered Decoder Based on Shortcut Updating
CN117674858A (zh) 一种Hadamard_LDPC译码方法及译码器装置