JP2020516119A - 符号器、復号器及び送信機 - Google Patents

符号器、復号器及び送信機 Download PDF

Info

Publication number
JP2020516119A
JP2020516119A JP2019551713A JP2019551713A JP2020516119A JP 2020516119 A JP2020516119 A JP 2020516119A JP 2019551713 A JP2019551713 A JP 2019551713A JP 2019551713 A JP2019551713 A JP 2019551713A JP 2020516119 A JP2020516119 A JP 2020516119A
Authority
JP
Japan
Prior art keywords
column
block
polar
parity
parity block
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.)
Granted
Application number
JP2019551713A
Other languages
English (en)
Other versions
JP6847252B2 (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.)
Mitsubishi Electric Corp
Original Assignee
Mitsubishi Electric 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 Mitsubishi Electric Corp filed Critical Mitsubishi Electric Corp
Publication of JP2020516119A publication Critical patent/JP2020516119A/ja
Application granted granted Critical
Publication of JP6847252B2 publication Critical patent/JP6847252B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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/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/2957Turbo codes and decoding
    • H03M13/296Particular turbo code structure
    • H03M13/2963Turbo-block codes, i.e. turbo codes based on block codes, e.g. turbo decoding of product 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/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/1108Hard decision decoding, e.g. bit flipping, modified or weighted bit flipping
    • 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
    • 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
    • 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/1555Pipelined decoder implementations
    • 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/1575Direct decoding, e.g. by a direct determination of the error locator polynomial from syndromes and subsequent analysis or by matrix operations involving syndromes, e.g. for codes with a small minimum Hamming distance
    • 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/27Coding, 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 using interleaving techniques
    • H03M13/2703Coding, 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 using interleaving techniques the interleaver involving at least two directions
    • H03M13/271Row-column interleaver with permutations, e.g. block interleaving with inter-row, inter-column, intra-row or intra-column permutations
    • 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/27Coding, 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 using interleaving techniques
    • H03M13/2771Internal interleaver for turbo 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/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
    • 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/37Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
    • H03M13/45Soft decoding, i.e. using symbol reliability information
    • H03M13/451Soft decoding, i.e. using symbol reliability information using a set of candidate code words, e.g. ordered statistics decoding [OSD]

Landscapes

  • Physics & Mathematics (AREA)
  • Probability & Statistics with Applications (AREA)
  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Algebra (AREA)
  • General Physics & Mathematics (AREA)
  • Pure & Applied Mathematics (AREA)
  • Error Detection And Correction (AREA)

Abstract

ソース情報を、通信チャネルにおいて使用される符号化されたコードワードに符号化する符号器が、ソースデータを受信するデータ入力と、プロセッサと、符号器プログラムを記憶するメモリとを含む。符号器プログラムは、プロセッサに、ソースデータをターボ積符号化(TPC)構造に符号化させ、TPC構造は、ソースデータに対応するデータブロックと、第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、第1のパリティブロックは、第1の列部分、第1の角部分及び第1の底部分によって、データブロックの右端列、データブロックの右底角及びデータブロックの底列を覆うように配置される、第1のパリティブロックと、行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックとを備える。

Description

