ターボ符号(ターボふごう、英: Turbo code)は、1993年に発表された高性能な誤り訂正符号である[1]。第三世代携帯電話、第四世代携帯電話などの移動通信システムや、宇宙探査機での通信など、ノイズのある限られた帯域幅であっても、信頼性の高い高速通信を行う場合に使われている。 既知の誤り訂正符号の中では、ターボ符号と低密度パリティ検査符号 (LDPC) がシャノン限界(ノイズのある伝送路における最大情報転送量の理論的限界値)に最も近い。 ターボ符号は送信機の出力を上げずにデータレートを上げることができ、逆に言えばあるデータレートでの消費電力を低減できる。主な欠点は、復号処理が複雑で復号処理遅延が比較的大きい点であり、このため低レイテンシが重視される用途には向かない。但し、復号処理は近年のプロセッサの高速化でレイテンシ全体で見ると支配要因とはならない場合がある。また、宇宙探査機において、復号処理遅延の大きいターボ符号であっても問題とされない。復号処理遅延より伝搬遅延の方がレイテンシの支配要因となるためである。 ターボ符号以前には、LDPCの実用的実装も開発されていなかったため、シャノン限界に最も近い技法としては、リード・ソロモン誤り訂正ブロック符号とビタビ復号の短拘束長畳み込み符号を組み合わせた RSV 符号があった。 これらのアルゴリズムは複雑であり、ソフトウェア特許で守られているため、システムに採用するのを避ける場合がある。 1993年、Claude Berrou、Alain Glavieux、Punya Thitimajshima(ブルターニュ電気通信国立大学 符号器はビット列を3つのサブブロックとして送信する。第一のサブブロックは m-ビットのペイロードデータである。第二のサブブロックはそのペイロードデータの n/2 パリティビット列であり、再帰系統的畳み込み符号(RSC符号)を使って計算する。第三のサブブロックはペイロードデータの既知の並べ替えの n/2 パリティビット列であり、こちらもRSC畳み込み符号を使って計算する。従って、ペイロードと共に2つの冗長だが異なるパリティビット列が送信される。ブロック長は m+n ビットであり、符号レートは m/(m+n) である。ペイロードデータの並べ替えは、インターリーバ(interleaver)という手法を使う。 ハードウェアによるターボ符号器は2つのRSC符号器 C1 と C2 から構成され、これらの出力を並列連結と呼ばれる手法で連結する。 入力ビット列 dk は C1 にはそのまま入力され、C2 にはインターリーバを通して並べ替えた上で入力される。出力は、入力 dk をそのまま出力する系統出力 xk と C1 の出力 y1k、C2 の出力 y2k がある。 復号器も符号器と似たような形で構築され、2つの復号器を相互接続するが、こちらは直列接続であって並列接続ではない。それ故、遅延は符号器よりも構造的に大きくなる。一段目の復号器 DEC1 が符号器 C1 に対応し、二段目の復号器 DEC2 が符号器 C2 に対応している。DEC1 は軟判定を行い、それによって L1 の遅延が生じる。同じ遅延は符号器のインタリーバ部分にあるレジスタでも生じる。DEC2 では L2 の遅延を生じる。 2つの復号器の中間にインターリーバが置かれ、DEC1 の出力におけるバースト誤りを分散させる。受信信号のうち xk はそのまま DEC1 に入力されるが、y1k または y2k に相当する部分はデマルチプレクサによって DEC1 か DEC2 に振り分けられる。 伝送路が履歴の影響がないガウスノイズのある加算的伝送路(AWGN)とし、反復が k 番目の場合、復号器は以下のような確率変数の対を受け取る。 x k = ( 2 d k − 1 ) + a k {\displaystyle ~x_{k}=(2d_{k}-1)+a_{k}} , y k = 2 ( Y k − 1 ) + b k {\displaystyle ~y_{k}=2(Y_{k}-1)+b_{k}} ここで ak と bk は独立ノイズ成分であり、共に分散は σ2 である。Yk は yk 符号器出力の k 番目のビットである。 冗長情報はデマルチプレックスされた後、(yk=y1k のとき)DEC1 に送られるか(yk=y2k のとき)DEC2 に送られる。 DEC1 は軟判定を行う。すなわち、 Λ ( d k ) = log p ( d k = 1 ) p ( d k = 0 ) {\displaystyle \Lambda (d_{k})=\log {\frac {p(d_{k}=1)}{p(d_{k}=0)}}} であり、その結果を DEC2 に渡す。Λ(dk) は logarithm of likelihood ratio (LLR) と呼ばれる。p(dk=i), i=0,1 は dk データビットの事後確率(APP)であり、受信した dk を i と解釈する確率を示している。LLR を考慮することで、DEC2 は硬判定、すなわち復号を行う。 ビタビアルゴリズムではAPPを計算できないことが知られている。そのため DEC1 には使えない。その代わりに修正を加えたBCJRアルゴリズムを使う。DEC2 にはビタビアルゴリズムがよく使われる。 なお、ここで示した流れは最適ではない。DEC1 は利用可能な冗長情報の一部しか使っていない。一般に DEC2 の出力を DEC1 にフィードバックすることで最適化する。 復号器の前半部はデータストリームの各ビットについて、ある整数値を生成する。この整数はそのビットが 0 または 1 である確からしさを示すものである。例えば、その整数が [-127, 127] の範囲とした場合、 などと解釈できる。 これはフロントエンドからのデータストリームに確率的な面を導入するが、単にビットが0か1かというよりも多くの情報を伝えられる。 例えば、従来型の無線受信機のフロントエンドなら、各ビットは信号の電圧が所定のしきい電圧の上か下かで判別されていた。ターボ符号の復号器の場合、フロントエンドは電圧がしきい値からどれだけ離れているかを数値的に表すことになる。 m+n ビットのデータブロックを復号するため、復号器のフロントエンドは個々のビットの可能性測度をまとめた可能性測度のブロックを生成する。2つの並列の復号器が、それぞれ n/2 ビットのパリティサブブロックを扱う。これら復号器はペイロードデータのために m 個の可能性測度のサブブロックを使う。2番目のパリティのサブブロックを扱う復号器は、符号器が行った並べ替えを知っている。 ターボ符号の鍵となる発明は、可能性データをどのように使って2つの復号器の違いを調和させるかという点である。2つの畳み込み復号器はそれぞれ m ビットのパターンの仮説(と可能性)を生成する。仮説ビットパターンを比較し、差異があれば、復号器は仮説内の各ビットに対応した可能性測度を交換する。それぞれの復号器はもう一方の復号器が生成した可能性測度列を持っていて、それを使って新たな仮説ビットパターンを生成する。その後、それらは新たな仮説を比較する。このような反復プロセスは2つの復号器が同じ仮説ビットパターンで合意するまで繰り返され、通常15から18回反復される。 これは、言ってみればクロスワードパズルや数独を解くようなものである。部分的に解かれ一部改ざんされた可能性のあるクロスワードパズルを2人の人間(=復号器)が解くことを想定してみよう。1人は縦のヒント(パリティビット)だけを処理し、もう1人は横のヒントだけを処理する。2人はまず自分の持つヒントに基づいてパズルを解き、それぞれの文字についてどれだけ信頼があるかを添える。そして、それぞれの結果を比較し、互いに解と信頼度を交換し、どこがどう違うのかを知る。この新たな知識に基づいて、解と信頼度を更新し、最終的に同じ解になるまでこれを繰り返すのである。 人工知能の観点では、ターボ符号はベイジアンネットワークでのループのある確率伝播と見なすことができる[5]。
利点と欠点
歴史
符号化
復号
軟判定手法
-127 なら「確実に 0 である」
-100 なら「ほぼ確実に 0 である」
0 なら「0 または 1 のどちらかである」
100 なら「ほぼ確実に 1 である」
127 なら「確実に 1 である」
2つのビットパターン仮説
ターボ符号の具体的応用
ターボ符号は第三世代携帯電話[3]や第四世代携帯電話[4]の規格で広く使われている。
MediaFLO: クアルコムの携帯端末向けマルチメディア放送規格。
アメリカ航空宇宙局(NASA)の最近のミッション(マーズ・リコネッサンス・オービターなど)は、RS-ビタビ符号の代わりにターボ符号を使うようになっている。
ブロックターボ符号と畳み込みターボ符号は無線ネットワーク規格 IEEE 802.16 で使われている。
ベイズ的定式化
脚注^ a b .mw-parser-output cite.citation{font-style:inherit;word-wrap:break-word}.mw-parser-output .citation q{quotes:"\"""\"""'""'"}.mw-parser-output .citation.cs-ja1 q,.mw-parser-output .citation.cs-ja2 q{quotes:"「""」""『""』"}.mw-parser-output .citation:target{background-color:rgba(0,127,255,0.133)}.mw-parser-output .id-lock-free a,.mw-parser-output .citation .cs1-lock-free a{background:url("//upload.wikimedia.org/wikipedia/commons/6/65/Lock-green.svg")right 0.1em center/9px no-repeat}.mw-parser-output .id-lock-limited a,.mw-parser-output .id-lock-registration a,.mw-parser-output .citation .cs1-lock-limited a,.mw-parser-output .citation .cs1-lock-registration a{background:url("//upload.wikimedia.org/wikipedia/commons/d/d6/Lock-gray-alt-2.svg")right 0.1em center/9px no-repeat}.mw-parser-output .id-lock-subscription a,.mw-parser-output .citation .cs1-lock-subscription a{background:url("//upload.wikimedia.org/wikipedia/commons/a/aa/Lock-red-alt-2.svg")right 0.1em center/9px no-repeat}.mw-parser-output .cs1-ws-icon a{background:url("//upload.wikimedia.org/wikipedia/commons/4/4c/Wikisource-logo.svg")right 0.1em center/12px no-repeat}.mw-parser-output .cs1-code{color:inherit;background:inherit;border:none;padding:inherit}.mw-parser-output .cs1-hidden-error{display:none;color:#d33}.mw-parser-output .cs1-visible-error{color:#d33}.mw-parser-output .cs1-maint{display:none;color:#3a3;margin-left:0.3em}.mw-parser-output .cs1-format{font-size:95%}.mw-parser-output .cs1-kern-left{padding-left:0.2em}.mw-parser-output .cs1-kern-right{padding-right:0.2em}.mw-parser-output .citation .mw-selflink{font-weight:inherit}Berrou, Claude; Glavieux, Alain; Thitimajshima, Punya (1993). Near Shannon limit error-correcting coding and decoding: Turbo-codes. 1 (PDF). Proceedings of ICC'93-IEEE International Conference on Communications. Vol. 2. Telecom Bretagne. pp. 1064?1070. 2009年2月27日時点のオリジナル
Size:18 KB
出典: フリー百科事典『ウィキペディア(Wikipedia)』
担当:undef