本発明は、硬判定クリーニング(hard decision cleaning)を伴うターボ積ポーラ符号化方法及びデバイスに関する。
ポーラ符号は、逐次除去(SC:successive cancellation)復号を用いて、任意のバイナリ入力無記憶チャネルにおいてチャネル容量を漸近的に達成できることが証明されている。しかしながら、短いコードワード長における誤り率性能は、低密度パリティ検査(LDPC:low-density parity-check)符号等の他のチャネル容量に迫る符号(capacity-approaching code)には対抗できない。Tal及びValdyは、CRC連接を伴うSCL復号によって、ポーラ復号性能を著しく改善する打開策である特許文献1を考案した。また、Zhang、Liu、Pan及びPan(非特許文献1)によって、SCLポーラ復号性能がCRC多項式に大きく依存すること、及び適切に設計されたCRC多項式によって、ポーラ−CRC連接符号の最小ハミング距離を大きくできることも解明された。
Bose、Chaudhuri及びHocquenghem(BCH)符号及びハミング符号等の従来の線形符号に基づく積符号を用いて、並列符号化及び復号の能力によって最小ハミング距離を大きくしてきた。積符号が最尤に近い性能を達成する軟判定(SD:soft-decision)反復のための効率的なチェイス復号法がPyndiah(非特許文献2)によって提案された。積符号のために使用される、ターボライク(turbo-like)SD反復手法は、ターボ積符号(TPC:turbo product code)として知られている。
米国特許第9503126号
「CRC code design for list decoding of polar codes」Communications Letter 2017 「Near-optimum decoding of product codes: block turbo codes」IEEE Transactions on Communications, vol. 46, no. 8, 1998
本開示は、明白でないようにしてポーラ構成符号を用いる新たなTPCを提供し、分極及びインターリーブ処理に起因する非正則性を利用して、ハミング重み分布を改善する。さらに、本発明は、ポーラTPCの、チェイスライクSD反復復号のためにSCLポーラ復号を拡張する方法を提供する。SCLチェイス復号によれば、ポーラ符号に基づくTPCは、BCH符号、ハミング符号、リードソロモン符号又はリードミューラー符号等の代数的符号に基づく従来からのTPCに比べて、誤り率性能の著しい改善を提供する。
さらに、本開示のいくつかの実施形態は、分極及びインターリーブ処理に起因する非正則性を利用して、ターボポーラ符号のハミング重み分布を改善する、ポーラ符号化を用いる積符号化方法を提供する。それらの実施形態は、非正則空間結合ポーラ符号の誤り性能を低減するために、軟判定ポーラ復号を使用することができる。そのシステムは、複数のパリティ検査行列を伴う積符号からなることができる。パリティブロックは、行パリティ、列パリティ及び結合パリティ行列(joint parity matrix)を含むことができる。データセクションは、より良好な誤り性能を得るために、空間結合ポーラ符号の非正則性を利用する1組の付加パリティブロックを含むことができる。
ポーラ符号は良好なハミング重み分布を有するが、空間結合ポーラ符号内の構成符号として使用される、短符号長の高速ポーラ符号は、通常、BCH符号より短い最小ハミング距離を有することが知られている。短い最小ハミング距離は、信号対雑音比(SNR:signal-to-noise ratio)が高い状況においてのみ、誤り率性能に影響を及ぼすことができる。結果として、空間結合ポーラ符号は、潜在的には、他のTPCより高い誤りフロア(error floor:エラーフロア)問題を被る可能性がある。
本発明では、CRCの代わりにBCH連接を使用し、SD反復復号後に硬判定(HD:hard-decision)クリーニングを使用することによって、誤りフロアを低減する方法が開示される。BCH連接を伴うHDクリーニングが空間結合ポーラ符号の最も支配的な誤りパターンを除去することができるので、BCH符号の連接は、誤りフロア除去を提供するだけでなく、必要とされる反復回数の削減も提供する。ポーラ符号のハミング重み分布は、ハミング距離が短いほど連接が高い等の固有の特徴を有するので、その方法は、ポーラ構成符号に基づくTPCの場合に特に有効である。さらに、BCH連接は、多数の非正則分極非アクティブ化(inactivation)に対する許容度を高めることによって、計算複雑度を更に緩和し、復号待ち時間を更に短縮することもできる。
いくつかの実施形態は、正則ポーラ符号化構成が、通信チャネル及び変調方式が送信コードワードビットごとに均一な伝送信頼性を与える状況に対処するという認識に基づく。容量及び凍結ビットロケーション設計を達成するという理論的証明のために、この仮定が必要とされる。しかしながら、より高次の変調、周波数選択性フェージング、経時的に変化するチャネル、及び多入力多出力(MIMO)チャネル等のいくつかの状況の結果として、送信ビットにわたって信頼性が不均一になる。
いくつかの実施形態は、正則ポーラ符号化が大きい(理論的には無限に大きい)符号にわたって最適な符号化効率に向かって収束するとき、符号長が短くなる場合でも、より多くの自由度を追加することによって、その実際の誤り訂正性能を改善できるという別の認識に基づく。
いくつかの実施形態は、通信チャネルのパラメータの変動に対する正則ポーラ符号の適応性が、コードワード内のデータビットの数を規定するパラメータ、符号化コードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化コードワード内のパリティビットの数を規定するパラメータ等のパラメータの値によって決まるという理解に基づく。それらのパラメータは、本明細書において、ポーラ符号の正則パラメータと呼ばれる。
いくつかの実施形態は、ポーラ符号の適応性を高めるために、正則パラメータに加えて、いくつかの他のパラメータが使用される必要があるという理解に基づく。そのような付加的なパラメータは、ポーラ符号の少なくとも1つの正則パラメータのカップリング値(coupling value)の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、ポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含むことができ、非正則ポーラ符号器は、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化する。
これらの付加的なパラメータは、本明細書において、非正則パラメータと呼ばれる。正則パラメータ及び非正則パラメータを用いて設計されるポーラ符号は、本明細書において、非正則ポーラ符号と呼ばれる。非正則ポーラ符号を用いてコードワードを符号化するポーラ符号器は、本明細書において、非正則ポーラ符号器と呼ばれる。
例えば、いくつかの実施形態は、SD復号を短い待ち時間で実行できるように、そのコードワード長が相対的に短い複数のポーラ符号を使用し、各SD復号が、潜在的な誤りを訂正するために、SD情報を他のポーラ復号器に前後に伝搬させる。このターボライクポーラ符号化及び復号アーキテクチャの場合、誤り訂正性能は、ポーラ符号にわたって「非正則性」を課すことによって、例えば、異なる符号化率、異なる凍結ビットロケーション、異なるコードワード長、異なるインターリーブ処理及び異なる分極カーネルを使用することによって高められる。更に別の実施形態において、ポーラ符号化アーキテクチャは、中間ステージにおいて非正則に置換される。複雑度を低減し、性能を改善するために、この非正則ポーラ符号アーキテクチャは、いくつかの分極演算を疎にディアクティベートすることによって、更に一般化される。いくつかの実施形態において、ディアクティベートする分極演算は、異なる非バイナリ及び高次カーネルを有することによって更に一般化される。
いくつかの実施態様において、通信チャネル及び/又は変調方式の結果として、送信コードワードビットに関する信頼性が不均一になるので、インターリーバを利用して誤り訂正性能を改善できるようにするが、誤り訂正性能を改善するには、インターリーバ及びポーラ符号構成を同時に設計することが要求される。したがって、一実施形態は、インターリーバ及びポーラ符号構成を同時に設計するシステム及び方法を開示し、インターリーバ及びポーラ符号構成は、不均一な信頼性を考慮に入れることによって交互に最適化される。この方法は、インターリーバによって実行される置換が、設計することができる1組のパラメータによってパラメータ化されるインターリーバ方式を利用する。
したがって、一実施形態は、通信チャネルを介して、符号化されたコードワードを送信する送信機を開示する。送信機は、送信されるソースデータを受け取るソースと、プロセッサによって動作し、ソースデータをポーラ符号で符号化し、符号化されたコードワードを生成する非正則ポーラ符号器であって、ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定され、ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器は、ポーラ符号の正則パラメータ及び非正則パラメータを用いてソースデータを符号化する、非正則ポーラ符号器と、符号化されたコードワードを変調する変調器と、被変調符号化コードワードを、通信チャネルを介して送信するフロントエンドとを備える。
別の実施形態は、通信チャネルを介して、符号化されたコードワードを送信する方法を開示する。方法は、送信されるソースデータを受け取ることと、ソースデータを非正則ポーラ符号で符号化し、符号化されたコードワードを生成することであって、非正則ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定され、ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器が、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化することと、符号化されたコードワードを変調することと、被変調符号化コードワードを、通信チャネルを介して送信することとを含む。
更に別の実施形態は、方法を実行するためにプロセッサによって実行可能であるプログラムを具現する非一時的コンピュータ可読記憶媒体を開示する。方法は、ソースデータを受け取ることと、ソースデータを非正則ポーラ符号で符号化し、符号化されたコードワードを生成することであって、非正則ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定され、ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器が、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化することと、符号化されたコードワードを変調することと、被変調符号化コードワードを、通信チャネルを介して送信することとを含む。
さらに、本開示の実施形態によれば、ソース情報を、通信チャネルにおいて使用されることになる符号化されたコードワードに符号化する符号器は、符号化されることになるソースデータを受信するデータ入力と、プロセッサと、プロセッサによって実行可能な符号器プログラムを記憶するメモリとを備え、符号器プログラムは、プロセッサに、ソースデータをターボ積符号(TPC)構造に符号化させ、TPC構造は、ソースデータに対応するデータブロックと、第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、この第1のパリティブロックは、第1の列部分、第1の角部分及び第1の底部分によって、データブロックの右端列、データブロックの右底角及びデータブロックの底列を覆うように配置される、第1のパリティブロックと、行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックであって、この第2のパリティブロックは、行パリティブロック、結合パリティブロック及び列パリティブロックを用いて、第1のパリティブロックを覆うように配置される、第2のパリティブロックとを備える。
別の実施形態は、符号器によってソースデータから符号化されたコードワードを復号する復号器を開示する。その復号器は、復号されることになるコードワードを受信するコードワード入力と、復号器プログラムに従ってコードワードをソースデータに復号するプロセッサと、プロセッサによって実行可能な復号器プログラムを記憶するメモリとを備え、行軟判定(SD)プロセス、列SDプロセス及び硬判定(HD)プロセスを含む復号器プログラムは、プロセッサに、復号プロセスに従ってターボ積符号化(TPC)構造を有するコードワードをソースデータに復号させ、復号プロセスは、一連の行SDプロセス及び列SDプロセスの少なくとも2回の反復と、少なくとも1つのHDプロセスとを含み、TPC構造は、ソースデータに対応するデータブロックと、第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、この第1のパリティブロックは、第1の列部分、第1の角部分及び第1の底部分によって、データブロックの右端列、データブロックの右底角及びデータブロックの底列を覆うように配置される、第1のパリティブロックと、行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックであって、この第2のパリティブロックは、行パリティブロック、結合パリティブロック及び列パリティブロックによって、第1のパリティブロックを覆うように配置される、第2のパリティブロックとを備える。
さらに、別の実施形態は、通信チャネルを介して、符号化されたコードワードを送信する送信機を開示する。その送信機は、送信されることになるソースデータを受け取るソースと、符号化されることになるソースデータを受信するデータ入力と、プロセッサと、プロセッサによって実行可能な符号器プログラムを記憶するメモリとを備え、符号器プログラムは、プロセッサに、ソースデータを積符号化構造に符号化させ、積符号化構造は、ソースデータに対応するデータブロックと、第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、この第1のパリティブロックは、第1の列部分、第1の角部分及び第1の底部分によって、データブロックの右端列、データブロックの右底角及びデータブロックの底列を覆うように配置される、第1のパリティブロックと、行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックであって、この第2のパリティブロックは、行パリティブロック、結合パリティブロック及び列パリティブロックを用いて、第1のパリティブロックを覆うように配置される、第2のパリティブロックと、を備え、符号化されたコードワードを変調する変調器と、変調され、符号化されたコードワードを、通信チャネルを介して送信するフロントエンドとを備える。
本開示の実施形態によるポーラ符号の符号化システム及び方法は、誤り訂正の性能を改善することができ、計算複雑度を緩和し、復号待ち時間を短縮し、プロセッサ(ハードウェアプロセッサ)の電力消費量を削減することもできる。
いくつかの実施形態によるデジタルデータの伝送のための通信システムの機能図である。 図1のシステムの符号器によって利用される例示的な符号化の概略図である。 一実施形態による、軟判定復号器によって実行される軟判定復号の方法のブロック図である。 いくつかの実施形態による、候補パスのリストを生成するリスト復号の概略図である。 いくつかの実施形態の原理を用いてビットロケーションごとの軟出力を求めるための、1組の復号された候補コードワードと軟入力との間の距離の計算の一例を示す図である。 コードワードのデータビット内の複数のCRC符号の埋め込みの概略図である。 コードワードのデータビット内の複数のCRC符号の埋め込みの概略図である。 いくつかの実施形態による、軟復号のための方法のブロック図である。 一実施形態による、チャネルを介して送信されるコードワードを復号する方法のブロック図である。 いくつかの実施形態による、非正則ポーラ符号でコードワードを符号化するように動作する非正則ポーラ符号器の概略図である。 一実施形態による、非正則ポーラ符号のパラメータを求める概略図である。 いくつかの実施形態による、不均一なチャネルのためのビットインターリーブ式ポーラ符号化変調の概略図である。 いくつかの実施形態による、不均一なチャネルのためのインターリーバ及びポーラ符号構成のための同時最適化手順のブロック図である。 いくつかの実施形態による、積符号化構造を有する例示的な連接誤り訂正符号の図である。 いくつかの実施形態による、階段符号化構造を有する例示的な連接誤り訂正符号の図である。 いくつかの実施形態による、非正則符号化構造を有する例示的な連接誤り訂正符号の図である。 いくつかの実施形態による、軟復号器を使用する連接誤り訂正符号の繰り返し復号手順のブロック図である。 いくつかの実施形態による、分極ステージ間に複数のインターリーブ処理ユニットを使用する例示的な非正則ポーラ符号化構造の図である。 いくつかの実施形態による、中間インターリーバを設計する方法のブロック図である。 いくつかの実施形態による、疎に選択された非アクティブ分極ユニットを有する例示的な非正則ポーラ符号化構造の図である。 いくつかの実施形態による、誤り確率の上限におけるディアクティベートされるポラライザの影響を示す、4の符号長の場合の非アクティブ分極ユニットを有する3つの例示的な非正則ポーラ符号化構造の図である。 いくつかの実施形態による、復号性能の許容範囲に基づく、非正則ポーラ符号化構造の選択的非アクティブポラライザの方法のブロック図である。 いくつかの実施形態による軟復号を実行するための受信機及び/又はいくつかの実施形態によるコードワードを符号化するための送信機の種々の構成要素を実現するのに適したシステムのブロック図である。 本発明のいくつかの実施形態による、BCH−TPC及びポーラTPCの積符号化構造を示す図である。 本発明のいくつかの実施形態による、復号プロセスを示すブロック図である。 本発明のいくつかの実施形態による、BCHベースTPC及びポーラベースTPCのビット誤り率(BER)性能を示す図である。 本発明のいくつかの実施形態による、CRC−1符号及びBCH符号と連接されるポーラ(256,240,4)に基づく行及び列構成符号の一例を示す図である。 本発明のいくつかの実施形態による、行SD復号器、列SD復号器、及びBCH HD復号器を使用する復号手順を示す図である。 本発明の実施形態による、図19Bの行SD復号器、列SD復号器、及びBCH HD復号器を使用する復号手順に従って、図19Aの符号化されたデータブロックを復号することによって得られるBER性能を示す図である。 本発明の実施形態による、高スループットシステムのためのパイプライン処理を伴う並列符号化の一例を示す図である。 本発明の実施形態による、高スループットシステムのためのパイプライン処理を伴う並列復号の一例を示す図である。
本発明の様々な実施形態が、図面を参照して以下で説明される。図面は縮尺どおり描かれておらず、類似の構造又は機能の要素は、図面全体にわたって同様の参照符号によって表されることに留意されたい。図面は、本発明の特定の実施形態の説明を容易にすることのみを意図することにも留意されたい。図面は、本発明の網羅的な説明として意図されるものでもなければ、本発明の範囲を限定するものとして意図されるものでもない。加えて、本発明の特定の実施形態と併せて説明される態様は、必ずしもその実施形態に限定されず、本発明の任意の他の実施形態において実施することができる。
図1は、いくつかの実施形態による、チャネル120を介して、送信機110から受信機130までデジタルデータを伝送するための通信システムを示す。例えば、通信チャネル120は、無線通信のための無線媒体、有線通信のための銅線、データストレージ移送のための固体ドライブ、光ファイバー通信のための光ファイバーケーブルを含む。通信中に、デジタルデータはチャネル内の雑音によって破損する可能性がある。送信機110は、ポーラ符号140等の前方誤り訂正(FEC)符号を用いて、信頼性のあるデータ通信を実現する。受信機が、復号器133を使用することによって、データを再生しようと試みる。
送信機110において、送信されるデータは、元のデータを収容するように構成されるソース111からもたらされる。ソースは、データを記憶するメモリ、データを受信する入力ポート、及び/又はデータを生成するデバイスを含むことができる。例えば、一実施形態において、ソースは入力音声信号をデジタルデータに変換する音声通信デバイスを含む。ソース111からの入力データは、FEC符号器112によって符号化される。符号化されたデータは、変調器113によって変調される。場合によっては、符号化されたデータは、コードワードと呼ぶことができる。変調器113は、種々のデジタル変調フォーマット、例えば、直交振幅変調(QAM)を使用し、直交周波数分割多重(OFDM)等の線形変換を伴う場合も、伴わない場合もある。被変調データはフロントエンド回路114を介してチャネルの中に送信され、フロントエンド回路は、例えば、光通信のための電気光学デバイス及び無線通信のための無線周波数デバイスを含むことができる。また、フロントエンドは、バンドパスフィルタ、プリコーディング、電力負荷、パイロット挿入及び予歪等の信号事前処理を含むこともできる。
チャネル120は送信信号を歪ませる。例えば、チャネルは、相加性白色ガウス雑音(AWGN)、同一チャネル干渉(CCI)、深いフェージング、インパルス雑音、シンボル間干渉(ISI)、カー効果に起因する非線形干渉(NLI)、及び線形色分散(CD)並びに他のハードウェア欠陥を付加する。
受信機130は、最初に、フロントエンド回路131を介して、チャネル出力を電気的な受信信号に変換し、そのフロントエンド回路は、通常、送信機にあるフロントエンド114の相補回路である。例えば、フロントエンドは、線形等化、非線形等化、適応フィルタリング、チャネル推定、キャリア位相再生、同期、及び分極再生を含む。受信信号は復調器132において復調され、送信コードワードのビットの初期推定値が生成され、それらのビットが、ソースデータを再生するために復号器133によって使用される。種々の実施形態において、復号器133は、ポーラ符号140のための軟出力復号器である。復号されたデータはデータシンク134に送出される。いくつかの実施形態において、復号器133は、復調器132からもたらされた受信コードワードからビットの対数尤度比(LLR)を示す値を生成する硬判定(HD)復号器である。いくつかの他の実施形態において、復号器133は、復号の軟出力を生成する軟判定復号器と、軟復号器から受信される軟出力に基づいて、受信コードワードからビットのLLRを示す値を生成する硬判定復号器との組み合わせを含む。
送信機110及び/又は受信機130は、メモリに動作可能に接続されるプロセッサを用いて実現することができる。送信機110及び受信機130の各々は、1つ又は複数のプロセッサ(図示せず)を備える。例えば、受信機130のメモリは、ポーラ符号化、復号器133の軟入力及び軟出力、復号の中間計算の結果及びパラメータのうちの1つ又は組み合わせに関連する何らかの情報を記憶することができる。例えば、ポーラ符号化コードワードは、1からなる下三角行列のクロネッカー累乗として形成される符号化行列を用いて符号化することができる。そのために、受信機のメモリは、コードワードを復号するために軟復号器のプロセッサによって使用される符号化行列を記憶することができる。
符号器112、変調器113、復調器132及び復号器133を含む、送信機110及び受信機130内の全ての構成要素は、ハードウェア、1つ以上のプロセッサ(ハードウェアプロセッサ)、コンピュータソフトウェア(プログラム又はプログラムモジュール)、又はハードウェア及びコンピュータソフトウェアの組み合わせによって実現することができる。
図2は、例示的なポーラ符号のために符号器112によって利用される例示的な符号化の概略図を示す。ただし、n=16個のコードワードビット210、k=10個のデータビット202、n−k=6個の凍結ビット201が存在する。10個のデータビットがデータビット202のロケーションに書き込まれ、一方、凍結ビット201は、既知の固定値に設定される(それは、実際には、簡単にするために全て0とすることができる)。したがって、この例において、ビット(u,u,u,u,u,u10,u11,u12,u14,u15)を10個のデータビットの値に設定し、残りのビット(u,u,u,u,u,u13)を既知の固定値に設定することによって、ベクトルu:=(u,...,un−1)が形成される。データインデックス集合は、この例の場合、I={1,2,4,6,9,10,11,12,14,15}であり、それは、パラメータn、k及び凍結ビットの固定値とともに、ポーラ符号仕様140を構成する。その概略図は、ベクトルu:=(u,...,un−1)をコードワードベクトルc:=(c,...,cn−1)に変換する手順を示し、それは、図示されるように、バイナリ排他的論理和(XOR)演算220を利用することを伴う。これらの演算は、全体的な手順が式
Figure 2020516119
を適用することに相当するように構造化されたパターンに従う。ただし、行列乗算はバイナリフィールド(すなわち、モジュロ2演算)を介して実行され、Bはn×nビット反転置換行列を表し、
Figure 2020516119
は行列
Figure 2020516119
の第mのクロネッカー累乗であり、m:=lognは分極ステージの数である。正則ポーラ符号の場合、ステージ当たりn/2回のXOR演算が存在し、結果として、全部でnm/2回の演算になる。各XOR演算は、本明細書において、便宜上、分極演算と呼ばれる。なぜなら、この演算は、ポラライザのような、アップグレードされたサブチャネル及びダウングレードされたサブチャネルを生成するためである。
図3は、一実施形態による、軟復号器133によって実行される軟復号の方法のブロック図を示す。復号器133は、メモリに動作可能に接続され、その方法のステップを実施するように構成されるプロセッサを含むことができる。
その方法は、逐次除去リスト(SCL)復号320を用いて受信コードワード310のビットの取り得る値を推定し、1組の候補コードワード325を生成し、各候補コードワード325と受信コードワード310との間の距離を求め(330)、対応する1組の距離335を生成する。その方法は、ビット系列内のビットの値の尤度350を、受信コードワードに最も近く、そのビットの位置において逆の値を有する候補コードワードの距離の差を用いて求める(340)。例えば、一実施形態は、その位置において「1」の値を有する最も近い候補の距離と、その位置において「0」を有する最も近い候補の距離との差に基づいて、軟入力の各ビット位置において軟出力を計算する。
図4は、いくつかの実施形態による、木構造400において複数の復号パスを検討することによって、候補復号パス420のリストを生成するSCL復号320の概略図を示す。復号プロセスは、第1のビットの両方の可能性を考慮し、復号パスのリスト内に初期の2つの候補421を生成するために、空の開始パス410からの分岐411で開始する。候補パス「0...」412は、リスト421内にあり、木構造400内の位置に対応する。次のビットロケーションのために、リスト内の候補復号パスがそれぞれ、次のビットの両方の可能性を条件付けるために分岐される。例えば、リスト内の候補は、第1のビットロケーション421を検討することから第2のビットロケーション422に進み、第2のビットロケーション422を検討することから第3のビットロケーション423に進むように分岐される。これは、木構造400において見られる分岐に対応する。分岐によって、リストサイズが増大するので、候補のリストを固定サイズに制限することによって、この増大が制限される。この図に示される例において、リストは3のサイズに制限される。第2の分岐後に、1つの候補パス413がリストから削除される。第3の分岐後に、3つの候補パス414、415及び416がリストから削除される。
図5は、いくつかの実施形態の原理を使用する、ビットロケーションごとの軟出力を求めるための、1組の復号された候補コードワード501と軟入力301との間の距離の計算の一例を示す。この例において、候補コードワード501のリストは3つの候補を含み、距離は二乗距離として求められる。そのため、軟入力301に対して、各候補の二乗距離が計算される(502)。異なる実施形態では、候補の数及び距離を求めるための指標は異なることができる。
(y,...,y)が軟入力301を表すものとし、(c,...,c)が特定の復号された候補コードワードを表すものとする。二乗距離は、二乗ユークリッド距離定式
Figure 2020516119
に従って計算される。各候補が、項(2c−1)によってバイナリ値{0,1}から{−1,+1}に変換されることに留意されたい。最終軟出力508の計算プロセス507は、その後、候補コードワード501のリストと、それぞれの二乗距離503とに基づいて、各ビットロケーションにわたって個々に実行される。ビットロケーションごとに、そのロケーションにおいて0を有する最も近い候補の二乗距離と、そのロケーションにおいて1を有する最も近い候補の二乗距離との差の関数から、軟出力が計算される。これは、式о=f(di,0−di,1)によって与えられる。ただし、оはビットロケーションiの場合の軟出力であり、di,0はロケーションiにおいて0を有する最も近い候補の二乗距離であり、di,1はロケーションiにおいて1を有する最も近い候補の二乗距離である。
例えば、一実施形態において、その関数は、距離差をスカラーで割ること、例えば、о=(di,0−di,1)/4を含む(ただし、この例では、スカラーは4である)。例えば、ロケーション504におけるビットの軟出力は、(1.81−2.84)/4=−0.257である。ただし、1.81はロケーション504において値0を有する唯一の候補コードワードの距離であり、2.84はロケーション504において値1を有する最も近い候補の距離である。例えば、ロケーション505におけるビットの軟出力は、(3.59−1.81)/4=0.445である。ただし、3.59はロケーション505において値0を有する唯一の候補コードワードの距離であり、1.81はロケーション505において値1を有する最も近い候補の距離である。
いくつかの実施形態において、ロケーション506におけるビットのように、候補の全てがそのビットロケーションにおいて同じ値を有する場合には、この式は適用できず、代わりに、そのロケーションのための軟出力は、所与のパラメータβ>0に従って設定される。ただし、候補の全てがそのロケーションにおいて値1を有する場合には、出力はо=+βに設定され、候補の全てがそのロケーションにおいて値0を有する場合には、出力はо=−βに設定される。複数の候補から軟判定出力値を計算する上記のプロセスは、チェイス処理と呼ばれる。一実施形態において、SCL復号におけるリストの数は1まで削減することができ、オフラインで既知の信頼性のない未凍結のビットに基づいて最も起こり得る誤りパターンを使用することによって、複数の候補を生成することができる。
誤り訂正性能を更に高めるために、いくつかの実施形態は、符号化効率をわずかに下げることを犠牲にしてデータビット内に巡回冗長検査(CRC:cyclic redundancy check)を埋め込む。この変更を加えるとき、パスのうちの少なくとも1つが有効なCRCを有するデータ系列に対応する場合には、代わりに、有効なCRCを有する最も可能性が高いパスが推定のために選択されるように、復号器を変更することができる(SCL+CRCと呼ばれる)。
図6A及び図6Bは、コードワードのデータビット内に少なくとも1つのCRC符号を埋め込む概略図を示す。例えば、図6Aは、復号の正確性を検証するために、1つのCRCがコードワードの最後に埋め込まれる例を示す。この例において、コードワード600のビットは、実際のメッセージデータを含む、単一のデータ部分601と、データ部分601から計算され、データ部分601を検証する(603)後続の単一のCRC符号602とに分割される。
図6Bは、複数のCRC符号を使用する例を示し、SCL複号の性能を改善するために第1のCRCがコードワードの中央に埋め込まれ、第2のCRCがコードワードの最後に埋め込まれる。コードワード内に埋め込まれるそのような複数のCRC符号を用いて、部分復号パスを検証することができる。そのようにして、CRCは、SCL復号器が復号手順の中間ステップにおいて候補コードワードを剪定するのを支援することができる。さらに、複数のCRC符号は、SCL復号における潜在的な誤り伝搬を防ぐことができる。
コードワード610のビットにおいて、複数のCRC符号が埋め込まれ、コードワード610を4つの部分に分割する。第1のデータ部分611に、第1のデータ部分611から計算され、第1のデータ部分611を検証する(613)第1のCRC部分612が後続する。第2のデータ部分614に、第2のデータ部分614から計算され、第2のデータ部分614を検証する(616)第2のCRC部分615が後続する。
図7は、いくつかの実施形態による軟復号のための方法のブロック図を示し、受信コードワードは複数のCRC符号を含む。例えば、一実施形態において、軟復号器133のプロセッサは、候補コードワードの一部が正しくないCRC符号を含むときに、受信コードワード内のCRC符号を含む場所によって決定される部分長において1組の候補コードワードを剪定する。
例えば、その方法は、部分的に復号された候補コードワードからCRC値を抽出し(710)、第1のCRC715を生成し、部分的に復号された候補コードワードに既知のCRC計算手順を適用することによってCRCを計算し(720)、第2のCRC725を生成する。
その方法は、第1のCRC715を第2のCRC725と比較し(730)、第1のCRCが第2のCRCに一致しない場合には、復号されたビットの取り得る組み合わせのリストから、部分的に復号された候補コードワードを削除する。
図8は、一実施形態による、チャネルを介して送信されるコードワードを復号する方法のブロック図である。この手順への軟入力801は、チャネルを介して受信される雑音を含むコードワードであり、それは、y:=(y,...,yn−1)によって表される。ただし、各yは、対応する符号ビットcの雑音を含む観測結果である。リスト復号手順は、インデックス0からn−1までのビットにわたって順次に進行する。ただし、ビットインデックスi∈{0,...,(n−1)}の場合の各繰り返し805において、以下のことが実行される:
データビットインデックスにおいて復号パスを分岐する(802)。
第1のインデックスがデータビットロケーションでない(すなわち、
Figure 2020516119
である)場合には、復号パスのリストは1つのパスで開始し、その場合、単一のパスが、uの既知の固定値に設定される第1のビットの推定値
Figure 2020516119
を含む。そうでない場合、すなわち、第1のインデックスがデータビットロケーションである(すなわち、0∈Iである)とき、復号パスのリストは、第1のビットが0又は1のいずれかである可能性を表す、2つのパス
Figure 2020516119
及び
Figure 2020516119
で開始する。
後続のビットインデックスi>0において、既存のパスが延長される。ビットインデックスがデータビットロケーションに対応する(すなわち、i∈Iである)場合には、各分岐にそれぞれ
Figure 2020516119
及び
Figure 2020516119
を追加することによって、各パスが2つのパスに分岐される。そうでない場合、すなわち、ビットインデックスがデータビットロケーションに対応しない(すなわち、
Figure 2020516119
である)とき、各パスは分岐されず、uの既知の固定値に設定される
Figure 2020516119
を加えることによって延長のみが行われる。
CRCが埋め込まれる場合には、パスのCRC妥当性を検査する(803)。
データビットが埋め込まれたCRC符号を含む場合には、これらのCRC符号を用いて、部分的に復号された無効なパスを破棄することができる。
ビットインデックスiにおいて、部分ベクトルのデータビットロケーション(u,...,u)が埋め込まれたCRC符号を含む場合、部分的に復号されたパスの自己一貫性を検査することができる。そうでない場合には、このステージにおいて何も行われない。また、特定のCRC符号が検査されると、後のインデックスに対して再検査される必要はない。
部分パス
Figure 2020516119
ごとに、そのデータビットロケーションにあるビットが、埋め込まれたCRC符号に対して自己一貫性があることを検査する。自己一貫性がないパスは、パスのリストから削除される。
パスリストを間引く(804)。
候補パスの指数関数的に大きくなる(それゆえ、扱いにくい)リストを取り扱うのを回避するために、リストは、固定リストサイズ限界Lまで間引かれる。
部分復号パス
Figure 2020516119
ごとに、この部分復号パスが正しいという相対的な統計的尤度
Figure 2020516119
が計算され、それはポーラ符号構造及び根底にあるチャネル統計値から得られる。
その後、最も高い尤度を有するL個のパスが保持され、一方、残りのパスはリストから削除される。
パスが完了するときループから抜ける(806)。
データインデックスi=n−1が検討された後にループは終了し、その手順は、候補パスを軟入力と比較することに移行する(807)。
各候補パスを軟入力と比較した(807)後に、候補パスの相対的な品質に基づいて、軟出力809が計算される(808)。
別の実施形態は、分極ステージにわたって信頼性情報を伝搬させるためにルックアップテーブル(LUT)を使用し、性能上の大きいペナルティを被ることなく、必要とされるLUTメモリサイズを最小化するために、量子化された信念メッセージが統計的に求められる。尤度統計値に基づいて出力される適応的LUTを用いて、凍結ビットロケーションを精緻化し、より高い符号化利得を達成し、量子化損失を補償する。
いくつかの実施形態において、復号中のビット尤度の計算は、いくつかの量子化ビットのみを用いて、計算複雑度を緩和し、メモリを削減する。一実施形態は、尤度の量子化されたものを単に近似するのではなく、着信するメッセージ及び発信するメッセージの統計値を考慮することによって、各分極演算において復号データを処理するために適応的LUTを使用する。例えば、分極演算子のダウングレードする分岐は低い信頼性のメッセージを生成し、それゆえ、ポラライザのアップグレードする分岐より、量子化ダイナミックレンジを小さくすべきである。そのステージ及びビットインデックスにおいて、異なるポラライザにおいて異なるLUTを使用するとき、量子化復号のペナルティを最小化することができる。
非正則ポーラ符号構成
いくつかの実施形態は、正則ポーラ符号化構成は、通信チャネル及び変調方式が送信コードワードビットごとに均一な伝送信頼性を与える状況に対処するという認識に基づく。容量及び凍結ビットロケーション設計を達成するという理論的証明のために、この仮定が必要とされる。しかしながら、より高次の変調、周波数選択性フェージング、経時的に変化するチャネル、及び多入力多出力(MIMO)チャネル等のいくつかの状況の結果として、送信ビットにわたって信頼性が不均一になる。いくつかの実施形態は、正則ポーラ符号化が大きい(理論的には無限に大きい)符号にわたって最適な符号化効率に向かって収束するとき、符号長が短くなる場合でもその実際の誤り訂正性能を改善できるという別の認識に基づく。
いくつかの実施形態は、通信チャネルのパラメータの変動に対する正則ポーラ符号化の適応性が、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータ等のパラメータの値によって決まるという理解に基づく。それらのパラメータは、本明細書において、ポーラ符号の正則パラメータと呼ばれる。
いくつかの実施形態は、ポーラ符号の適応性を高めるために、正則パラメータに加えて、いくつかの他のパラメータが使用される必要があるという理解に基づく。そのような付加的なパラメータは、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、ポーラ符号化の異なるステージにおけるディアクティベートされるXOR演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含むことができ、非正則ポーラ符号器は、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化する。
これらの付加的なパラメータは本明細書において非正則パラメータと呼ばれる。正則パラメータ及び非正則パラメータを用いて設計されるポーラ符号は、本明細書において、非正則ポーラ符号と呼ばれる。非正則ポーラ符号を用いてコードワードを符号化するポーラ符号器は、本明細書において、非正則ポーラ符号器と呼ばれる。
図9Aは、いくつかの実施形態による、コードワードを非正則ポーラ符号900で符号化し、符号化されたコードワードを生成するために、プロセッサによって動作する非正則ポーラ符号器の概略図を示す。非正則ポーラ符号器は、送信機110の符号器112に収容することができる。
非正則ポーラ符号900は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータ910によって規定される。非正則ポーラ符号900は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、ポーラ符号化の異なるステージにおけるディアクティベートされたXOR演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータ920によって更に規定される。いくつかの実施形態において、非正則ポーラ符号器は、非正則ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化する。
図9Bは、一実施形態による、非正則ポーラ符号のパラメータを求める概略図を示す。この実施形態において、送信機110は、通信チャネルのパラメータを求めるように構成されるチャネル推定器940を含む。例えば、通信チャネルのパラメータは、符号化されたコードワードのビットを送信するための不均一な信頼性の値、及び/又は信号対雑音比及び遅延プロファイル等のチャネルの他の統計値を含む。通信チャネルのパラメータは、パイロット及びトレーニングシンボルに基づく最小二乗チャネル推定、又はブラインド電力推定等の種々の方法を用いて求めることができる。
一実施形態において、送信機110は、通信チャネルのパラメータの異なる値への、正則パラメータ及び/又は非正則パラメータの異なる値間のマッピング930を記憶するメモリを含む。そのようにして、その実施形態は、チャネル推定器940によって求められた通信チャネルのパラメータに基づいて、ポーラ符号の正則パラメータ及び/又は非正則パラメータの値の組み合わせ935を選択することができる。
状況によっては、ポーラ符号の性能は、復号方法だけでなく、符号器における凍結ビットロケーションにも依存する。軟判定復号を容易にするために、軟判定復号中に尤度の統計値を処理することによって、分極効果を高めることができるように、凍結ビットロケーションが更に精緻化される。凍結ビットロケーション設計は、高次変調及び周波数選択性フェージングチャネルの場合に特に重要であり、その場合、異なる符号化ビットが異なる雑音強度で破損し、不均一なビット信頼性を生じさせる。その実施形態は、凍結ビットロケーションを選択するために尤度の統計値の知識を利用し、軟判定復号の性能を改善する。さらに、異なるマッピングは分極効果を劣化させる可能性があるので、そのような不均一な信頼性の場合に、符号化ビットを変調ビット上にマッピングする方法が重要である。それゆえ、凍結ビットロケーション設計に加えて、符号化ビットを変調ビット上にマッピングする注意深いインターリーブ処理設計が必要とされる。本発明の方法は、そのような高次変調及びフェージングチャネルの場合に凍結ビットロケーション及びインターリーブ処理を同時に設計する方法を提供する。
図10Aは、インターリーブ処理を伴う符号器の概略図を示し、ポーラ符号化112が符号化ビットc,...,c15を生成し、それらの符号化ビットは、インターリーバ1020によって、最下位ビット(LSB)プレーンから最上位ビット(MSB)プレーンにわたって、QAM変調器又はOFDM変調器1010において異なる変調ビットにマッピングされる。LSB及びMSBは異なるビット信頼性を有する。ビット桁位置(bit significance)に加えて、各被変調シンボルx,...,xは、例えば、周波数選択性フェージングチャネルに起因して、異なるチャネル雑音レベルを有する場合がある。本発明の方法は、高い復号性能が実現されるように、重要な符号化ビットを信頼性のある変調ビットに注意深くマッピングする。
図10Bは、不均一なチャネルの場合にインターリーバ及びポーラ符号構成を同時に最適化する手順を示す。この方法は、インターリーバによって実行される置換が、全ての取り得る置換を検討する代わりに、扱いやすいように最適化することができる1組のパラメータによってパラメータ化されるインターリーバ方式を利用する。例えば、インターリーブ処理の1つの実現形態は二次多項式置換(QPP:quadratic polynomial permutation)インターリーバであり、それは、符号化ビットインデックスiを以下のように変調ビットインデックスに並べ替える。
Figure 2020516119
ただし、(f,f,f)はインターリーバパラメータである。QPPインターリーブ処理の前後において、ポーラ符号化のためのインターリーブ処理を設計する自由度を高めるように、短い辞書的置換テーブル(lexicographical permutation tables)を使用することができる。
最初に、インターリーバは初期置換1001に設定される。その後、最も信頼性が高い擬似チャネルに対応するデータインデックス集合を選択することによって、この初期インターリーバ置換のためのポーラ符号構成が最適化される(1002)。その後、ポーラ符号構成及びインターリーバの誤り訂正性能が評価される(1003)。この評価は、シミュレーションによって実験的に、及び/又はデータインデックス集合によって選択された擬似チャネルの信頼性から計算される誤り限界によって解析的に実行することができる。例えば、各分極演算において、尤度の統計値は、バタチャリアパラメータ(Bhattacharyya parameter)、密度進化、ガウス近似、又は外因性情報転送(EXIT:extrinsic information transfer)方法によって追跡することができる。不均一な信頼性を取り込むために、一実施形態の方法は、従来にない追跡を使用する。例えば、バタチャリアパラメータは、ダウングレードする分岐i及びアップグレードする分岐jの場合に、それぞれ以下のように追跡される。
Figure 2020516119
ただし、
Figure 2020516119
はビットインデックスiの場合の分極ステージmにおけるバタチャリアパラメータである。バタチャリアパラメータは、ビット誤り率の上限に対応する。
いくつかの実施形態において、軟判定メッセージ伝搬を考慮するために、EXIT法が、分極演算のダウングレードする分岐及びアップグレードする分岐の場合にそれぞれ、以下のように、復号ステージにわたって外因性相互情報に関する信頼性を追跡する。
Figure 2020516119
ただし、
Figure 2020516119
は、チャネル出力から伝搬する相互情報量である。ここで、JTB(・)及び
Figure 2020516119
はテンブリンクのJ関数(ten Brink’s J-function)及びその逆関数を示し、すなわち、
Figure 2020516119
である。
復号後に相互情報量を計算すると、第iの入力ビットにおける誤り率は
Figure 2020516119
によって取得される。ただし、erfc(x)は相補誤差関数である。各分極ステージにおける相互情報量計算は、量子化された軟判定復号の場合に同一でないLUTを考慮に入れるべきである。具体的には、上記のJ関数は、連続ガウス関数から離散入力及び離散出力関数に変更され、その関数の相互情報量は、対応する遷移行列によって容易に計算することができる。さらに、EXIT追跡の式は、信念伝搬復号等の異なる復号方法に合わせて変更され、EXIT式は、隣接するポーラステージからの付加的なフィードバック情報を考慮するように変更される。EXIT追跡の式は、先行する分極ステージに加えて、次の分極ステージからのフィードバック情報を考慮することによって、BP復号等の異なる復号アルゴリズムの場合に容易に一般化されることに留意されたい。
次に、誤り訂正性能が収束した(すなわち、先行する繰り返しに対して大きく変化しない)か否かに基づいて、又は全繰り返し数に関する限界に達したか否かに基づいて、繰り返し最適化手順を継続するか、終了するかの決定が行われる(1004)。継続する場合には、ポーラ符号データセットインデックスが固定されている間にインターリーバ置換が最適化され(1005)、その後、インターリーバが固定されている間にポーラ符号データセットインデックスが再び最適化され(1002)、その後、ポーラ符号構成及びインターリーバの性能が再評価され(1003)、繰り返し最適化を継続するか、終了するかの決定が再び行われる(1004)。これらの繰り返しを終了した後に、最終結果は、同時に最適化されたインターリーバ及びポーラ符号構成1006である。凍結ビットロケーション及びインターリーブ処理のこの同時最適化は、コードワード長が長くなるほど、及び無線フェージングチャネルの場合に特に、増大した分極効果を与える。
いくつかの実施形態において、複数のポーラ符号が使用され、各コンポーネントポーラ符号は互いに連接され、軟判定復号出力が、複数のポーラ復号器にわたって前後に伝搬する。複数の連接されるポーラ符号の利点は、並列に復号できること、誤り訂正の潜在能力が高められること、及び復号待ち時間が短縮されることを含む。
図11は、積符号化構造を有する例示的な連接ポーラ符号を示す。積符号化構造は、2つのポーラ符号、長さn及びkのデータビットを有する第1の符号及び長さn及びkのデータビットを有する第2の符号を利用する。その符号化手順は、k行×k列の長方形データブロック1101に配列される、k×k個のデータビットを符号化する。データブロック1101の各行を第2のポーラ符号で系統的に符号化し、行ごとの計算されたパリティビットをk×(n−k)行パリティブロック1102の対応する行に書き込むことによって、行パリティブロック1102が生成される。データブロック1101の各列を第1のポーラ符号で系統的に符号化し、列ごとの計算されたパリティビットを(n−k)×k列パリティブロック1103の対応する列に書き込むことによって、列パリティブロック1103が生成される。行パリティブロック1102の各列を第1のポーラ符号で系統的に符号化し、列ごとの計算されたパリティビットを(n−k)×(n−k)行及び列パリティブロック1104の対応する列に書き込むことによって、行及び列パリティブロック1104が生成される。要するに、データブロック1101、行パリティブロック1102、列パリティブロック1103並びに行及び列パリティブロック1104がn×nコードワードブロックを形成し、それをシリアルに変換し、通信チャネルを介して送信することができる。いくつかの実施形態において、積ポーラ符号化は、2次元の平方構造から、より高次の結合、例えば、3次元の立方構造に拡大される。いくつかの実施形態において、行及び列内の各コンポーネントポーラ符号化は非正則に異なるパラメータを有し、例えば、繰り返し復号のための性能を改善するために、凍結ビットロケーションは同一ではない。通常の多次元積符号化の場合、符号化及び復号は任意の特定の順序及び方向とすることができ、一方、復号の順序は、チャネル不均一性及びポーラ非正則性の存在時にEXIT軌道解析に基づくスケジューリング最適化法によって最適化することができる。
図12は、階段符号化構造を有する空間的に結合されるポーラ符号化の別の例を示す。この符号化方式は、階段に類似している構造に配置される平方ブロックを伴う。「ブロック0」の番号を付される、構造1201内の第1のブロックは、既知の固定値に設定されるビットの平方ブロックを含む。後続のブロックは「ブロック1」、「ブロック2」等と番号を付され、それぞれデータ部分及びパリティ部分を含む。例えば、「ブロック1」は、「ブロック1:データ」1211及び「ブロック1:パリティ」1212を含む。この図は5つのブロックを示すが、この構造は、それより多いブロック又は少ないブロックに容易に一般化される。各平方ブロックは、n×nの大きさを有する。奇数の後続ブロックの場合、データ部分(例えば、1211、1231)は大きさn×kを有し、パリティ部分(例えば、1212、1232)は大きさn×(n−k)を有する。偶数の後続ブロックの場合、データ部分(例えば、1221、1241)は大きさk×nを有し、パリティ部分(例えば、1222、1242)は大きさ(n−k)×nを有する。この符号化構造は、n+k個のデータビットを長さ2nのコードワードに符号化するコンポーネントポーラ符号を利用する。初期の「ブロック0」後に4つの後続ブロックを含む、図示される具体例の場合、n×k×4ビットのデータを最初に後続ブロックのデータ部分1211、1221、1231、1241に書き込むことによって、それらのデータブロックが符号化される。その後、後続ブロックのパリティ部分1212、1222、1232、1242が以下のように順次に生成される。
各奇数ブロックのパリティ部分1212、1232の各行が、先行するブロックの対応する行と、同じブロックのデータ部分の対応する行との連接を系統的に符号化することによって生成される。例えば、「ブロック1」のパリティ部分1212の行iが、「ブロック1」のデータ部分1211の行iと連接される「ブロック0」1201の行iの系統的な符号化によって生成されたパリティビットによって求められる。別の例において、「ブロック3」のパリティ部分1232の行iが、「ブロック2」の行iの系統的な符号化によって生成されたパリティビットによって求められ、その「ブロック2」の行iは、「ブロック2」のパリティ部分1222の行iと連接される「ブロック2」のデータ部分1221の行iを含み、それは更に「ブロック3」のデータ部分1231の行iと連接される。
各偶数ブロックのパリティ部分1222、1242の各列は同様に生成されるが、その手順は、行ではなく、列にわたって動作する。例えば、「ブロック2」のパリティ部分1222の列iが、「ブロック1」の列iの系統的な符号化によって生成されたパリティビットによって求められ、その「ブロック1」の列iは、「ブロック1」のパリティ部分1212の列iと連接される「ブロック1」のデータ部分1211の列iを含み、それは更に「ブロック2」のデータ部分1221の列iと連接される。
階段符号化手順によって生成される連接コードワード全体が、初期の「ブロック0」後の後続ブロック内の全ビットであり、「ブロック0」は、既知の固定値に設定されるので、送信される必要はない。「ブロック1」内のビット、「ブロック2」内のビット等は、通信チャネルを介して送信するためにシリアルに変換される。階段ポーラ符号化構造の利点は、対応するコードワード長を有する単一のポーラ符号化に比べて待ち時間が短縮されることを含む。軟判定復号は並列に実行することができ、この実施形態では、待ち時間の少ないデータ通信のために、隣接する復号器にわたる少ない数の繰り返しがスライディングウィンドウのように利用される。空間的に結合されるポーラ符号化の他の例は、編み上げ構造、畳み込み構造、テールバイティング、トーラステールバイティング(torus tail-biting)等を含む。各コンポーネントポーラ符号化の正則パラメータは、繰り返し軟復号が潜在的な誤りを迅速に訂正できるように、個別に非正則に設計される。
正則ポーラ符号化は、凍結ビットロケーションを決定する、設計の自由度が限られる。いくつかの実施形態は、符号長、符号化率及び凍結ビットロケーション等の異なるパラメータを伴う複数のポーラ符号を有することによって、自由度を高め、軟判定復号を容易にする。
詳細には、図13は、非正則符号化構造を有する例示的な連接ポーラ符号を示す。この符号化方式は、凍結ビットロケーションが同一でない非正則構造において異なるコードワード及びデータ長を有するポーラ符号の組み合わせを利用する。連接符号全体のデータビットは1つ以上の長方形ブロックに配置され、そのブロックは垂直に積重され、その左端に沿って位置合わせされる。図示される例では、データビットの2つのブロック1301及び1302が存在し、それぞれk×k及びk×kの大きさを有する。その後、データブロックの右に1つ以上の行パリティブロックが水平に付加され、行パリティブロックの各行は、その行が付加されるデータビットの対応する行の系統的な符号化によって生成されたパリティビットによって求められる。図示される例では、2つの行パリティブロック1311及び1312が存在する。詳細には、大きさk×pを有する第1の行パリティブロック1311が、k個のデータビットを長さ(k+p)のコードワードに符号化するコンポーネントポーラ符号で第1のデータブロック1301の行を系統的に符号化することによって生成される。大きさk×pを有する第2の行パリティブロック1312が、第2のデータブロック1301の行を系統的に符号化することによって同様に生成されるが、ここでは、k個のデータビットを長さ(k+p)のコードワードに符号化するコンポーネントポーラ符号を使用する。次に、データビットブロック及び行パリティブロックの底部に列パリティブロックが垂直に付加され、列パリティブロックの各列は、対応するデータ列と、そのデータ列が付加されるパリティビットとの系統的な符号化によって生成されたパリティビットによって求められる。図示される例では、3つの列パリティブロック1321、1322及び1323が存在する。詳細には、大きさp×kを有する第1の列パリティブロック1321が、(k+k)個のデータビットを長さ(k+k+p)のコードワードに符号化するコンポーネントポーラ符号を用いて、両方のデータブロック1301及び1302の最初のk個の列を系統的に符号化することによって生成される。大きさp×kを有する第2の列パリティブロック1322が、(k+k)個のデータビットを長さ(k+k+p)のコードワードに符号化するコンポーネントポーラ符号を用いて生成される。第2の列パリティブロック1322の異なる列が、2つのデータブロック1301及び1302、並びに2つの行パリティブロック1311及び1312の異なる部分に重なることに留意されたい。第2の列パリティブロック1322の各列が、その直上の列を系統的に符号化することによって生成される。
図13は、1つの特定の例示的な配置のみを示すが、この一般概念は、様々なコンポーネントポーラ符号を利用するデータブロック、行パリティブロック及び列パリティブロックの数多くの取り得る非正則配置を含む。例えば、プロトグラフに基づくポーラ符号化構造が構成され、その構造では、並列ポーラ符号がシフト演算によって各ポラライザにおいて混合される。別の例は、レートレス(rateless)能力を与えるために、増え続ける階段構造を使用し、受信機が復号完了を肯定応答するまで、コンポーネントポーラ符号によってパリティビットのみが絶えず生成される。それゆえ、非正則符号化構造、及び異なる符号化パラメータを有する種々のコンポーネントポーラ符号の適用が、連接符号のコードワード全体にわたって様々な自由度(それゆえ、様々な程度の誤り訂正性能)をもたらし、それは不均一な通信チャネルの場合に有用な可能性がある。通信チャネルを介して送信するために、このコードワード全体がシリアルに変換され、誤り訂正性能利得を潜在的に得るために、不均一なチャネルを介して送信する前に、このシリアル変換を、インターリーバを介して置換することができる。
図14は、種々のコンポーネント符号に適用される軟判定復号器を使用する連接ポーラ符号の繰り返し復号手順のブロック図である。最初のステップは、チャネル出力、すなわち、通信チャネルを介して受信された雑音を含むコードワードを伴う軟判定復号器のための軟入力を初期化すること(1400)である。その後、連接ポーラ符号構成及び復号スケジュールの仕様1401が、連接誤り訂正符号の構造と、各復号繰り返しにおいてどのコンポーネント符号(複数の場合もある)が軟復号されるか(1410)とを規定する。1つ以上のコンポーネント符号1410の軟復号は軟出力を生成し、軟出力は、復号スケジュール1401によって規定されるような、次の繰り返しのための軟入力を更新するために使用される。次に、復号スケジュール1401によって規定されるように、次の繰り返しに進むか、又は繰り返し復号手順1411から抜けるかの判断が行われる。この復号順序スケジュールは、例えば、低遅延復号のためのスライディングウィンドウ、及び高度並列処理のためのフラッディングスケジューリングを含む。復号繰り返しを継続する場合には、その手順は、復号スケジュール1401において規定されるように選択される1つ以上のコンポーネント符号の軟判定復号1410に戻る。このプロセスは、復号スケジュール1401が中止すべきであることを示すまで繰り返し、結果として、繰り返し復号によって最終的な軟出力が生成され、そこから復号されたビットが求められる(1420)。
例えば、図11に示されるような、積符号の場合、例示的な復号スケジュールは、一定の繰り返し数が経過するまで、行コンポーネント符号及び列コンポーネント符号の軟復号を交互に行うことになる。更に別の実施形態では、各コンポーネントポーラ符号は、軟判定復号を容易にするために付加的な非正則性を有する。
図15Aは、いくつかの分極ステージ間、例えば、各分極ステージ間にインターリーバ1510を有する、非正則ポーラ符号の一例を示す。変調マッピングインターリーバ1520とともに、及び/又はそれに加えて、この実施形態は、中間インターリーバを注意深く設計することによって、計算が複雑になるという更なるペナルティを伴うことなく、より多くのインターリーブ処理ユニット1510を利用して、復号性能を改善する。
図15Bは、計算複雑度を管理しながら、中間インターリーバを設計する方法のブロック図を示す。この手順は、図10Bに示されるような不均一なチャネルの場合にインターリーバ及びポーラ符号構成を同時に最適化するための手順に類似であり、その手順の同じサブ構成要素のうちのいくつかを使用する。最初に、インターリーバが、いくつかの初期置換に設定される(1501)。その後、最も信頼性の高い擬似チャネルに対応するデータインデックス集合を選択することによって、インターリーバのこれらの初期置換に対してポーラ符号構成が最適化される(1502)。その後、ポーラ符号構成及びインターリーバの誤り訂正性能が評価される(1503)。次に、誤り訂正性能が収束した(すなわち、先行する繰り返しに対して大きく変化しない)か否かに基づいて、又は全繰り返し数に関する限界に達したか否かに基づいて、繰り返し最適化手順を継続するか、終了するかの決定が行われる(1504)。継続する場合には、ポーラ符号データセットインデックスが固定されている間にインターリーバ置換が最適化され(1505)、その後、インターリーバが固定されている間にポーラ符号データセットインデックスが再び最適化され(1502)、その後、ポーラ符号構成及びインターリーバの性能が再評価され(1503)、繰り返し最適化を継続するか、終了するかの決定が再び行われる(1504)。これらの繰り返しを終了した後に、最終結果は、同時に最適化されたインターリーバ及びポーラ符号構成1506である。
この手順と図10Bによって示される手順との間の顕著な違いは、インターリーバの最適化1505が、ただ1つの置換ではなく、複数の置換の最適化を取り扱うことである。図10Bの手順において行われるように、これらのインターリーバ置換は、各インターリーバの個々の最適化を扱いやすくするためにパラメータ化することができる。しかしながら、複数のインターリーバの全ての組み合わせにわたるブルートフォース探索は、計算複雑度を著しく高める可能性がある。計算コストを管理するために、インターリーバは、代わりに、順次に最適化され、すなわち、最適化スケジュール1507に従って他のインターリーバを固定したまま、一度にインターリーバのうちの1つを個別に最適化する。最適化スケジュール1507は、例えば、インターリーバ最適化1505の一度の実行中に全てのインターリーバが順次に最適化されるように指定することができるか、又は別の例として、繰り返し符号構成手順全体において、インターリーバ最適化1505を何度も実行する間にこの選択されるサブセットを順番に入れ替えながら、インターリーバ最適化1505の一度の実行中にインターリーバのサブセットのみが順次に最適化されるように指定することができる。
図16Aは、いくつかのXOR分極ユニットがディアクティベートされる、非正則ポーラ符号化構造の別の例を示す。非アクティブポラライザを注意深く選択することによって、誤り訂正性能を改善することができ、符号化及び復号のための計算複雑度を低減することができる。また、非アクティブ分極ユニットのいくつかのセットにより、部分的に並列の復号が可能になり、復号の待ち時間が短縮される。非アクティブポラライザのロケーションは、誤り限界が貪欲的に最小化されるようにEXIT法で誤り限界を解析することによって決定される。大部分のポラライザは復号性能を著しくは劣化させないので、より多くの非アクティブポラライザを選択することによって、この非正則ディアクティベーションは復号複雑度を著しく低減することができる。
図16Bは、ポラライザをディアクティベートすることによって与えられる利点を例示する、4の符号長の場合の非正則ポーラ符号化構造の3つの例を示す。正則ポーラ符号化1620は2つの分極ステージ1621、1622を有し、各ステージは2つのポラライザユニット1623、1624及び1625、1626を有する。各ポラライザユニットは、不良のサブチャネルと良好なサブチャネルとを与える。例えば、符号化された4つのビット{c,c,c,c}が0.5のバタチャリアパラメータで均一な信頼性を有するとき、第1の分極ステージ1621内の第1のポラライザユニット1623は、0.75のバタチャリアパラメータを有する不良のビットc’と、0.25のバタチャリアパラメータを有する良好なビットc’とを与える。同様に、第1の分極ステージ1621内の第2のポラライザユニット1624は、0.75のバタチャリアパラメータを有する不良のビットc’と、0.25のバタチャリアパラメータを有する良好なビットc’とを与える。第2の分極ステージ1622内の第1のポラライザユニット1625は、0.9375のバタチャリアパラメータを有する不良のビットuと、0.5625のバタチャリアパラメータを有する良好なビットuとを与える。
第2の分極ステージ1622内の第2のポラライザユニット1626は、0.4375のバタチャリアパラメータを有する不良のビットuと、0.0625のバタチャリアパラメータを有する良好なビットuとを与える。0.5の符号化率の場合、低いバタチャリアパラメータを有する2つの最良のビット{u,u}が情報データとして選択され、一方、高いバタチャリアパラメータを有する残りの2つの不良のビット{u,u}が凍結ビットとして選択される。この正則ポーラ符号化は、1−(1−0.4375)(1−0.0625)=0.473の上限(UB)と同等の誤り率性能を提供すると予想される。
非正則ポーラ符号化1630の一例が、第3のポラライザユニット1625をディアクティベートする(1610)。この非アクティブポラライザは、ビット{u,u}のための中間ビット{c’,c’}の信頼性を変更しないので、それらのバタチャリアパラメータはいずれも0.75である。しかしながら、それらのビットは凍結ビットになるほど既に信頼性がない。それゆえ、情報ビット{u,u}は正則ポーラ符号化1620と同じ信頼性を有するので、ポラライザユニット1625をディアクティベートすることによって、誤り率性能は影響を及ぼされない。この例は、この原理を利用する実施形態が、いかなる性能ペナルティも引き起こすことなく、重要でないポラライザユニットをディアクティベートすることによって、計算複雑度を低減できることを示唆する。
非正則ポーラ符号化1640の別の例は、より重要な利点を示し、すなわち、複雑度を低減することによって誤り率性能を改善することができる。この非正則ポーラ符号化1640は、第4のポラライザユニット1626をディアクティベートする(1610)。それゆえ、ビット{u,u}の信頼性は、0.25のバタチャリアパラメータを有する中間ビット{c’,c’}と同じままである。結果として生じるUBは1−(1−0.25)(1−0.25)=0.4375であり、それは、正則ポーラ符号化1620より良好である。この例は、ポラライザユニットをディアクティベートすることが、計算複雑度を低減できるだけでなく、情報ビットの信頼性を一律にすることによって、誤り率性能も改善できることを示唆する。
非アクティブポラライザユニットを用いる非正則ポーラ符号化は、正則ポーラ符号化より高い設計自由度を有することができる。具体的には、N’=nlog(n)/2個のポラライザユニットが存在するので、非アクティブポラライザユニットのロケーションを選択するのに
Figure 2020516119
個の可能性がある。Dをサイズn/2×log(n)のアクティベーション行列とし、その第(i,j)のエントリが、第jの分極ステージにおける第iのポラライザユニットがアクティブであるか、又は非アクティブであるかを表す「1」又は「0」のいずれかであるとする。例えば、正則ポーラ符号化1620は、
Figure 2020516119
の全て1のアクティベーション行列を有し、非正則ポーラ符号化1630は、
Figure 2020516119
を有し、非正則ポーラ符号化1640は
Figure 2020516119
を有する。取り得る非正則ポーラ符号の全数は指数関数的に増加していくので、長い非正則ポーラ符号化の場合にアクティベーション行列を最適化するのは容易ではない。良好な非正則ポーラ符号化を達成するアクティベーション行列を設計するために、本発明において貪欲リスト探索が使用される。
図16Cは、いくつかの実施形態による、非正則ポーラ符号化構造の非アクティブポラライザを選択する方法のブロック図を示す。その方法は、正則ポーラ符号化として、全て1になるようにアクティベーション行列1602を初期化する(1601)。次に、その方法は、先行するアクティベーション行列をディアクティベートする(1603)、すなわち、要素を「1」から「0」に変更する。ディアクティベーションが、全ての取り得るN’個のロケーション1604の場合に検討される。その後、非正則ポーラ符号化ごとに誤り率確率が計算される。ここで、誤り率性能のUBの解析中に、上記と同様にインターリーバ及び凍結ビットロケーションが最適化される。その方法は、最も小さい誤り確率を有する最良のL’個の非正則ポーラ符号化を選択する(1606)。選択された非正則ポーラ符号化ごとに、その方法は、異なるポラライザユニット1607を更にディアクティベートする(1603)。その手順は、終了条件が満たされるまで継続する(1608)。終了条件は、例えば、誤り率性能が最小化される場合、又は誤り率性能が、計算複雑度を最小化する正則ポーラ符号化の性能より悪くなる場合を含む。リスト探索が終了した後に、最適化されたアクティベーションテーブル、インターリーバ及び凍結ビットロケーションを有する非正則ポーラ符号化がもたらされる(1609)。
正則の系統的ポーラ符号器の場合に行われたように、鏡面対称の構造のような2回の非正則ポーラ符号化を使用することによって、それらの非正則ポーラ符号のいかなる変更も伴うことなく系統的符号化が可能であることに留意されたい。この手順の結果として系統的符号化が生じ、疎にされた非正則ポーラ符号化の場合であっても、ソースデータシンボルが、符号化されたデータシンボルと同じロケーションに現れる。
ポラライザユニットのXORをディアクティベートすることは、
Figure 2020516119
のポーラカーネルを非アクティブロケーションにある
Figure 2020516119
の別の最大階数恒等カーネルに変更することに相当する。この認識に基づいて、疎にされた非アクティブポラライザユニットに基づく非正則ポーラ符号化が、非バイナリ及び高次のカーネルの場合に更に一般化される。例えば、いくつかの実施形態は、4変数ガロア域(すなわち、モジュロ4演算)の場合に、
Figure 2020516119
等の異なる最大階数非バイナリカーネルを有する非正則ポーラ符号化を使用する。それらの異なる非バイナリカーネルは、誤り率性能を改善するために、及び計算複雑度を低減するために、ポラライザユニットごとに疎に割り当てられる。
更に別の実施形態は、高次のカーネルの非正則混合、例えば、次数3のカーネルの場合、
Figure 2020516119
を、そして次数4のカーネルの場合、
Figure 2020516119
を非正則に使用する。高次及び非バイナリカーネルを組み合わせることもできる。
図17は、いくつかの実施形態による軟復号を実行するための受信機、及び/又はいくつかの実施形態によるコードワードを符号化するための送信機の異なる組み合わせを実現するのに適したシステムのブロック図を示す。システム1700は、接続1720を通して他の構成要素に動作可能に結合することができる、センサ1710、慣性測定ユニット(IMU)1730、プロセッサ1750、メモリ1760、送受信機1770及びディスプレイ/画面1780のうちの1つ又は組み合わせを含むことができる。接続1720は、バス、ライン、ファイバー、リンク又はその組み合わせを含むことができる。
送受信機1770は、例えば、1つ以上のタイプの無線通信ネットワークを通じて1つ以上の信号を送信することを可能にする送信機と、1つ以上のタイプの無線通信ネットワークを通じて送信された1つ以上の信号を受信する受信機とを備えることができる。送受信機1770は、様々な技術に基づいて無線ネットワークとの通信を可能にすることができる。これらの技術は、標準規格のIEEE802.11ファミリーに基づくことができるフェムトセル、Wi−Fiネットワーク又は無線ローカルエリアネットワーク(WLAN)、標準規格のIEEE802.15xファミリーに基づくBluetooth(登録商標)、近距離場通信(NFC)、ネットワーク等の無線パーソナルエリアネットワーク(WPAN)、及び/又はLTE、WiMAX等の無線ワイドエリアネットワーク(WWAN)等であるが、これらに限定されるものではない。システム1700は、有線ネットワークを通じて通信する1つ以上のポートを備えることもできる。
いくつかの実施形態では、プロセッサ1750は、IMU1730から入力を受信することもできる。他の実施形態では、IMU1730は、3軸加速度計(複数の場合もある)、3軸ジャイロスコープ(複数の場合もある)、及び/又は磁気計(複数の場合もある)を備えることができる。IMU1730は、速度、方位、及び/又は他の位置関連情報をプロセッサ1750に提供することができる。いくつかの実施形態では、IMU1730は、測定された情報を、センサ1710による各画像フレームの捕捉と同期して出力することができる。いくつかの実施形態では、IMU1730の出力は、プロセッサ1750がセンサ測定値を融合し及び/又は融合された測定値を更に処理するのに部分的に用いられる。
また、システム1700は、カラー画像及び/又は深度画像等の画像をレンダリングするスクリーン又はディスプレイ1780を備えることができる。いくつかの実施形態では、ディスプレイ1780は、センサ1710によって捕捉されたライブ画像、融合画像、拡張現実(AR)画像、グラフィカルユーザーインターフェース(GUI)、及び他のプログラム出力を表示するのに用いることができる。いくつかの実施形態では、ディスプレイ1780は、ユーザーが、仮想キーボード、アイコン、メニュー、又は他のGUI、ユーザージェスチャー及び/又はスタイラス及び他の筆記用具等の入力デバイスの或る組み合わせを介してデータを入力することを可能にするタッチスクリーンを備えることができ及び/又はこのようなタッチスクリーンとともに収容することができる。いくつかの実施形態では、ディスプレイ1780は、液晶ディスプレイ(LCD)又は有機LED(OLED)ディスプレイ等の発光ダイオード(LED)ディスプレイを用いて実施することができる。他の実施形態では、ディスプレイ1780は、ウェアラブルディスプレイとすることができる。
例示的なシステム1700は、図示した機能ブロックのうちの1つ以上の追加、組み合わせ、又は省略等によって、本開示と整合性を有するように様々な方法で変更することもできる。例えば、いくつかの構成では、システム1700は、IMU1730又はセンサ1770を備えていない。いくつかの実施形態では、システム1700のいくつかの部分は、1つ以上のチップセット等の形態を取る。
プロセッサ1750は、ハードウェア、ファームウェア及びソフトウェアの組み合わせを用いて実現することができる。プロセッサ1750は、センサ融合及び/又は融合した測定値を更に処理するための方法に関連付けられる計算手順又はプロセスの少なくとも一部を実行するように構成可能な1つ以上の回路を表すことができる。プロセッサ1750は、メモリ1760から命令及び/又はデータを引き出す。プロセッサ1750は、1つ以上の特定用途向け集積回路(ASIC)、中央及び/又はグラフィカル処理ユニット(CPU及び/又はGPU)、デジタルシグナルプロセッサ(DSP)、デジタル信号処理デバイス(DSPD)、プログラマブル論理デバイス(PLD)、フィールドプログラマブルゲートアレイ(FPGA)、コントローラー、マイクロコントローラー、マイクロプロセッサ、埋め込みプロセッサコア、電子デバイス、本明細書において記述される機能を実行するように設計された他の電子ユニット、又はその組み合わせを用いて実現することができる。
メモリ1760は、プロセッサ1750の内部に、及び/又はプロセッサ1750の外部に実装することができる。本明細書において使用されるときに、「メモリ」という用語は、任意のタイプの長期、短期、揮発性、不揮発性又は他のメモリを指しており、任意の特定のタイプのメモリ若しくはメモリの数、又はメモリが記憶される物理媒体のタイプに制限されるべきではない。いくつかの実施形態では、メモリ1760は、軟復号及びポーラ符号化を容易にするプログラムコードを保持する。
いくつかの実施形態において、軟復号に加えて、又はその代わりに、プロセッサ1750は、軟復号アプリケーション1755のうちの1つ又は組み合わせを実行することができる。例えば、連接ECCを復号するために復号の軟出力を使用することができ、そのECCは複数のコンポーネントECCから形成され、それらのコンポーネントを組み合わせて、より高い性能の符号が生成される。別の例は繰り返し等化及び復号を利用するシステムであり、そのシステムでは、復号器からの軟判定出力が復調器にフィードバックされ、復号器入力が繰り返し精緻化される。更に別の例は、復号された出力に作用すること、例えば、出力をディスプレイ1780上に表示すること、出力をメモリ1760に記憶すること、送受信機1770を用いて出力を送信すること、及び/又は出力及びセンサ1710の測定値に基づいて、動作を実行することである。
ポーラベースターボ積符号(TPC)
図18Aは、本発明のいくつかの実施形態による、拡張BCH符号に基づくターボ積符号(TPC)(eBCH−TPC)181及びポーラ符号に基づくターボ積符号(ポーラ−TPC)182を示す、サイズ(256,239)の積符号(図11)の正方形の変形形態を示す。
BCH−TPC181は、eBCH(n,k,d)によって表されるn=256の行方向拡張BCH符号と、他方のn=256の列方向拡張BCH符号、eBCH(256,239,6)とを使用する。ここで、n=256、k=239及びd=6は、構成符号に関するコードワード長、情報長及び最小ハミング距離を表す。一方、ポーラ−TPC182は、ポーラ(256,239,4)によって表されるn=256の行方向ポーラ符号と、n=256の列方向ポーラ符号ポーラ(256,239,4)とを使用する。ポーラ−TPC182は、BCH構成符号の代わりに、ポーラ構成符号を使用する。短符号長の高速ポーラ符号の最小ハミング距離は、BCH符号より短い可能性があるが(すなわち、d=6に対してd=4)、ポーラ符号のハミング重み分布は、図18Cに示されるように、十分に構造化されるので、誤り率性能はBCH−TPCより優れている可能性がある。バースト誤りの影響を最小化するために、TPCコードワードは一般に、送信する前にスクランブルされるか、又はインターリーブされる。行及び列構成符号は異なる長さを使用することができ、TPCは、空間的に結合することによって、より高次元の積符号に拡張できることに留意されたい。
TPCの主な利点は、並列計算の能力、構成符号あたりの低電力復号、最小ハミング距離の指数関数的増加、及びSD復号反復を伴うMLに迫る性能を含む。m次元TPCの場合、最小ハミング距離は、dとして指数関数的に増加することができる。ポーラ−TPCは、並列に処理することができないSCLポーラ復号の主な欠点を解消することができる。
図18Bは、行SD復号器1813及び列SD復号器1814を含む、復号器133を使用する復号手順1801、1802、1823及び1824を示すフローチャートである。復号手順1801及び1802はそれぞれ、BCH−TPC181及びポーラ−TPC182に関して実行される。この場合、復号手順1801及び1802は、図示されるように、行SD復号器1813及び列SD復号器1814を用いて、2回だけ反復的に実行される。
さらに、BCH−TPC181及びポーラ−TPC182は、eBCH(256,239,6)×eBCH(256,239,6)及びポーラ(256,239,4)×ポーラ(256,239,4)に対応する。
復号器133(TPC復号器)は最初に、行SD復号器1813を用いて行方向SD復号を実行し、その後、Pyndiahのチェイス処理によって生成された外因性情報が、列方向SD復号器1814に送り込まれる。行SD復号器1813及び列SD復号器1814は、何も性能を損失することなく、順序を入れ替えることができることに留意されたい。TPC復号手順は、或る特定の反復回数にわたって、復号器1813及び1814を使用することによって行及び列SD復号プロセスを反復する。また、復号器1813によるSD復号は、実現するために、3要素メッセージパッシング等の量子化されたルックアップテーブルを使用することができる。
図18Cは、本発明のいくつかの実施形態による、239/256の符号化率の場合に256ビットのコードワード長においてBCH−TPC181及びポーラ−TPC182を使用するビット誤り率(BER)性能を示す。
2回反復にわたって一連の行復号器1813及び列復号器1814を用いてBCH−TPC181及びポーラ−TPC182をそれぞれ復号することによって、BER性能曲線1801及び1802がそれぞれ得られる。
バイナリ入力相加性白色ガウス雑音(biAWGN)チャネルにおけるBER性能は、反復回数を増やすことによって改善することができる。図18Cにおいて、2回反復の場合に、ポーラ−TPC182のBER曲線1802が、BCH−TPC181のBER曲線1801より0.5dBだけ良好なBERを達成することが示される。
BER曲線1824は、3反復回数の復号に基づく、ポーラ−TPC182のBER性能を示す。BER曲線1823は、3反復回数の復号に基づく、eBCH−TPC181のBER性能を示す。3回反復のBER性能曲線1824は依然として、BCH−TPC182の3回反復のBER曲線1823より良好であるが、ポーラ−TPC182のBER曲線1824は、10−11のBER未満の誤りフロアが高いことによって損なわれる。この誤りフロア問題は、eBCH(256,239,6)に比べて、ポーラ(256,239,4)の短い最小ハミング距離によって引き起こされ、それゆえ、ポーラ−TPCの最小ハミング距離は4=16であるが、その一方で、BCH−ポーラは6=36を有する。
最小ハミング距離は、CRC等の別の符号を連接することによって大きくすることができる。図19Aは、本発明の実施形態による、CRC−1符号1901及びBCH符号1902と連接される、ポーラ(256,240,4)に基づく行及び列構成符号の一例を示す図である。場合によっては、符号1901及び1902はそれぞれ、ポーラ−TPC1901及びポーラ−TPC+BCH1902と呼ばれる場合がある。
ポーラ−TPC1901及び1902はそれぞれ、データブロック90と、第1のパリティブロック190と、行パリティブロックと、列パリティブロックと、結合パリティブロックとを含む。第1のパリティブロック190は、第1の列部分191と、第1の角部分192と、第1の底部分193とを含む。ポーラ符号1901は、第1のパリティブロックとしてCRCパリティ91を使用し、ポーラ符号1902は、第1のパリティブロックとしてBCHパリティ92を使用する。
言い換えると、ポーラ−TPC1901及び1902の構造はそれぞれ、ソース111から与えられるデータソースに対応するデータブロック90と、第1の列部分191、第1の角部分192及び第1の底部分193を含む第1のパリティブロック190と、行パリティブロック196、結合パリティブロック197及び列パリティブロック198を含む第2のパリティブロック195とを含むように、データソースから符号器112によって符号化される。この場合、第1のパリティブロック190は、第1の列部分191、第1の角部分192及び第1の底部分193を使用することによって、データブロック90の右端列と、データブロック90の右下角と、データブロック90の底行とを覆うように配置される。さらに、第2のパリティブロック195は、行パリティブロック196、結合パリティブロック197及び列パリティブロック198を用いて、第1のパリティブロック190を覆うように配置される。
場合によっては、第1のパリティブロック190はCRCパリティビットから形成することができる。さらに、第1のパリティブロック190は、BCHパリティビットから構成することができる。この場合、BCHパリティビットの長さは、訂正可能な誤りビットの最大数がポーラ−TPCの最小ハミング距離以上であるように決定される。
場合によっては、いくつかのBCHパリティビットが、行あたり1ビット及び列あたり1ビットになるように配置され、BCH符号の訂正可能な誤りビットの最大数は、t=floor(p/ceil(log(k)))以下になるように決定することができる。ただし、floor(・)、ceil(・)及びpは、床関数、天井関数、及びBCH(k,p,2t+1)の場合のパリティビットの数を表す。
さらに、行パリティブロック196は、第1の列部分191を通してデータブロック90の右端列に隣接し、列パリティブロック198は、第1のパリティブロック190の第1の底部分193を通してデータブロック90の底行に隣接し、結合パリティブロック197は、第1のパリティブロック190の第1の角部分192を通してデータブロック90の右底角に直角に隣接する。
Tal及びVardyは、SCL復号を改善するために、CRC連接を伴うポーラ符号を改良した。同じ符号化率又はオーバーヘッドを維持するために、いくつかの凍結ビットがCRCパリティビット91に置き換えられる。この場合、結合パリティブロックと呼ばれる、行及び列構成符号は、CRC−1符号と連接されるポーラ(256,240,4)に基づく。しかしながら、この改良は、CRCパリティビット長が厳しく制限され、すなわち、この場合には行又は列あたり1ビットのみに制限されるので、性能を大幅に改善するには不十分である可能性がある。そのような短いCRCパリティの場合に、全ての取り得る多項式を考慮する場合であっても、連接されるポーラ+CRC符号の最小ハミング距離を大きくすることはできない。
本発明の一実施形態によれば、符号化−復号手順が、第1のパリティブロック190として、CRCパリティ91の代わりにBCHパリティ92を使用することによって、BER曲線1824内の誤りフロア問題を解消する方法を提供する。パリティビットの数が行又は列あたり1ビットのみに制限される場合であっても、TPC全体においてBCHパリティ92のために全部で240−239=479ビットが利用可能である。BCH(240,239,59)とポーラ−TPC(256,240,4)との連接が、最大で29の残存ビット誤りを訂正することができる。ポーラ−TPCの最小ハミング距離は16であるので、BCH符号連接によって、最も支配的な誤りパターンを除去するのに成功することができる。BCHパリティビットは、ブロック90内の任意の位置に配置することができる。36の最小ハミング距離を有するBCH−TPC(256,239,6)のために使用される、最大で29ビットを訂正することができる外側BCH符号は役に立たないので、BCH符号連接は、構造化されたハミング重みを有するポーラ−TPCの場合に特に有効であることに留意されたい。
本発明の一実施形態によれば、復号器133は、行復号器1813及び列SD復号器1814に加えて、BCH HD復号器1815を含むことができる。
図19Bは、本発明のいくつかの実施形態による、行SD復号器1813、列SD復号器1814及びBCH HD復号器1815を用いる復号手順を示す図を示す。
図19Cは、本発明のいくつかの実施形態による、行SD復号器1813、列SD復号器1814及びBCH HD復号器1815を用いる復号手順に従って、符号化されたデータブロック90を復号することによって得られるBER性能曲線1921及び1922を示す。この場合、BER性能曲線1921は、行及び列SD復号器1813及び1814を使用する2回反復でポーラ−TPC1901を復号し、BCH HD復号器1815を用いて一度HD復号することによって得られる。さらに、BER性能曲線1922は、行SD復号器1813及び列SD復号器1814を使用する3回反復でポーラ−TPC1901を復号し、BCH HD復号器1815を用いて一度HD復号することによって得られる。
BCH連接を伴うポーラ−TPCに関して、復号器133は、行SD復号器1813及び列SD復号器1814を用いて行及び列SD復号反復を実行し、外側BCH符号のHD復号が、残存誤りパターンを除去するために、SD復号の最後にHD復号器1815を用いて実行される。BCH HDクリーニングと呼ぶことができる、BCH HD復号器1815を用いるこのHD復号は、BER曲線1922によって示されるように、3反復BER性能の場合に誤りフロアを除去することができる。
誤りフロア軽減の利点に加えて、BCH HDクリーニングは、HDクリーニングを使用しないポーラ−TPCの性能曲線1802に比べて、2回反復復号の場合のポーラ−TPC性能曲線1921を著しく改善することができる。HDクリーニングは実効的に付加的な反復として挙動することができるので、実効的には、同じBER性能を達成するのに必要な反復回数を削減することができる。より具体的には、2反復におけるHDクリーニングのBER曲線傾斜は、3反復におけるSD復号の曲線に類似になる可能性がある。
さらに、本発明の復号方法は、ポーラ符号の特定のハミング重み分布を利用することができる。ポーラ(256,240,4)は、[1,2,3,4,...]の距離に関して[0,0,0,56,0,1,0,3009,0,15018,...]のハミング重みを有するのに対して、eBCH(256,239,6)は、[0,0,0,0,0,5757696,0,624879840,...]のハミング重みを有する。それゆえ、ポーラ−TPCは、[16,24,36]の距離の場合に[562,2x56,1]のハミング重みを有する。24の第2の最小ハミング距離も外側BCH符号の訂正可能な29ビットの範囲内にあるので、HDクリーニングを伴うBCH連接は、誤りフロア軽減に関してだけでなく、より少ない反復回数に関してもBER性能を改善することができる。
本発明の方法は、その構成ポーラ符号が、異なるコードワード長n、情報長k及び最小ハミング距離dを有する、ポーラ−TPCの他の実施形態の場合にも使用することができる。誤りフロア軽減の利点を維持するために、訂正可能な誤りビットの最大数がポーラ−TPCの最小ハミング距離以上であるように、BCHパリティ長が選択される。この認識は、第2の最小ハミング距離又は第3の最小ハミング距離に拡張することができる。例えば、より少ない反復においてBER性能を改善することに加えて、BCHパリティ長はまた、最も支配的な誤りパターン及び第2の支配的な誤りパターンの両方を訂正するために、訂正可能な誤りビットの最大数がポーラ−TPCの第2の最小ハミング距離以上であるように選択される。具体的には、BCH符号の訂正可能な誤りビットの最大数は、t=floor(p/ceil(log(k)))以下である。ただし、floor(・)、ceil(・)及びpは、床関数、天井関数、及びBCH(k,p,2t+1)に関するパリティビットの数を表す。ポーラ符号は偶数ハミング重みを有するので、オーバーヘッドを犠牲にすることなく、ポーラ−TPCの場合のいくつかの最も支配的な誤りパターンを訂正するために、外側BCH符号を選択することができる。
誤りフロア軽減及び反復回数の削減に加えて、ポーラ−TPCのためにBCH符号を使用することは、ポーラ構成符号が、計算複雑度緩和のために非正則ポラライザ剪定に基づくときに別の利点を有する。BCH連接によって最小ハミング距離を更に大きくすることにより、過剰剪定に起因する損失を許容することができる。より具体的には、ポーラ−TPC(256,239,4)の場合、BER性能を犠牲にすることなく、CRC−1を伴うポーラ符号(256,240,4)の約55%のポラライザユニットを剪定することができる。それに対して、BCH連接を伴うポーラ符号(256,240,4)の場合、ポラライザユニットの72%ディアクティベーションを剪定することができる。72%ディアクティベーションは、復号に関して約4分の1の複雑度に、部分並列処理によって7倍速い復号に相当する。その結果、本発明の方法は、ポーラ−TPCに関するBCH連接に伴う自明でない利点、すなわち、誤りフロア軽減、必要とされる反復回数の削減、非正則剪定の向上を提供する。
図20Aは、本発明による、高スループット伝送のためのポーラ−TPC符号器2000の並列及びパイプラインの実施態様の一例を示す。ポーラ−TPC符号器2000は、列符号器2010及び行符号器2020を含む。列符号器2010は、k=240のポーラ符号器を並列に動作させ、その後、行符号器2020内のn=256のポーラ符号器が並列に処理される。列符号器2010及び行符号器2020は、符号化スループットが高く保たれるように、パイプライン方式で動作する。上記のポーラ−TPC符号器の実施態様は、ソースデータの符号化プロセスの有効性を改善することができ、送信機内のプロセッサ(ハードウェアプロセッサ)の性能を向上させることができ、送信機のスループットを高めることができる。
図20Bは、高スループット処理のためのポーラ−TPC復号器3000の並列及びパイプラインの実施態様の一例を示す。ポーラ−TPC復号器3000は、行方向復号器2030及び列方向復号器2040を含む。行方向SCL復号器2030はn=256行にわたって完全に並列処理される。行方向SCL復号器2030のSD出力は、チェイス処理2050を介して、列方向SCL復号器2040に送り込まれる。列方向SCL復号器2040も、n=256列にわたって完全に並列処理可能である。行復号器2030及び列復号器2040は、図示されるように、反復にわたるパイプライン処理によって並列処理することができる。並列及びパイプライン実施態様の能力は、高スループット送受信機に関するポーラ−TPCの大きい利点である。上記のポーラ−TPC復号器の実施態様は、コードワードの復号プロセスの有効性を改善することができ、受信機内のプロセッサ(ハードウェアプロセッサ)の性能を向上させることができ、受信機のスループットを高めることができる。
本発明の上記の実施形態は数多くの方法のいずれかにおいて実現することができる。例えば、それらの実施形態は、ハードウェア、ソフトウェア又はその組み合わせを用いて実現することができる。ソフトウェアにおいて実現されるとき、そのソフトウェアコードは、単一のコンピュータ内に設けられるにしても、複数のコンピュータ間に分散されるにしても、任意の適切なプロセッサ、又はプロセッサの集合体において実行することができる。そのようなプロセッサは集積回路として実現することができ、集積回路コンポーネント内に1つ以上のプロセッサが含まれる。しかしながら、プロセッサは、任意の適切な構成の回路を用いて実現することができる。
また、本発明の実施形態は方法として具現することができ、その一例が提供されてきた。その方法の一部として実行される動作は、任意の適切な方法において順序化することができる。したがって、例示的な実施形態において順次の動作として示される場合であっても、例示されるのとは異なる順序において動作が実行される実施形態を構成することもでき、異なる順序は、いくつかの動作を同時に実行することを含むことができる。
請求項要素を修飾するために特許請求の範囲において「第1の」、「第2の」のような序数の用語を使用することは、それだけで、或る請求項要素が別の請求項要素よりも優先度が高いこと、優位であること、若しくは上位にあることを暗示するのでも、又は方法の動作が実行される時間的な順序を暗示するのでもなく、請求項要素を区別するために、或る特定の名称を有する1つの請求項要素を(序数用語を使用しなければ)同じ名称を有する別の要素から区別するラベルとして単に使用される。
本発明を好ましい実施形態の例として説明したが、本発明の趣旨及び範囲内で様々な他の適応及び変更を行うことができることを理解されたい。
したがって、添付の特許請求の範囲の目的は、本発明の真の趣旨及び範囲に入る全てのそのような変形及び変更を包含することである。
他の特徴に関する説明
デジタル通信の分野において、誤り訂正符号(ECC:error correcting code)の適用による前方誤り訂正(FEC)は、雑音を含む通信チャネルによって導入される不確定性を軽減し、復号器によって送信誤りを低減できるようにするために冗長性を追加するようにメッセージを符号化する技法である。一般に、ECCは、データシンボル系列(メッセージを表す)を、雑音を含むチャネルを介して送信される冗長性の高い符号シンボル系列に変換するための技法である。復号器は、雑音を含むチャネル出力からデータシンボルの推定値を再生するシステム又は方法である。
ポーラ符号と呼ばれる、或る特定の種類のECCが2009年にArikanによって導入された。それは、符号化するデータブロックが大きいほど漸近的に最適な符号化効率に(すなわち、チャネル容量を達成することに)向かって収束するのを証明可能である復号器とともに、バイナリ入力チャネルのための系統立てられた符号構成技法を提供する。Arikanによって提案されるようなポーラ符号は、k個のデータバイナリシンボル(「ビット」)の系列として表されるメッセージをn個の符号ビットの系列に符号化する。ただし、nは一般に2の累乗であり、kより大きい。具体的には、符号化手順は、最初に、k個のデータビットを、カージナル数|I|=kを有するデータインデックス集合I⊂{0,...,n−1}によって規定されるk個のロケーションにおいてベクトルu:=(u,...,un−1)に書き込み、一方、残りのn−k個のロケーションは任意であるが、既知の固定値に設定される。
その後、ベクトルc:=(c,...,cn−1)によって表される、n個の符号化されたビットが、式
Figure 2020516119
によって求められる。ただし、行列乗算はバイナリフィールド(すなわち、モジュロ2演算)を介して実行され、Bはn×nビット反転置換行列を表し、
Figure 2020516119
は行列
Figure 2020516119
の第mのクロネッカー累乗であり、m:=lognは分極ステージである。ポーラ符号は、データインデックス集合Iと、パラメータn及びkとによって完全に規定される。したがって、ポーラ符号を構成する鍵は、雑音を含むチャネルに適したデータインデックス集合I(同等には、補集合、凍結ビットロケーション)を選択することである。
Arikanによって提供される逐次除去(SC)復号器が、ポーラ符号構成技法の仕様を説明するのに有用である。SC復号器は入力としてy:=(y,...,yn−1)によって表される雑音を含むチャネル出力を取り込む。ただし、各yは、対応する符号ビットcの雑音を含む観測結果である。SC復号器は、インデックス0からn−1までのビットにわたって順次に進行する。ただし、インデックスi∈{0,...,(n−1)}ごとに、ビットuに関する推定値
Figure 2020516119
が以下のように求められる:
Figure 2020516119
(すなわち、凍結ビットロケーション)である場合には、
Figure 2020516119
はuの既知の固定値に設定され、そうでない場合、すなわち、i∈Iであるとき、チャネル出力yを与えられ、先行する推定値
Figure 2020516119
が正しいと仮定すると、
Figure 2020516119
はuに関する最も可能性が高い値に設定される。インデックスi∈Iにおいてこれらの推定値をサンプリングすることにより、データビットに関する推定値が与えられる。各推定値
Figure 2020516119
は条件付き分布P(y,u,...,ui−1|u)に対して求められ、それはポーラ符号構造及び根底にあるチャネル統計値から得られ、ビットuのための擬似チャネルを表すと考えることもできる。推定値
Figure 2020516119
の精度を最大化することを目的とする場合、データインデックス集合Iは、k個の最も信頼性の高い擬似チャネルを選ぶように選択されるべきである。
また、ポーラ符号は系統的に符号化することもでき、それは、或る特定の連接符号においてポーラ符号を適用できるようにする重要な特性である。ポーラ符号のための系統的符号化手順は、インデックスJによって規定されるロケーションにおいてデータビットがコードワード内に直接現れるような有効なコードワードを生成し、インデックスJはI内のロケーションのビット反転置換を表す。系統的符号化手順は、k個のデータビットをJ内のロケーションにおいてベクトルuに書き込み、一方、他のロケーションは0に設定され、その後、符号化間の中間結果において凍結ビットロケーション(すなわち、I内にないロケーション)を0に設定しながら、ポーラ符号化手順を2回適用する。非正則ポーラ符号に関して、第1の符号化及び第2の符号化は、ポーラステージの反対方向から見て鏡面対称の構造を有する。この手順は、式
Figure 2020516119
を適用することに相当する。ただし、φ(・)は、I内にないロケーションにおいてビットを0に等しく設定することを表す。この手順から生じるコードワードcは、J内のロケーションにおいて書き込まれるデータビットを含み、一方、J内にない残りのロケーションは、パリティビットと呼ばれるビットを含む。状況によっては、最初にk個のデータビットロケーション(インデックス集合Jによって規定される)を配置し、その後、n−k個のパリティロケーション(インデックス集合Jの補集合によって規定される)を配置する置換によってコードワードcを再配置することが好都合な場合がある。そのような置換によれば、符号化手順の結果として、系統的ポーラ符号化手順によって、k個のデータビットにn−k個のパリティビットが付加されたベクトルが計算される。
ポーラ符号は無限のコードワード長の場合に漸近的に容量限界を達成するが、有限のコードワード長における性能は多くの場合に、他の現行技術水準のECC符号より劣っている可能性がある。ポーラ符号に関する符号設計は、信頼性のある擬似チャネルを有する情報インデックスIを選択することによって行われる。それゆえ、ポーラ符号を最適化する自由度、具体的には、n個のロケーションからk個のロケーションを選択する組み合わせには限りがある。さらに、符号化及び復号両方の計算複雑度は対数線形、すなわち、nlog(n)であり、それは、線形複雑度の低密度パリティ検査符号よりコストが高い。
図11〜図17の実施形態の他の特徴
図11は、積符号化構造を有する例示的な連接ポーラ符号を示す。積符号化構造は、2つのタイプのポーラ符号、長さn及びkのデータビットを有する第1の符号及び長さn及びkのデータビットを有する第2の符号を利用する。その符号化手順は、k行×k列の長方形データブロック1101に配列される、k×k個のデータビットを符号化する。データブロック1101の各行を第2のポーラ符号で系統的に符号化し、行ごとの計算されたパリティビットをk×(n−k)行パリティブロック1102の対応する行に書き込むことによって、行パリティブロック1102が生成される。データブロック1101の各列を第1のポーラ符号で系統的に符号化し、列ごとの計算されたパリティビットを(n−k)×k列パリティブロック1103の対応する列に書き込むことによって、列パリティブロック1103が生成される。行パリティブロック1102の各列を第1のポーラ符号で系統的に符号化し、列ごとの計算されたパリティビットを(n−k)×(n−k)行及び列パリティブロック1104の対応する列に書き込むことによって、行及び列パリティブロック1104が生成される。場合によっては、行及び列パリティブロック1104は結合パリティブロックと呼ぶことができる。要するに、データブロック1101、行パリティブロック1102、列パリティブロック1103並びに行及び列パリティブロック1104がn×nコードワードブロックを形成し、それをシリアルに変換し、通信チャネルを介して送信することができる。いくつかの実施形態において、積ポーラ符号化は、2次元の平方構造から、より高次の結合、例えば、3次元の立方構造に拡大される。いくつかの実施形態において、行及び列内の各コンポーネントポーラ符号化は非正則に異なるパラメータを有し、例えば、繰り返し復号のための性能を改善するために、凍結ビットロケーションは同一ではない。
図12は、階段符号化構造を有する空間的に結合されるポーラ符号化の別の例を示す。この符号化方式は、階段に類似している構造に配置される(正:arranged)平方ブロックを伴う。「ブロック0」の番号を付される、構造1201内の第1のブロックは、既知の固定値に設定されるビットの平方ブロックを含む。後続のブロックは「ブロック1」、「ブロック2」等と番号を付され、それぞれデータ部分及びパリティ部分を含む。例えば、「ブロック1」は、「ブロック1:データ」1211及び「ブロック1:パリティ」1212を含む。この図は5つのブロックを示すが、この構造は、それより多いブロック又は少ないブロックに容易に一般化される。各平方ブロックは、n×nの大きさを有する。奇数の後続ブロックの場合、データ部分(例えば、1211、1231)は大きさn×kを有し、パリティ部分(例えば、1212、1232)は大きさn×(n−k)を有する。偶数の後続ブロックの場合、データ部分(例えば、1221、1241)は大きさk×nを有し、パリティ部分(例えば、1222、1242)は大きさ(n−k)×nを有する。この符号化構造は、n+k個のデータビットを長さ2nのコードワードに符号化するコンポーネントポーラ符号を利用する。初期の「ブロック0」後に4つの後続ブロックを含む、図示される具体例の場合、n×k×4ビットのデータを最初に後続ブロック1211、1221、1231、1241のデータ部分に書き込むことによって、それらのデータブロックが符号化される。その後、後続ブロック1212、1222、1232、1242のパリティ部分が以下のように順次に生成される。
各奇数ブロックのパリティ部分1212、1232の各行が、先行するブロックの対応する行と、同じブロックのデータ部分の対応する行との連接を系統的に符号化することによって生成される。例えば、「ブロック1」のパリティ部分1212の行iが、「ブロック1」のデータ部分1211の行iと連接される「ブロック0」1201の行iの系統的な符号化によって生成されたパリティビットによって求められる。別の例において、「ブロック3」のパリティ部分1232の行iが、「ブロック2」の行iの系統的な符号化によって生成されたパリティビットによって求められ、その「ブロック2」の行iは、「ブロック2」のパリティ部分1222の行iと連接される「ブロック2」のデータ部分1221の行iを含み、それは更に「ブロック3」のデータ部分1231の行iと連接される。
各偶数ブロックのパリティ部分1222、1242の各列は同様に生成されるが、その手順は、行ではなく、列にわたって動作する。例えば、「ブロック2」のパリティ部分1222の列iが、「ブロック1」の列iの系統的な符号化によって生成されたパリティビットによって求められ、その「ブロック1」の列iは、「ブロック1」のパリティ部分1212の列iと連接される「ブロック1」のデータ部分1211の列iを含み、それは更に「ブロック2」のデータ部分1221の列iと連接される。
階段符号化手順によって生成される連接コードワード全体が、初期の「ブロック0」後の後続ブロック内の全ビットであり、「ブロック0」は、既知の固定値に設定されるので、送信される必要はない。「ブロック1」内のビット、「ブロック2」内のビット等は、通信チャネルを介して送信するためにシリアルに変換される。階段ポーラ符号化構造の利点は、対応するコードワード長を有する単一のポーラ符号化に比べて待ち時間が短縮されることを含む。軟判定復号は並列に実行することができ、この実施形態では、待ち時間の少ないデータ通信のために、隣接する復号器にわたる少ない数の繰り返しがスライディングウィンドウのように利用される。空間的に結合されるポーラ符号化の他の例は、編み上げ構造、畳み込み構造、テールバイティング、トーラステールバイティング等を含む。各コンポーネントポーラ符号化の正則パラメータは、繰り返し軟復号が潜在的な誤りを迅速に訂正できるように、個別に非正則に設計される。
正則ポーラ符号化は、凍結ビットロケーションを決定する、設計の自由度が限られる。いくつかの実施形態は、符号長、符号化率及び凍結ビットロケーション等の異なるパラメータを伴う複数のポーラ符号を有することによって、自由度を高め、軟判定復号を容易にする。
詳細には、図13は、非正則符号化構造を有する例示的な連接ポーラ符号を示す。この符号化方式は、凍結ビットロケーションが同一でない非正則構造において異なるコードワード及びデータ長を有するポーラ符号の組み合わせを利用する。連接符号全体のデータビットは1つ以上の長方形ブロックに配置され、そのブロックは垂直に積重され、その左端に沿って位置合わせされる。図示される例では、データビットの2つのブロック1301及び1302が存在し、それぞれk×k及びk×kの大きさを有する。その後、データブロックの右に1つ以上の行パリティブロックが水平に付加され、行パリティブロックの各行は、その行が付加されるデータビットの対応する行の系統的な符号化によって生成されたパリティビットによって求められる。図示される例では、2つの行パリティブロック1311及び1312が存在する。詳細には、大きさk×pを有する第1の行パリティブロック1311が、k個のデータビットを長さ(k+p)のコードワードに符号化するコンポーネントポーラ符号で第1のデータブロック1301の行を系統的に符号化することによって生成される。大きさk×pを有する第2の行パリティブロック1312が、第2のデータブロック1301の行を系統的に符号化することによって同様に生成されるが、ここでは、k個のデータビットを長さ(k+p)のコードワードに符号化するコンポーネントポーラ符号を使用する。次に、データビットブロック及び行パリティブロックの底部に列パリティブロックが垂直に付加され、列パリティブロックの各列は、対応するデータ列と、そのデータ列が付加されるパリティビットとの系統的な符号化によって生成されたパリティビットによって求められる。図示される例では、3つの列パリティブロック1321、1322及び1323が存在する。詳細には、大きさp×kを有する第1の列パリティブロック1321が、(k+k)個のデータビットを長さ(k+k+p)のコードワードに符号化するコンポーネントポーラ符号を用いて、両方のデータブロック1301及び1302の最初のk個の列を系統的に符号化することによって生成される。大きさp×kを有する第2の列パリティブロック1322が、(k+k)個のデータビットを長さ(k+k+p)のコードワードに符号化するコンポーネントポーラ符号を用いて生成される。第2の列パリティブロック1322の異なる列が、2つのデータブロック1301及び1302、並びに2つの行パリティブロック1311及び1312の異なる部分に重なることに留意されたい。第2の列パリティブロック1322の各列が、その直上の列を系統的に符号化することによって生成される。
図13は、1つの特定の例示的な配置のみを示すが、この一般概念は、様々なコンポーネントポーラ符号を利用するデータブロック、行パリティブロック及び列パリティブロックの数多くの取り得る非正則配置を含む。例えば、プロトグラフに基づくポーラ符号化構造が構成され、その構造では、並列ポーラ符号がシフト演算によって各ポラライザにおいて混合される。別の例は、レートレス能力を与えるために、増え続ける階段構造を使用し、受信機が復号完了を肯定応答するまで、コンポーネントポーラ符号によってパリティビットのみが絶えず生成される。それゆえ、非正則符号化構造、及び異なる符号化パラメータを有する種々のコンポーネントポーラ符号の適用が、連接符号のコードワード全体にわたって様々な自由度(それゆえ、様々な程度の誤り訂正性能)をもたらし、それは不均一な通信チャネルの場合に有用な可能性がある。通信チャネルを介して送信するために、このコードワード全体がシリアルに変換され、誤り訂正性能利得を潜在的に得るために、不均一なチャネルを介して送信する前に、このシリアル変換を、インターリーバを介して置換することができる。
図14は、種々のコンポーネント符号に適用される軟判定復号器を使用する連接ポーラ符号の繰り返し復号手順のブロック図である。最初のステップは、チャネル出力、すなわち、通信チャネルを介して受信された雑音を含むコードワードを伴う軟判定復号器のための軟入力を初期化すること(1400)である。その後、連接ポーラ符号構成及び復号スケジュールの仕様1401が、連接誤り訂正符号の構造と、各復号繰り返しにおいてどのコンポーネント符号(複数の場合もある)が軟復号されるか(1410)とを規定する。1つ以上のコンポーネント符号1410の軟復号は軟出力を生成し、軟出力は、復号スケジュール1401によって規定されるような、次の繰り返しのための軟入力を更新するために使用される。次に、復号スケジュール1401によって規定されるように、次の繰り返しに進むか、又は繰り返し復号手順1411から抜けるかの判断が行われる。この復号順序スケジュールは、例えば、低遅延復号のためのスライディングウィンドウ、及び高度並列処理のためのフラッディングスケジューリングを含む。復号繰り返しを継続する場合には、その手順は、復号スケジュール1401において規定されるように選択される1つ以上のコンポーネント符号の軟判定復号1410に戻る。このプロセスは、復号スケジュール1401が中止すべきであることを示すまで繰り返し、結果として、繰り返し復号によって最終的な軟出力が生成され、そこから復号されたビットが求められる(1420)。
例えば、図11に示されるような、積符号の場合、例示的な復号スケジュールは、一定の繰り返し数が経過するまで、行コンポーネント符号及び列コンポーネント符号の軟復号を交互に行うことになる。更に別の実施形態では、各コンポーネントポーラ符号は、軟判定復号を容易にするために付加的な非正則性を有する。
図15Aは、いくつかの分極ステージ間、例えば、各分極ステージ間にインターリーバ1510を有する、非正則ポーラ符号の一例を示す。変調マッピングインターリーバ1520とともに、及び/又はそれに加えて、この実施形態は、中間インターリーバを注意深く設計することによって、計算が複雑になるという更なるペナルティを伴うことなく、より多くのインターリーブ処理ユニット1510を利用して、復号性能を改善する。
図15Bは、計算複雑度を管理しながら、中間インターリーバを設計する方法のブロック図を示す。この手順は、図10Bに示されるような不均一なチャネルの場合にインターリーバ及びポーラ符号構成を同時に最適化するための手順に類似であり、その手順の同じサブ構成要素のうちのいくつかを使用する。最初に、インターリーバが、いくつかの初期置換に設定される(1501)。その後、最も信頼性の高い擬似チャネルに対応するデータインデックス集合を選択することによって、インターリーバのこれらの初期置換に対してポーラ符号構成が最適化される(1502)。その後、ポーラ符号構成及びインターリーバの誤り訂正性能が評価される(1503)。次に、誤り訂正性能が収束した(すなわち、先行する繰り返しに対して大きく変化しない)か否かに基づいて、又は全繰り返し数に関する限界に達したか否かに基づいて、繰り返し最適化手順を継続するか、終了するかの決定が行われる(1504)。継続する場合には、ポーラ符号データセットインデックスが固定されている間にインターリーバ置換が最適化され(1505)、その後、インターリーバが固定されている間にポーラ符号データセットインデックスが再び最適化され(1502)、その後、ポーラ符号構成及びインターリーバの性能が再評価され(1503)、繰り返し最適化を継続するか、終了するかの決定が再び行われる(1504)。これらの繰り返しを終了した後に、最終結果は、同時に最適化されたインターリーバ及びポーラ符号構成1506である。
この手順と図10Bによって示される手順との間の顕著な違いは、インターリーバの最適化1505が、ただ1つの置換ではなく、複数の置換の最適化を取り扱うことである。図10Bの手順において行われるように、これらのインターリーバ置換は、各インターリーバの個々の最適化を扱いやすくするためにパラメータ化することができる。しかしながら、複数のインターリーバの全ての組み合わせにわたるブルートフォース探索は、計算複雑度を著しく高める可能性がある。計算コストを管理するために、インターリーバは、代わりに、順次に最適化され、すなわち、最適化スケジュール1507に従って他のインターリーバを固定したまま、一度にインターリーバのうちの1つを個別に最適化する。最適化スケジュール1507は、例えば、インターリーバ最適化1505の一度の実行中に全てのインターリーバが順次に最適化されるように指定することができるか、又は別の例として、繰り返し符号構成手順全体において、インターリーバ最適化1505を何度も実行する間にこの選択されるサブセットを順番に入れ替えながら、インターリーバ最適化1505の一度の実行中にインターリーバのサブセットのみが順次に最適化されるように指定することができる。
図16Aは、いくつかのXOR分極ユニットがディアクティベートされる、非正則ポーラ符号化構造の別の例を示す。非アクティブポラライザを注意深く選択することによって、誤り訂正性能を改善することができ、符号化及び復号のための計算複雑度を低減することができる。非アクティブポラライザのロケーションは、誤り限界が貪欲的に最小化されるようにEXIT法で誤り限界を解析することによって決定される。大部分のポラライザは復号性能を著しくは劣化させないので、より多くの非アクティブポラライザを選択することによって、この非正則ディアクティベーションは復号複雑度を著しく低減することができる。
図16Bは、ポラライザをディアクティベートすることによって与えられる利点を例示する、4の符号長の場合の非正則ポーラ符号化構造の3つの例を示す。正則ポーラ符号化1620は2つの分極ステージ1621、1622を有し、各ステージは2つのポラライザユニット1623、1624及び1625、1626を有する。各ポラライザユニットは、不良のサブチャネルと良好なサブチャネルとを与える。例えば、符号化された4つのビット{c,c,c,c}が0.5のバタチャリアパラメータで均一な信頼性を有するとき、第1の分極ステージ1621内の第1のポラライザユニット1623は、0.75のバタチャリアパラメータを有する不良のビットc’と、0.25のバタチャリアパラメータを有する良好なビットc’とを与える。同様に、第1の分極ステージ1621内の第2のポラライザユニット1624は、0.75のバタチャリアパラメータを有する不良のビットc’と、0.25のバタチャリアパラメータを有する良好なビットc’とを与える。第2の分極ステージ1622内の第1のポラライザユニット1625は、0.9375のバタチャリアパラメータを有する不良のビットuと、0.5625のバタチャリアパラメータを有する良好なビットuとを与える。
第2の分極ステージ1622内の第2のポラライザユニット1626は、0.4375のバタチャリアパラメータを有する不良のビットuと、0.0625のバタチャリアパラメータを有する良好なビットuとを与える。0.5の符号化率の場合、低いバタチャリアパラメータを有する2つの最良のビット{u,u}が情報データとして選択され、一方、高いバタチャリアパラメータを有する残りの2つの不良のビット{u,u}が凍結ビットとして選択される。この正則ポーラ符号化は、1−(1−0.4375)(1−0.0625)=0.473の上限(UB)と同等の誤り率性能を提供すると予想される。
非正則ポーラ符号化1630の一例が、第3のポラライザユニット1625をディアクティベートする(1610)。この非アクティブポラライザは、ビット{u,u}のための中間ビット{c’,c’}の信頼性を変更しないので、それらのバタチャリアパラメータはいずれも0.75である。しかしながら、それらのビットは凍結ビットになるほど既に信頼性がない。それゆえ、情報ビット{u,u}は正則ポーラ符号化1620と同じ信頼性を有するので、ポラライザユニット1625をディアクティベートすることによって、誤り率性能は影響を及ぼされない。この例は、この原理を利用する実施形態が、いかなる性能ペナルティも引き起こすことなく、重要でないポラライザユニットをディアクティベートすることによって、計算複雑度を低減できることを示唆する。
図11〜図17に関する更なる説明の概要
いくつかの実施形態は、ポーラ符号で符号化されたコードワードの逐次除去のリスト復号(SCL)を、硬判定復号の場合だけでなく、軟出力復号の場合にも使用されるように変更できるという理解に基づく。例えば、いくつかの実施形態は、SCL復号器を用いて、候補コードワードのリストを作成し、軟出力を生成するために、候補コードワードのこのリストを復号器の軟入力、すなわち、通信チャネルから受信された雑音を含むコードワードと比較する。それらの実施形態は、比較の結果に基づいて、軟出力を決定する。
例えば、一実施形態は、軟入力から復号器までのSCL復号の各候補コードワードの距離を求め、受信されたコードワードに最も近く、ビットの位置において逆の値を有する候補コードワードの距離の差を用いて、ビット系列内のビットの値の尤度を求める。例えば、候補コードワード及び/又は軟入力の各ビット位置において、その実施形態は、そのロケーションにおいて「1」を有する最も近い候補の距離と、そのロケーションにおいて「0」を有する最も近い候補の距離との差に基づいて、軟出力を計算する。そのようにして、その実施形態は、コードワードの各ビットの軟出力を求めるための別の反復を回避しながら、SCL復号全体の結果に基づいて、軟出力を求める。
任意選択で、いくつかの実施形態は、コードワード内に埋め込まれた少なくとも1つの巡回冗長検査(CRC)符号を用いて、CRC符号を介して部分復号パスを検証する。コードワードの最後にCRCを埋め込むのとは対照的に、コードワード内に埋め込まれたCRCを使用することは、復号手順の中間ステップにおいて、SCL復号器が候補コードワードを剪定するのを支援する。また、これは、SCL復号における誤り伝搬を許容する。
いくつかの実施態様において、全ての候補が或る特定のロケーションに関して一致するとき、軟出力の大きさがパラメータβに設定される。それに加えて、又はその代わりに、いくつかの実施態様では、軟出力はパラメータαによって更に増減される。
したがって、一実施形態は、通信チャネルを介して送信された符号化されたコードワードを復号する受信機を開示する。その受信機は、通信チャネルを介して、通信チャネルの雑音で変更されたビットの系列を含むコードワードを受信するフロントエンドであって、コードワードはポーラ符号で符号化される、フロントエンドと、復号の軟出力を生成するプロセッサを含む軟復号器とを有し、プロセッサは、SCL復号を用いて、受信されたコードワードのビットの取り得る値を推定し、1組の候補コードワードを生成し、各候補コードワードと受信されたコードワードとの間の距離を求め、受信されたコードワードに最も近く、ビットの位置において逆の値を有する候補コードワードの距離の差を用いて、ビット系列内のビットの値の尤度を求めるように構成される。
別の実施形態は、通信チャネルを介して送信された符号化されたコードワードを復号する方法を開示し、その方法は、通信チャネルを介して、通信チャネルの雑音で変更されたビットの系列を含むコードワードを受信することであって、コードワードはポーラ符号で符号化される、受信することと、SCL復号を用いて、受信されたコードワードのビットの取り得る値を推定し、1組の候補コードワードを生成することと、各候補コードワードと受信されたコードワードとの間の距離を求めることと、受信されたコードワードに最も近く、ビットの位置において逆の値を有する候補コードワードの距離の差を用いて、ビット系列内のビットの値の尤度を求めることとを含む。その方法の少なくともいくつかのステップがプロセッサを用いて実行される。
更に別の実施形態は、方法を実行するためのプロセッサによって実行可能なプログラムを具現する非一時的コンピュータ可読記憶媒体を開示し、その方法は、通信チャネルを介して、通信チャネルの雑音で変更されたビットの系列を含むコードワードを受信することであって、コードワードはポーラ符号で符号化される、受信することと、SCL復号を用いて、受信されたコードワードのビットの取り得る値を推定し、1組の候補コードワードを生成することと、各候補コードワードと受信されたコードワードとの間の距離を求めることと、受信されたコードワードに最も近く、ビットの位置において逆の値を有する候補コードワードの距離の差を用いて、ビット系列内のビットの値の尤度を求めることとを含む。
図1〜図17に関する更なる説明についての補足説明
SC復号器は、Arikanによって証明されたように、長い符号長nに関して漸近的に容量を達成するが、符号長nがより短くなる場合でもその実際の誤り訂正性能を改善することができる。2015年にTal及びVardyによって、SC復号器のリスト復号改善形態(SCL)が提案された。SCL復号器はSC復号器と同様に進むが、SC復号器とは異なり、データビットインデックスi∈Iごとに、復号器が両方の取り得る推定値
Figure 2020516119
及び
Figure 2020516119
並びにそれらの後続の復号パスを考慮するように分岐する。チェックされないままである場合、この分岐は各i∈Iにおいてパスの数を2倍にし、結果として、全ての2個の取り得るデータビット系列に対応する2個のパスが検討されることになる。指数関数的に増加するパス数を取り扱うことは非現実的であるので、リスト復号手法は、i∈Iごとの分岐からパスが2倍になった後に、パスの数を、最も可能性が高い部分パスの固定サイズリストまで間引く。この手順は、検討すべき完全復号パスの固定サイズリストを生成し、そのリストから、推定されるデータ系列を生成するために、最も可能性が高い完全パスが選択される。
最終的な目的は、元のデータシンボルを推定するための硬判定を行うことである場合があるが、データシンボル及び/又は符号シンボルについての推定される信念又は尤度を表す軟判定情報(「軟出力」)を出力する復号器を有することが有用な場合もある。軟出力復号器は、例えば、連接ECCを復号するための、より複雑な受信機を構成する際に有用な構成要素であり、連接ECCは複数のコンポーネントECCから形成され、それらのコンポーネントECCが組み合わせられ、より高い性能の符号になる。別の例は、反復等化及び復号を利用するシステムである。
SC復号器及びSCL復号器はいずれも、ポーラ符号化されたコードワードのための硬判定出力のみを与える。いくつかの方法、例えば、軟除去(SCAN:soft cancelation)復号及び信念伝搬(BP:belief propagation)復号は、ポーラ符号化されたコードワードのための軟判定情報を与える。しかしながら、それらの方法は、各組の軟出力を生成するために何度も繰り返す必要があり、それゆえ、時間がかかり、メモリ及び計算能力に費用がかかる。
本開示に関連する特徴
通信チャネルを介して、符号化されたコードワードを送信する送信機は、送信されるソースデータを受け取るソースと、プロセッサによって動作し、ソースデータをポーラ符号で符号化し、符号化されたコードワードを生成する非正則ポーラ符号器であって、ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定され、ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器は、ポーラ符号の正則パラメータ及び非正則パラメータを用いてソースデータを符号化する、非正則ポーラ符号器と、符号化されたコードワードを変調する変調器と、被変調符号化コードワードを、通信チャネルを介して送信するフロントエンドとを備える。
さらに、送信機は、通信チャネルのパラメータを決定するチャネル推定器と、非正則パラメータの異なる値と通信チャネルのパラメータの異なる値との間のマッピングを記憶するメモリとを備え、プロセッサは、チャネル推定器によって決定された通信チャネルのパラメータに基づいて、ポーラ符号の非正則パラメータの値の組み合わせを選択する。
この場合、マッピングは、正則パラメータ及び非正則パラメータの異なる値を通信チャネルのパラメータの異なる値に更に関連付け、プロセッサは、チャネル推定器によって決定された通信チャネルのパラメータに基づいて、ポーラ符号の正則パラメータ及び非正則パラメータの値の組み合わせを選択する。
さらに、通信チャネルのパラメータは、符号化されたコードワードのビットを送信するための不均一な信頼性の値を含む。
場合によっては、1組の非正則パラメータは、互いに空間的に結合される複数の異なるポーラ符号の符号化構造を形成するために、ポーラ符号の少なくとも1つの正則パラメータの値の非正則空間変動を規定するパラメータを含む。
加えて、符号化構造は、長さn及びデータビットkを有する第1のポーラ符号と、長さn及びデータビットkを有する第2のポーラ符号とを含む少なくとも2つのポーラ符号を利用して、データブロックと、第1の方向に沿ってデータブロックに結合される行パリティブロックと、第1の方向に垂直な第2の方向に沿ってデータブロックに結合される列パリティブロックと、第1の方向及び第2の方向から等距離にある第3の方向に沿ってデータブロックに結合される行及び列パリティブロックとを含む、特殊なブロック配置を形成する積符号化構造であり、非正則ポーラ符号器は、k×k個のデータビットをk行及びk列のデータブロックに符号化し、非正則ポーラ符号器は、データブロックの各行を第2のポーラ符号で符号化し、行パリティビットを生成し、この行パリティビットの各行をk×(n−k)行パリティブロックの対応する行に追加し、非正則ポーラ符号器は、データブロックの各列を第1のポーラ符号で符号化し、列パリティビットを生成し、この列パリティビットの各列を(n−k)×k列パリティブロックの対応する列に追加し、非正則ポーラ符号器は、行パリティブロックの各列を第1のポーラ符号で符号化し、行及び列パリティビットを生成し、この行及び列パリティビットの各列を(n−k)×(n−k)行及び列パリティブロックの対応する列に追加する。
このような場合では、符号化構造は、大きさn×kのデータ部分及び大きさn×(n−k)のパリティ部分を有する第1のデータブロックと、大きさk×nのデータ部分及び大きさ(n−k)×nのパリティ部分を有する第2のデータブロックとを含む、平方ブロックの系列によって形成される階段符号化構造であり、第1のブロック及び第2のブロックの連接が階段の1つの段を形成し、コードワードのビットが第1のブロック及び第2のブロックのデータ部分にわたって広がり、第1のブロック及び第2のブロックのパリティ部分のパリティビットが、平方ブロックの系列内の同じブロックのデータ部分のビットと、先行するブロックのパリティ部分のビットとを用いて求められる。
さらに、符号化構造は、ポーラ符号の正則パラメータの異なる値で符号化された、長方形データブロック、行パリティブロック及び列パリティブロックからなる非正則配置である。
送信機は、符号化されたコードワードのビットを置換し、この置換された、符号化されたコードワードを変調器に送出するように構成されるインターリーバを更に備える。この場合、インターリーバは、変調ビットの信頼性に従って、符号化されたコードワードのビットをマッピングする。
さらに、インターリーバ、及びポーラ符号の少なくとも1つのパラメータは、通信チャネルの不均一な信頼性に対して同時に最適化される。
さらに、1組の非正則パラメータは、異なる分極ステージ間に配置される異なるインターリーバによる、符号化されたビットの置換の非正則性を規定するパラメータを含む。
また、1組の非正則パラメータは、非アクティブポラライザのロケーションを指定することによって、ディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータを含む。
非アクティブポラライザを形成するためにディアクティベートされるいくつかのポラライザは、復号性能の許容範囲に基づいて選択され、ポラライザのディアクティベーションが、許容範囲によって許される範囲内で復号性能に影響を及ぼすようにする。
非正則ポーラ符号器は、符号化されたコードワード内の異なる場所に複数の巡回冗長検査(CRC)符号を追加し、コードワードの1つの部分が決定された後に、コードワードのこの部分に適用されるCRC符号器を用いて1つのCRC符号が追加される。
1組の非正則パラメータは、異なる最大階数非バイナリカーネルでポーラ符号内の分極カーネルの非正則性を規定するパラメータを含む。
1組の非正則パラメータは、異なる高次カーネルでポーラ符号内の分極カーネルの非正則性を規定するパラメータを含む。
通信チャネルを介して、符号化されたコードワードを送信する方法は、送信されるソースデータを受け取ることと、ソースデータを非正則ポーラ符号で符号化し、符号化されたコードワードを生成することであって、非正則ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定され、ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器が、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化することと、符号化されたコードワードを変調することと、被変調符号化コードワードを、通信チャネルを介して送信することとを含む。
この場合、その方法は、通信チャネルのパラメータに基づいて、ポーラ符号の正則パラメータ及び非正則パラメータの値の組み合わせを選択することを更に含む。
さらに、方法を実行するためにプロセッサによって実行可能であるプログラムを具現する非一時的コンピュータ可読記憶媒体であって、その方法は、ソースデータを受け取ることと、ソースデータを非正則ポーラ符号で符号化し、符号化されたコードワードを生成することであって、非正則ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定され、ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器が、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化することと、符号化されたコードワードを変調することと、被変調符号化コードワードを、通信チャネルを介して送信することとを含む、非一時的コンピュータ可読記憶媒体。
本開示に関連する他の特徴
通信チャネルを介して送信される符号化されたコードワードを復号するポーラ復号器を備える受信機は、通信チャネルを介して、この通信チャネルの雑音で変更されたビット系列を含むコードワードを受信するフロントエンドであって、コードワードはポーラ符号を用いて少なくとも1つのポーラ符号器によって符号化される、フロントエンドと、プロセッサによって動作し、復号の軟出力を生成する軟復号器とを備え、プロセッサは、逐次除去リスト(SCL)復号を用いて、受信コードワードのビットの取り得る値を推定し、1組の候補コードワードを生成し、各候補コードワードと軟復号器への軟入力との間の距離を求め、ビット系列内のビットの値の尤度を、受信コードワードに最も近く、このビットの位置において逆の値を有する候補コードワードの距離の差を用いて求めるように構成される。
符号化されたコードワードは、1からなる下三角行列のクロネッカー累乗として形成される符号化行列を用いて符号化され、システムは、符号化行列を記憶するメモリを更に備え、軟復号器はメモリから符号化行列を引き出し、符号化行列を用いてコードワードを復号する。
符号化されたコードワードは、1からなる下三角行列のクロネッカー累乗として形成される符号化行列を用いて符号化され、ディアクティベートされた排他的論理和演算及びクロネッカー累乗間の中間インターリーブ処理が非正則に選択され、システムは、符号化行列を記憶するメモリを更に備え、軟復号器はメモリから符号化行列を引き出し、符号化行列を用いてコードワードを復号する。
SCLは、復号されるビットの取り得る組み合わせのリストを保持しながら、コードワードのビットを順次に復号し、SCLの繰り返しごとに、1組の候補コードワードのサイズが閾値以下になるように、保持される組み合わせの数はこの閾値以下である。
受信機は通信チャネルから被変調信号を受信し、被変調信号は雑音を含むアナログ信号であり、受信機は、被変調信号を、受信コードワードを表す、軟復号器への軟入力に変換する復調器と、軟復号器から受信された軟出力に基づいて、受信コードワードからビットの対数尤度比を示す値を生成する硬復号器とを更に備える。
軟復号器は、軟入力と候補コードワードとの間のユークリッド距離として、候補コードワードごとの距離を求める。尤度を求めることは、全ての候補コードワードにおける各ビット位置上の少なくともいくつかの値が異なる値を有するときに、この位置において「1」の値を有する最も近い候補の距離と、この位置において「0」を有する最も近い候補の距離との差に基づいて、軟入力のこのビット位置において軟出力の値を計算することと、そうでない場合、すなわち、全ての候補コードワードにおけるビット位置上の全ての値が同じ値を有するとき、軟出力の値を所定の定数として選択することとを含む。
計算することは、軟出力の値をスケーリングパラメータと乗算し、コードワードの対応するビットのための軟出力を生成することを更に含む。
コードワードは、凍結ビットロケーション、データビットの数、パリティビットの数、及び符号化されたビットのインターリーバ置換のうちの1つ又は組み合わせを含む、各ポーラ符号の同一でない1組のパラメータを規定する空間パターンに従って互いに空間的に結合される複数のポーラ符号で符号化される複数のコンポーネントを含み、軟復号器は、1つのコンポーネントの復号の軟出力が別のコンポーネントの復号への軟入力であるように、複数のコンポーネントにわたって軟復号を繰り返すことによって、空間パターンに従って軟出力を生成する。
コードワードは中間符号化プロセスにおいて使用される複数の異なるインターリーバのうちの1つ又は組み合わせで符号化され、アクティブ及び非アクティブ排他的論理和演算子が、軟復号の計算複雑度及び誤り訂正性能を調整する。
軟復号器は、各分極演算においてビットの値の尤度を求めるために適応的ルックアップテーブル(LUT)を使用し、このLUTはビットごとの分極のダウングレードする分岐及びアップグレードする分岐を規定し、入力量子化メッセージを与えられると、これらのメッセージの確率質量関数に基づいて、出力量子化メッセージが最大相互情報量を有するように、このLUTの規則が決定される。
受信コードワードは複数のCRC符号を含み、候補コードワードの一部が正しくないCRC符号を含むときに、プロセッサが、受信コードワード内のCRC符号を含む場所によって決定される部分長において1組の候補コードワードを剪定する。
軟復号器は、部分的に復号された候補コードワードからCRC値を抽出して、第1のCRCを生成し、部分的に復号された候補コードワードにCRC関数を適用することによってCRCを計算して、第2のCRCを生成し、第1のCRCを第2のCRCと比較し、第1のCRCが第2のCRCと一致しない場合には、復号されたビットの取り得る組み合わせのリストから部分的に復号された候補コードワードを削除するように構成される。
さらに、通信チャネルを介して送信される符号化されたコードワードを復号する方法は、通信チャネルを介して、この通信チャネルの雑音で変更されたビット系列を含むコードワードを受信することであって、このコードワードは少なくとも1つのポーラ符号器で符号化される、受信することと、SCL復号を用いて、受信コードワードによって表される軟入力のビットの取り得る値を推定し、1組の候補コードワードを生成することと、各候補コードワードと受信コードワードとの間の距離を求めることと、ビット系列内のビットの値の尤度を、受信コードワードに最も近く、このビットの位置において逆の値を有する候補コードワードの距離の差を用いて求めることとを含み、方法の少なくともいくつかのステップはプロセッサを用いて実行される。
その方法では、SCLは、復号されるビットの取り得る組み合わせのリストを保持しながら、コードワードのビットを順次に復号し、SCLの繰り返しごとに、1組の候補コードワードのサイズが閾値以下になるように、保持される組み合わせの数はこの閾値以下である。
その方法は、通信チャネルから被変調信号を受信することであって、この被変調信号は雑音を含むアナログ信号である、受信することと、被変調信号を軟入力に変換することと、軟入力と対応する候補コードワードとの間のユークリッド距離として候補コードワードごとの距離を求めることとを更に含む。
その方法では、尤度を求めることは、全ての候補コードワードにおける各ビット位置上の少なくともいくつかの値が異なる値を有するときに、この位置において「1」の値を有する最も近い候補の距離と、この位置において「0」を有する最も近い候補の距離との差に基づいて、軟入力のこのビット位置において軟出力の値を計算することと、そうでない場合、すなわち、全ての候補コードワードにおけるビット位置上の全ての値が同じ値を有するとき、軟出力の値を所定の定数として選択することとを含む。
その方法では、受信コードワードは複数のCRC符号を含み、候補コードワードの一部が正しくないCRC符号を含むときに、プロセッサが、受信コードワード内のCRC符号を含む場所によって決定される部分長において1組の候補コードワードを剪定する。
さらに、方法を実行するためにプロセッサによって実行可能であるプログラムを具現する非一時的コンピュータ可読記憶媒体であって、その方法は、通信チャネルを介して、この通信チャネルの雑音で変更されたビット系列を含むコードワードを受信することであって、このコードワードはポーラ符号器で符号化される、受信することと、SCL復号を用いて、受信コードワードによって表される軟入力のビットの取り得る値を推定し、1組の候補コードワードを生成することと、各候補コードワードと受信コードワードとの間の距離を求めることと、ビット系列内のビットの値の尤度を、受信コードワードに最も近く、このビットの位置において逆の値を有する候補コードワードの距離の差を用いて求めることとを含む、非一時的コンピュータ可読記憶媒体。
そのメモリにおいて、その方法は、全ての候補コードワードにおける各ビット位置上の少なくともいくつかの値が異なる値を有するときに、この位置において「1」の値を有する最も近い候補の距離と、この位置において「0」を有する最も近い候補の距離との差に基づいて、軟入力のこのビット位置において軟出力の値を計算することと、そうでない場合、すなわち、全ての候補コードワードにおけるビット位置上の全ての値が同じ値を有するとき、軟出力の値を所定の定数として選択することとを更に含む。
本発明の実施形態による送信機及び受信機が以下に説明される。
通信チャネルを介して、符号化されたコードワードを送信する送信機は、ソースデータを受け取るソースと、プロセッサによって動作し、少なくとも1つのポーラ符号でソースデータを符号化し、符号化されたコードワードを生成する非正則ポーラ符号器と、符号化されたコードワードを変調する変調器と、被変調符号化コードワードを、通信チャネルを介して送信するフロントエンドとを備える。ポーラ符号は、コードワード内のデータビットの数を規定するパラメータ、符号化されたコードワード内の凍結ビットのロケーションを指定するデータインデックス集合を規定するパラメータ、及び符号化されたコードワード内のパリティビットの数を規定するパラメータのうちの1つ又は組み合わせを含む、1組の正則パラメータによって規定される。ポーラ符号は、ポーラ符号の少なくとも1つの正則パラメータの値の非正則性を規定するパラメータ、符号化されたビットの置換の非正則性を規定するパラメータ、ポーラ符号内の分極カーネルの非正則性を規定するパラメータ、及びポーラ符号化の異なるステージにおけるディアクティベートされる排他的論理和演算の選択に関する非正則性を規定するパラメータのうちの1つ又は組み合わせを含む、1組の非正則パラメータによって更に規定され、非正則ポーラ符号器は、ポーラ符号の正則パラメータ及び非正則パラメータを用いてコードワードを符号化する。非正則ポーラ符号は、多次元ターボ積符号を構成するように空間的に結合され、外側符号は、短いハミング重みに起因して最も支配的な誤りパターンを訂正し、かつ複雑度を緩和し、待ち時間を短縮するために非正則過剰剪定カーネルを可能にするように連接される。
さらに、受信機が、通信チャネルを介して送信された符号化されたコードワードを復号するためのポーラ復号器を含む。受信機は、通信チャネルを介して、通信チャネルの雑音で変更されたビットの系列を含むコードワードを受信するフロントエンドと、復号の軟出力を生成するためにプロセッサによって動作する軟復号器とを含む。コードワードは、少なくとも1つのポーラ符号器によってポーラ符号で符号化される。プロセッサは、SCL復号を用いて、受信されたコードワードのビットの取り得る値を推定し、1組の候補コードワードを生成し、チェイス処理を介して、各候補コードワードと軟復号器への軟入力との間の距離を求め、受信されたコードワードに最も近く、ビットの位置において逆の値を有する候補コードワードの距離の差を用いて、ビット系列内のビットの値の尤度を求めるように構成される。空間的に結合されたコードワードにわたる軟判定反復復号後に、誤りフロアを軽減し、必要とされる反復回数を削減するために、硬判定クリーニングが実行される。

Claims (20)

  1. ソース情報を、通信チャネルにおいて使用されることになる符号化されたコードワードに符号化する符号器であって、
    符号化されることになるソースデータを受信するデータ入力と、
    プロセッサと、
    前記プロセッサによって実行可能な符号器プログラムを記憶するメモリと、
    を備え、前記符号器プログラムは、前記プロセッサに、前記ソースデータをターボ積符号(TPC)構造に符号化させ、前記TPC構造は、
    前記ソースデータに対応するデータブロックと、
    第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、前記第1のパリティブロックは、前記第1の列部分、前記第1の角部分及び前記第1の底部分によって、前記データブロックの右端列、前記データブロックの右底角及び前記データブロックの底列を覆うように配置される、第1のパリティブロックと、
    行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックであって、前記第2のパリティブロックは、前記行パリティブロック、前記結合パリティブロック及び前記列パリティブロックを用いて、前記第1のパリティブロックを覆うように配置される、第2のパリティブロックと、
    を備える、符号器。
  2. 前記第1のパリティブロックは、Bose、Chaudhuri及びHocquenghem(BCH)符号化に基づくパリティビットから構成される、請求項1に記載の符号器。
  3. 前記第2のパリティブロックはポーラ符号化に基づくパリティビットから構成される、請求項1に記載の符号器。
  4. 前記BCHパリティビットの長さは、誤りフロアを低減するために、訂正可能な誤りビットの最大数が最小ハミング距離以上であるように求められる、請求項2に記載の符号器。
  5. 前記BCHパリティビットの長さは、雑音を許容するために、訂正可能な誤りビットの最大数が第2の最小ハミング距離以上であるように求められる、請求項2に記載の符号器。
  6. 前記ポーラ符号化は、正則パラメータだけでなく、非正則パラメータも有し、非正則パラメータは、複雑度を緩和し、待ち時間を短縮するために、ポラライザユニット内の非正則ビット置換及び非アクティブ化排他的論理和演算の非正則ロケーションを含む、請求項3に記載の符号器。
  7. 前記TPC構造は、より多くの符号を空間的に結合することによって最小ハミング距離を大きくするために、行方向及び列方向だけでなく、付加的な次元によって拡張される、請求項1に記載の符号器。
  8. 第2のパリティビットは、次元ごとに、すなわち、行方向又は列方向に並列に生成され、前記行方向又は前記列方向である次元方向の生成は、高スループット符号化のためにパイプライン方式で処理される、請求項1に記載の符号器。
  9. 前記TPC構造は畳み込み構造に拡張され、パリティビットは階段状に配置される、請求項1に記載の符号器。
  10. 前記符号器プログラムは列符号器及び行符号器を含み、前記列符号器はk個のポーラ符号器を並列に動作させ、前記行符号器はn個のポーラ符号器を並列に動作させる、請求項1に記載の符号器。
  11. 前記列符号器及び前記行符号器はパイプライン方式で動作する、請求項10に記載の符号器。
  12. 前記ポーラ符号器に関してk=240、前記ポーラ符号器に関してn=256である、請求項10に記載の符号器。
  13. 請求項1に記載の符号器によってソースデータから符号化されたコードワードを復号する復号器であって、
    復号されることになる前記コードワードを受信するコードワード入力と、
    復号器プログラムに従って前記コードワードを前記ソースデータに復号するプロセッサと、
    前記プロセッサによって実行可能な前記復号器プログラムを記憶するメモリと、
    を備え、行軟判定(SD)プロセス、列SDプロセス及び硬判定(HD)プロセスを含む前記復号器プログラムは、前記プロセッサに、復号プロセスに従ってターボ積符号化(TPC)構造を有する前記コードワードを前記ソースデータに復号させ、前記復号プロセスは、
    一連の前記行SDプロセス及び前記列SDプロセスの少なくとも2回の反復と、
    少なくとも1つのHDプロセスと、
    を含み、
    前記TPC構造は、
    前記ソースデータに対応するデータブロックと、
    第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、前記第1のパリティブロックは、前記第1の列部分、前記第1の角部分及び前記第1の底部分によって、前記データブロックの右端列、前記データブロックの右底角及び前記データブロックの底列を覆うように配置される、第1のパリティブロックと、
    行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックであって、前記第2のパリティブロックは、前記行パリティブロック、前記結合パリティブロック及び前記列パリティブロックによって、前記第1のパリティブロックを覆うように配置される、第2のパリティブロックと、
    を備える、復号器。
  14. 前記第1のパリティブロックはBCH符号化に基づくパリティビットから構成される、請求項13に記載の復号器。
  15. 前記第2のパリティブロックはポーラ符号化に基づくパリティビットから構成される、請求項13に記載の復号器。
  16. 前記行SDプロセス及び前記列SDプロセスは、リスト復号に基づくチェイス処理を使用する、請求項13に記載の復号器。
  17. 前記行SDプロセス及び前記列SDプロセスは、高スループット復号のために並列にパイプライン処理される、請求項13に記載の復号器。
  18. 前記HDプロセスはBCH復号を使用する、請求項13に記載の復号器。
  19. 前記復号器プログラムは、行方向復号器及び列方向復号器を含み、前記行方向復号器は、n個のポーラ復号器を並列に動作させ、前記列方向復号器は、k個のポーラ復号器を並列に動作させ、前記行方向復号器の出力は、チェイス処理を介して、前記列方向復号器に送り込まれる、請求項13に記載の復号器。
  20. 通信チャネルを介して、符号化されたコードワードを送信する送信機であって、
    送信されることになるソースデータを受け取るソースと、
    符号化されることになるソースデータを受信するデータ入力と、
    プロセッサと、
    前記プロセッサによって実行可能な符号器プログラムを記憶するメモリと、
    を備え、前記符号器プログラムは、前記プロセッサに、前記ソースデータを積符号化構造に符号化させ、前記積符号化構造は、
    前記ソースデータに対応するデータブロックと、
    第1の列部分、第1の角部分及び第1の底部分を含む第1のパリティブロックであって、前記第1のパリティブロックは、前記第1の列部分、前記第1の角部分及び前記第1の底部分によって、前記データブロックの右端列、前記データブロックの右底角及び前記データブロックの底列を覆うように配置される、第1のパリティブロックと、
    行パリティブロック、結合パリティブロック及び列パリティブロックを有する第2のパリティブロックであって、前記第2のパリティブロックは、前記行パリティブロック、前記結合パリティブロック及び前記列パリティブロックを用いて、前記第1のパリティブロックを覆うように配置される、第2のパリティブロックと、
    を備え、前記符号化されたコードワードを変調する変調器と、
    前記変調され、符号化されたコードワードを、前記通信チャネルを介して送信するフロントエンドと、
    を備える、送信機。
JP2019551713A 2017-07-28 2018-07-26 符号器、復号器及び送信機 Active JP6847252B2 (ja)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201762538593P 2017-07-28 2017-07-28
US62/538,593 2017-07-28
US15/866,594 US10998922B2 (en) 2017-07-28 2018-01-10 Turbo product polar coding with hard decision cleaning
US15/866,594 2018-01-10
PCT/JP2018/028949 WO2019026981A2 (en) 2017-07-28 2018-07-26 ENCODER, DECODER AND TRANSMITTER

Publications (2)

Publication Number Publication Date
JP2020516119A true JP2020516119A (ja) 2020-05-28
JP6847252B2 JP6847252B2 (ja) 2021-03-24

Family

ID=65038309

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2019551713A Active JP6847252B2 (ja) 2017-07-28 2018-07-26 符号器、復号器及び送信機

Country Status (5)

Country Link
US (1) US10998922B2 (ja)
EP (1) EP3659261B1 (ja)
JP (1) JP6847252B2 (ja)
CN (1) CN110915141B (ja)
WO (1) WO2019026981A2 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2021502767A (ja) * 2017-11-15 2021-01-28 中興通訊股▲ふん▼有限公司Zte Corporation 階段コードの復号化方法、装置および記憶媒体

Families Citing this family (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109194337B (zh) * 2013-11-11 2019-08-27 华为技术有限公司 一种Polar码编码方法、装置
KR102426047B1 (ko) * 2017-11-06 2022-07-26 삼성전자주식회사 폴라 부호 복호화 장치 및 방법
WO2019090468A1 (en) * 2017-11-07 2019-05-16 Qualcomm Incorporated Methods and apparatus for crc concatenated polar encoding
US10608672B2 (en) * 2017-12-22 2020-03-31 Massachusetts Institute Of Technology Decoding concatenated codes by guessing noise
US10812107B2 (en) * 2018-01-19 2020-10-20 Huawei Technologies Co., Ltd. Apparatus and methods for polar code construction and bit position allocation
WO2019183309A1 (en) * 2018-03-22 2019-09-26 Idac Holdings, Inc. Reduced complexity polar encoding and decoding
WO2020052769A1 (en) * 2018-09-13 2020-03-19 Huawei Technologies Co., Ltd. Apparatuses and methods for mapping frozen sets between product codes and component polar codes
KR102064227B1 (ko) * 2018-10-17 2020-01-09 고려대학교 산학협력단 극 부호의 복호를 위한 방법 및 장치
WO2020127529A1 (en) * 2018-12-20 2020-06-25 Sony Corporation Communications device, infrastructure equipment and methods
US10516503B1 (en) * 2019-02-20 2019-12-24 Mitsubishi Electric Research Laboratories, Inc. Distribution matcher
KR102118899B1 (ko) * 2019-03-07 2020-06-04 한양대학교 산학협력단 연판정 기반으로 선형 부호를 고속 복호화하는 방법 및 장치
US11080137B2 (en) 2019-05-09 2021-08-03 Rambus Inc. Error coalescing
CA3177569A1 (en) * 2019-05-15 2020-11-19 Xiang He Data transmission method and apparatus
CN111030704B (zh) * 2019-12-31 2021-07-27 华中科技大学 一种基于极化码的免同步通信方法、装置及系统
CN113067786B (zh) * 2020-01-02 2023-08-29 上海诺基亚贝尔股份有限公司 用于均衡信号的设备、方法、装置及计算机可读介质
US11152953B2 (en) 2020-02-28 2021-10-19 Qualcomm Incorporated Error detection for a wireless channel
KR102455652B1 (ko) * 2020-03-17 2022-10-18 한국전자통신연구원 연판정을 이용한 복호 방법 및 장치
US11239944B1 (en) 2020-08-14 2022-02-01 Huawei Technologies Co., Ltd. Methods and devices for rate adaptive forward error correction using a flexible irregular error correcting code
US11265019B1 (en) * 2020-12-01 2022-03-01 Huawei Technologies Co., Ltd. Parallel polar code with shared data and cooperative decoding
CN113141232B (zh) * 2021-02-02 2021-11-26 中南民族大学 基于16QAM调制的无速率IoT上行传输系统及方法
US11463114B2 (en) 2021-02-22 2022-10-04 Mitsubishi Electric Research Laboratories, Inc. Protograph quasi-cyclic polar codes and related low-density generator matrix family
CN113572577B (zh) * 2021-07-28 2022-04-26 北京邮电大学 一种新型缩短极化码方法及系统
TWI783727B (zh) * 2021-10-14 2022-11-11 國立中山大學 使用極化碼之通訊系統及其解碼方法
CN114421976B (zh) * 2022-01-25 2023-09-08 电子科技大学 基于概率计算的tpc迭代译码方法及译码器

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6526538B1 (en) * 1998-09-28 2003-02-25 Comtech Telecommunications Corp. Turbo product code decoder
US20040199847A1 (en) * 2002-05-03 2004-10-07 Stefano Calabro Method and apparatus for improving the performance of concatenated codes
WO2006027838A1 (ja) * 2004-09-09 2006-03-16 Mitsubishi Denki Kabushiki Kaisha 誤り訂正符号化装置および誤り訂正復号装置
US20090086839A1 (en) * 2005-11-07 2009-04-02 Agency For Science, Technology And Research Methods and devices for decoding and encoding data
US20130147645A1 (en) * 2011-12-13 2013-06-13 Broadcom Corporation Encoding methods and systems for binary product codes
US20140129896A1 (en) * 2012-11-08 2014-05-08 Micron Technology, Inc. Error correction methods and apparatuses using first and second decoders
US20150358113A1 (en) * 2014-06-06 2015-12-10 Huawei Technologies Co., Ltd. System and Method for Forward Error Correction
US20160344426A1 (en) * 2015-05-18 2016-11-24 Sk Hynix Memory Solutions Inc. Performance optimization in soft decoding for turbo product codes

Family Cites Families (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5040179A (en) * 1989-08-18 1991-08-13 Loral Aerospace Corp. High data rate BCH encoder
US7356752B2 (en) * 2000-03-14 2008-04-08 Comtech Telecommunications Corp. Enhanced turbo product codes
US20020116681A1 (en) * 2000-12-27 2002-08-22 Cute Ltd. Decoder, system and method for decoding trubo block codes
US7012974B1 (en) 2001-09-24 2006-03-14 Lsi Logic Corporation High rate product code decoding for partial response channel
US7913145B2 (en) * 2003-05-28 2011-03-22 Mitsubishi Denki Kabushiki Kaisha Re-transmission control method and communication device
US7333028B2 (en) * 2005-06-01 2008-02-19 Global Traffic Technologies, Llc Traffic preemption system communication method
WO2007072721A1 (ja) * 2005-12-20 2007-06-28 Mitsubishi Electric Corporation 検査行列生成方法、符号化方法、通信装置、通信システム、符号化器
CN100592639C (zh) * 2006-04-27 2010-02-24 华为技术有限公司 低密度奇偶校验编码方法、装置及奇偶校验矩阵生成方法
JP4662278B2 (ja) * 2006-04-28 2011-03-30 富士通株式会社 エラー訂正装置、符号器、復号器、方法及び情報記憶装置
WO2007145491A1 (en) 2006-06-15 2007-12-21 Samsung Electronics Co., Ltd. Apparatus and method of encoding/decoding block low density parity check codes in a communication system
JP5502363B2 (ja) * 2009-04-28 2014-05-28 三菱電機株式会社 光伝送装置および光伝送方法
US8879623B2 (en) * 2009-09-02 2014-11-04 Sony Computer Entertainment Inc. Picture-level rate control for video encoding a scene-change I picture
US8347186B1 (en) * 2012-04-19 2013-01-01 Polaran Yazilim Bilisim Danismanlik Ithalat Ihracat Sanayi Ticaret Limited Sirketi Method and system for error correction in transmitting data using low complexity systematic encoder
US9503126B2 (en) 2012-07-11 2016-11-22 The Regents Of The University Of California ECC polar coding and list decoding methods and codecs
KR101951663B1 (ko) * 2012-12-14 2019-02-25 삼성전자주식회사 Crc 부호와 극 부호에 의한 부호화 방법 및 장치
CN104079370B (zh) * 2013-03-27 2018-05-04 华为技术有限公司 信道编译码方法及装置
US9391641B2 (en) * 2013-04-26 2016-07-12 SK Hynix Inc. Syndrome tables for decoding turbo-product codes
CN108364657B (zh) * 2013-07-16 2020-10-30 超清编解码有限公司 处理丢失帧的方法和解码器
US9287899B1 (en) * 2013-12-20 2016-03-15 Xilinx, Inc. Forward error correction
US9673840B2 (en) * 2014-12-08 2017-06-06 SK Hynix Inc. Turbo product codes for NAND flash
CN104636780B (zh) * 2015-01-30 2017-07-04 深圳市民德电子科技股份有限公司 矩阵式二维码及其编码方法和译码方法
US20170353267A1 (en) * 2016-06-01 2017-12-07 Qualcomm Incorporated Generalized polar code construction

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6526538B1 (en) * 1998-09-28 2003-02-25 Comtech Telecommunications Corp. Turbo product code decoder
US20040199847A1 (en) * 2002-05-03 2004-10-07 Stefano Calabro Method and apparatus for improving the performance of concatenated codes
WO2006027838A1 (ja) * 2004-09-09 2006-03-16 Mitsubishi Denki Kabushiki Kaisha 誤り訂正符号化装置および誤り訂正復号装置
US20090086839A1 (en) * 2005-11-07 2009-04-02 Agency For Science, Technology And Research Methods and devices for decoding and encoding data
US20130147645A1 (en) * 2011-12-13 2013-06-13 Broadcom Corporation Encoding methods and systems for binary product codes
US20140129896A1 (en) * 2012-11-08 2014-05-08 Micron Technology, Inc. Error correction methods and apparatuses using first and second decoders
US20150358113A1 (en) * 2014-06-06 2015-12-10 Huawei Technologies Co., Ltd. System and Method for Forward Error Correction
US20160344426A1 (en) * 2015-05-18 2016-11-24 Sk Hynix Memory Solutions Inc. Performance optimization in soft decoding for turbo product codes

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
H.MUKHTAR(他2名): "Turbo Product Codes: Applications, Challenges, and Future Directions", IEEE COMMUNICATIONS SURVEYS & TUTORIALS, vol. 18, no. 4, JPN6020046628, 6 July 2016 (2016-07-06), pages 3052 - 3069, XP011634947, ISSN: 0004402095, DOI: 10.1109/COMST.2016.2587863 *

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2021502767A (ja) * 2017-11-15 2021-01-28 中興通訊股▲ふん▼有限公司Zte Corporation 階段コードの復号化方法、装置および記憶媒体
US11184034B2 (en) 2017-11-15 2021-11-23 Xi'an Zhongxing New Software Co., Ltd. Method and device for decoding staircase code, and storage medium
JP7047092B2 (ja) 2017-11-15 2022-04-04 中興通訊股▲ふん▼有限公司 階段コードの復号化方法、装置および記憶媒体

Also Published As

Publication number Publication date
US20190036550A1 (en) 2019-01-31
US10998922B2 (en) 2021-05-04
WO2019026981A2 (en) 2019-02-07
JP6847252B2 (ja) 2021-03-24
CN110915141B (zh) 2023-07-21
EP3659261B1 (en) 2022-11-09
CN110915141A (zh) 2020-03-24
EP3659261A2 (en) 2020-06-03
WO2019026981A3 (en) 2019-03-14

Similar Documents

Publication Publication Date Title
JP6847252B2 (ja) 符号器、復号器及び送信機
JP6858857B2 (ja) 受信機及び復号方法
US8880973B1 (en) Detector-decoder interface for GF(q) iterative decoding
US11463114B2 (en) Protograph quasi-cyclic polar codes and related low-density generator matrix family
US20220376819A1 (en) Spatially coupled forward error correction encoding method and device using generalized error locating codes as component codes
CN114073024A (zh) 极性码的卷积预编码和解码
Seksembayeva et al. Study of the principles of error correcting code in a multipath communication channel with intersymbol interference
EP2406908B1 (en) Mimo communication method and devices
Jain et al. Variable-rate FEC decoder VLSI architecture for 400G rate-adaptive optical communication
JP4863519B2 (ja) 復号化装置、復号化方法、復号化プログラム、受信装置、及び通信システム
WO2024084554A1 (ja) 推定装置、設計支援装置、推定方法、設計支援方法及びコンピュータープログラム
US8259868B1 (en) Conditionally cycle-free generalized tanner graphs based decoding

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20190919

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20201208

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20210105

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: 20210202

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20210302

R150 Certificate of patent or registration of utility model

Ref document number: 6847252

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250