JP4025226B2 - Error correction transmission device - Google Patents

Error correction transmission device Download PDF

Info

Publication number
JP4025226B2
JP4025226B2 JP2003077083A JP2003077083A JP4025226B2 JP 4025226 B2 JP4025226 B2 JP 4025226B2 JP 2003077083 A JP2003077083 A JP 2003077083A JP 2003077083 A JP2003077083 A JP 2003077083A JP 4025226 B2 JP4025226 B2 JP 4025226B2
Authority
JP
Japan
Prior art keywords
sub
symbol
bits
symbols
bit
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2003077083A
Other languages
Japanese (ja)
Other versions
JP2004289353A (en
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.)
Panasonic Corp
Panasonic Holdings Corp
Original Assignee
Panasonic Corp
Matsushita Electric Industrial Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Panasonic Corp, Matsushita Electric Industrial Co Ltd filed Critical Panasonic Corp
Priority to JP2003077083A priority Critical patent/JP4025226B2/en
Publication of JP2004289353A publication Critical patent/JP2004289353A/en
Application granted granted Critical
Publication of JP4025226B2 publication Critical patent/JP4025226B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Landscapes

  • Error Detection And Correction (AREA)
  • Digital Transmission Methods That Use Modulated Carrier Waves (AREA)

Description

【0001】
【発明の属する技術分野】
本発明は、誤り訂正伝送装置に関し、特に、畳込み符号を多値変調方式で伝送して軟判定ビタビ復号を行う誤り訂正伝送装置に関する。
【0002】
【従来の技術】
ディジタル通信では、誤り訂正符号化された送信データを送信シンボルに変換し、変調して送信する。受信機では、誤り訂正符号の復号を行い、情報データを得る。各種のディジタル通信で、バーストエラーに有利な畳込み符号が用いられている。畳込み符号の復号法としては、ビタビ・アルゴリズムが用いられている。ビタビ・アルゴリズムは、畳込み符号のもつ繰返し構造を利用して、最尤復号を効率的に実行する復号方法である。基本的には、トレリス線図上で時点毎に取り得るビット列と受信ビット列(またはビット列に対応した変調シンボル)とを比較し、尤度関数が最も大きくなる経路(最尤パス)を選択することで存在する符号系列パタンの全てとの総当り法を行うことなく送信信号を推定する。
【0003】
ビタビ・アルゴリズムを使った復号法には、硬判定と軟判定とがある。硬判定復号では、尤度関数にハミング距離を利用するもので、受信信号を2値として決定してから、パスの判定をする方法である。他方、軟判定復号は、尤度関数としてユークリッド距離を利用するもので、受信信号をアナログ値のまま取り扱って、パスの判定を行う方法である。軟判定復号は、受信信号のアナログ値に基づいて判定を行うので、硬判定復号に比べて誤り訂正能力が高い。従来の軟判定のビタビ・アルゴリズムを用いる誤り訂正符号の復号法については、非特許文献1を参照されたい。
【0004】
周波数利用効率の高い多値変調方式として、線形変調方式で符号識別点を格子状に配置した多値QAM方式(QPSK、16QAM、64QAM等)があり、多くのシステムで使用されている。線形変調方式では搬送波の同相成分(Ich)と搬送波の直交成分(Qch)の2チャネルを独立に使用することが可能である。従って、変調シンボルは、(I+jQ)のように複素数で表記することができる。ここでは、(I+jQ)を変調シンボル(または、単にシンボル)、I、Q個々を指す場合は変調サブシンボル(または、単にサブシンボル)と呼ぶものとする。
【0005】
ところで、軟判定ビタビ・アルゴリズムは、畳込み符号を多値変調方式で送信する場合に、無条件で利用できるわけではない。その理由は、多値変調方式の送信単位(サブシンボル)は1ビットの場合と複数ビットの場合があるが、復調時の振幅情報は送信単位でしか得られないので、サブシンボルの情報量が2ビット以上の場合は1ビット単位の振幅情報を知ることができなくなるためである。
【0006】
図13に示すトレリス線図を参照しながら、従来の軟判定ビタビ復号の方法を説明する。符号化率R=1/2で変調方式がQPSKの場合を例にすると、符号器の1ステップの状態遷移の経路は2つある。入力ビット値が0の場合と1の場合である。ビタビ・アルゴリズムでは、それぞれの場合について、送信系列と受信系列を効率的に比較するために、各時点において各状態に合流するブランチに対応する送信シンボルと受信振幅とを比較して、そのユークリッド距離の2乗を求め、1時点前の状態のパスメトリックと加算し、その値の小さい方のブランチを選択することにより、全ての状態(S0〜S15)に対する経路とパスメトリックを決める。1つの生き残りパスの着目すると、その結果は図14に示すようになる。ここでMはパスメモリの値である。このような処理を、時点1から時点N×R(Nは符号長、Rは符号化率)まで実行する。畳込み符号がテールビットにより状態0に終結されている場合、最後の状態はS0であることから、時点N×RのS0から、時点0の方向にパスメモリの値に従って状態遷移を逆に辿って行く(これをトレースバックと言う。)と、復号ビット列を得ることができる。
【0007】
図15は、畳込み符号を多値変調方式で伝送して軟判定ビタビ復号を行う従来の無線機の構成である。ここでは、送信側で畳込み符号器の直後にビットインタリーバが配置されているため、一般に受信側では1ビット/サブシンボルのQPSKなどの変調方式でなければ、サブシンボルデインタリーバによって元の配列の戻すことができない。
【0008】
【非特許文献1】
今井秀樹:「符号理論」(社団法人電子通信学会、平成9年発行)pp.280-312.
【0009】
【発明が解決しようとする課題】
従来の誤り訂正伝送方式では、多値変調のサブシンボルが1ビット構成(1ビット/サブシンボル)の場合にしか軟判定を適用できず、誤り訂正能力を十分に高めることができないという問題がある。その理由は以下の通りである。
【0010】
多値変調のシンボルの数を22qで表すと、サブシンボルI及びQはqビットで表現される。因みに、4値の場合はq=1、16値の場合はq=2、64値の場合はq=3、256値の場合はq=4となる。一方、畳込み符号の符号化率は、入力系列数kと出力系列数n(符号ブロックのビット数。以降、符号ブロックは符号語と略記する。)により、R=k/nと表される。qがnの約数であれば、一つの符号語を整数個のサブシンボルで表現できるので、1ステップの状態遷移ごとに、受信シンボルが各ブランチに対応した送信シンボルである確率(条件付確率。これを尤度関数と呼ぶ。)を計算できる。しかし、qがnの約数でないと、一つの符号語を整数個のサブシンボルでは表現できない。そのため、1ステップの状態遷移ごとの各ブランチの条件付確率を定義できない。従って、硬判定復号は可能であるが、符号器入力kビット毎の状態遷移を評価する通常の軟判定ビタビ復号は不可能となる。
【0011】
符号化率R=1/2の畳込み符号の場合、1ビット/サブシンボルのQPSK(π/4シフトQPSKでも同じ)か、2ビット/サブシンボルの16QAMであれば、一つの符号語を整数個のサブシンボルで表現できるので、通常の軟判定ビタビ復号は可能である。しかし、ビットインタリーブが施された場合は、16QAMでは一つの符号語の情報は二つのサブシンボルに分離され、他の符号語の情報と混合された形でしか取り出すことが出来なくなる。また、64QAMは3ビット/サブシンボルであるので、一つの符号語を1つのサブシンボルでは表現すること自体できない。符号化率R=2/3の畳込み符号の場合は、QPSKと64QAMは使えるが、16QAMは使えない。また、ビットインタリーブを行った場合は64QAMでは単独の符号語の情報を取り出すことができない。このように、従来方式では特定の符号化率の畳込み符号に対して特定の多値数(以降、シンボルサイズと表記する。)の多値変調方式しか使うことができず、最適の多値変調方式を選択して伝送効率を上げることができない。
【0012】
本発明は、上記従来の問題を解決して、任意の符号化率の畳込み符号を任意のシンボルサイズの多値変調方式を使って伝送しても軟判定ができるようにして、誤り率を下げて伝送効率を高めることを目的とする。
【0013】
【課題を解決するための手段】
上記の課題を解決するために、本発明では、誤り訂正伝送装置を、kビットの情報系列入力ごとにnビットの符号語を出力する符号化率k/nの畳込み符号化手段と、畳込み符号化手段から出力された符号語のビット系列からqビットのサブシンボル2つからなるシンボルを組み立てるシンボル符号化手段と、サブシンボルを単位としてインタリーブするサブシンボルインタリーブ手段と、インタリーブしたサブシンボルで搬送波を直交変調して送信する送信手段と、受信信号を同期検波してサブシンボルとサブシンボル単位の搬送波振幅情報とを得る受信手段と、搬送波振幅情報とともにサブシンボルをデインタリーブするサブシンボルデインタリーブ手段と、サブシンボル単位で軟判定する軟判定ビタビ復号手段とを具備する構成とした。
【0014】
このように構成したことにより、任意の符号化率の畳込み符号に対して、任意のシンボルサイズの多値変調方式を選択しても、軟判定ビタビ復号ができるので、誤り率を低減させて伝送効率を高めることができる。
【0015】
また、シンボル符号化手段に、qとnの最小公倍数LCM(q,n)を処理単位ビット数pとして、pビット分の符号語をpビット分のサブシンボルに対応させる手段を設け、軟判定ビタビ復号手段に、pビット分の符号語に対応する畳込み符号化手段の状態遷移ごとにブランチメトリックを計算する評価手段を設けた。このように構成したことにより、符号語のビット数がサブシンボルのビット数で割り切れない場合でも、軟判定ビタビ復号ができるので、誤り率を低減させて伝送効率を高めることができる。
【0016】
また、評価手段に、pビット分の符号語とpビット分のサブシンボルと間のユークリッド距離を計算する計算手段を設けた。このように構成したことにより、ハミング距離を使う場合より精密に軟判定ビタビ復号ができるので、誤り率を低減させて伝送効率を高めることができる。
【0017】
また、受信手段に、正規化した同期検波出力に各時点の搬送波レベルを乗じて元の座標系に戻す手段を設け、計算手段に、ユークリッド距離の2乗を対数尤度としてブランチメトリックを計算する手段を設けた。このように構成したことにより、熱雑音の影響を除去して精密に軟判定ビタビ復号ができるので、誤り率を低減させて伝送効率を高めることができる。
【0018】
【発明の実施の形態】
以下、本発明の実施の形態について、図1〜図12を参照しながら詳細に説明する。
【0019】
(実施の形態)
本発明の実施の形態は、畳込み符号器の出力を多値変調シンボルに変換した後、サブシンボル単位でインタリーブを行い直交変調して送信し、受信して同期検波により得られた受信サブシンボル値(アナログ値)と再生搬送波レベル情報(これらを総称して「サブシンボルの振幅情報」と呼ぶものとする。)の組をサブシンボル単位でデインタリーブし、符号語のビット数とサブシンボルのビット数の最小公倍数を処理単位ビット数として、複数符号語ごとの状態遷移によりサブシンボルの振幅情報を使って軟判定ビタビ復号する誤り訂正伝送装置である。
【0020】
図1は、本発明の実施の形態における誤り訂正伝送装置の送受信機の機能ブロック図である。図1(a)は、送信機の構成図である。図1(b)は、受信機の構成図である。図1において、畳込み符号器1は、情報系列入力を畳込み符号化する回路である。符号化部2は、複数ビットをまとめて一つのサブシンボルに変換する回路である。サブシンボルインタリーバ3は、サブシンボル単位でインタリーブする手段である。同期検波処理部4は準同期検波されA/D変換されてデジタルフィルタで構成されたLPFにより帯域制限されサンプリングデータから同期タイミングを抽出して同期検波を行う回路である。サブシンボルデインタリーバ5は、サブシンボル単位でインタリーブされたデータを元の順序に並べ直す手段である。軟判定ビタビ復号器6は、状態遷移の複数ステップ単位で軟判定をしてビタビ復号する手段である。
【0021】
図2は、本発明の実施の形態における誤り訂正伝送装置を従来例と比較して説明する流れ図である。図3は、畳込み符号器の回路図の一例である。図4は、状態遷移をすべて示したトレリス線図である。図5は、状態遷移のブランチメトリックを計算する様子を説明するトレリス線図である。図6は、一つの生残りパスに着目した複数符号語ごとの状態遷移を示す図である。ここでMはパスメモリの値である。
【0022】
図7は、本発明の実施の形態における誤り訂正伝送方式の復調手順を示す流れ図である。図8は、復号手順を示す流れ図である。図9は、トレースバックの手順を示す流れ図である。図10は、インタリーブ関数の説明図である。図11は、バーストフォーマットの説明図である。図12は、誤り訂正の静特性のグラフと、フラットフェージング下における誤り訂正特性のグラフと、マルチパスフェージング下における誤り訂正特性のグラフである。
【0023】
上記のように構成された本発明の実施の形態における誤り訂正伝送方式の動作を説明する。最初に、図1を参照しながら、送受信機の動作の概要を説明する。情報系列入力SD[i]を畳込み符号器1に入力する。畳込み符号器1の出力を符号化部2でqビットごとにグレイ符号化して多値変調のシンボル(I[m]、Q[m])にマッピングする。サブシンボルインタリーバ3により、サブシンボル単位でインタリーブ(I[n]、Q[n])を行う。これ以降は、通常の直交変調送信機の動作と同様である。
【0024】
受信機では、受信した信号を準同期検波(I'(t)、Q'(t))し、これをボーレート周波数の数倍周波数(例えば8倍)でサンプリング及びA/D変換してデジタルローパスフィルタ(LPF)を通し、出力されたサンプリングデータ(I'(k)、Q'(k))を同期検波処理部4に送る。同期検波処理部4では、送られてきたサンプリングデータの中から同期シンボルを検出してシンボルタイミングを抽出し、バーストフォーマットで定義されているパイロットシンボルを利用して搬送波を再生(cx(n))してその絶対値(W(n))を算出するとともに、再生搬送波により同期検波部で同期検波(I[n]、Q[n])する。ここで得られたサブシンボル情報(I[n], W[n]、Q[n], W[n])を、サブシンボル・デインタリーバ5でデインタリーブ(I[m], W[m]、Q[m], W[m])する。軟判定ビタビ復号器6で、サブシンボル単位で軟判定を行う。
【0025】
本発明の実施の形態における誤り訂正伝送装置を一般化すると、次のようになる。符号化率k/nの畳込み符号化手段で、kビットの情報系列入力ごとに、nビットの符号語を出力する。畳込み符号化手段から出力された符号語のビット系列を、qビットごとに区切ってのサブシンボル系列を生成する。サブシンボルを単位としてインタリーブする。インタリーブしたサブシンボルを2つづつ取り出してIch、Qchとし、搬送波を直交変調して送信する。受信側では、受信信号を同期検波してサブシンボル(Ich、Qch)とサブシンボル単位の搬送波振幅情報(W)とを得る。搬送波振幅情報とともにサブシンボルをデインタリーブする。qとnの最小公倍数LCM(q,n)を処理単位ビット数pとして、pビット分の符号語をpビット分のサブシンボルに対応させる。pビット分の符号語に対応する畳込み符号化手段の状態遷移ごとに、pビット分の符号語とpビット分のサブシンボルとの間のユークリッド距離に搬送波振幅を掛けて2乗した値によりブランチメトリックを計算して軟判定を行う。
【0026】
軟判定復号を行う場合、変調方式が16QAM(2ビット/サブシンボル)のとき、符号化率R=k/3(k=1〜2)、k/5(k=1〜4)といった符号が、変調方式が64QAM(3ビット/サブシンボル)のときは、符号化率R=1/2、k/4(k=1〜3)といった符号が、1ステップ(時点)ごとの状態遷移が不可能となる。16QAMでR=k/3の場合は3ステップ(LMC(2,3)=6ビット)、16QAMでR=k/5の場合は2ステップ(LMC(2,5)=10ビット)、64QAMでR=1/2の場合は3ステップ(LMC(3,2)=6ビット)、64QAMでR=k/4の場合も3ステップ(但し、LMC(4,3)=12ビット)ごとの状態遷移が必要となる。このように、複数ステップごとの状態遷移により、ブランチメトリック、パスメトリックを算出してパスを決定する方法を、通常のビタビ復号と区別するために、ここでは「変形ビタビ復号」と呼ぶものとする。
【0027】
図2を参照しながら、生成多項式次数5、符号化率R=1/2、情報点数100ビットの符号を64QAMで伝送する場合について、従来例と比較して本発明を説明する。情報系列入力(100ビット)を畳込み符号化(210ビット)するところまでは、従来例と同様である。従来は、ビットインタリーブしてから多値変調のシンボルに変換(35シンボル)している。一方、本発明では多値変調のシンボルに変換(70サブシンボル)してから、サブシンボル単位でインタリーブ(70サブシンボル)を行う。その後、バースト信号へサブシンボルをマッピング(70サブシンボル)して、直交変調して送信する。従来例の受信側では、同期検波してデータシンボルを抽出(35シンボル)し、グレイ符号を復号(210ビット)してビット単位でデインタリーブ(210ビット)した後、硬判定ビタビ復号(100ビット)を行う。一方、本発明では、準同期検波出力からデータサブシンボルを抽出(70サブシンボル)し、サブシンボル単位でデインタリーブ(70サブシンボル)した後、軟判定ビタビ復号(100ビット)を行う。
【0028】
次に、図4と図5を参照しながら、図1(b)の中の軟判定ビタビ復号の処理ブロックにおいて、符号器の状態遷移を複数ステップごとに行う方法について、生成多項式の次数4(拘束長5、状態数16)、符号化率R=1/2の符号を64QAMで伝送する場合を例に説明する。前述したように、変調サブシンボルが3ビット構成で、符号化率R=1/2の場合、軟判定を実行するためには、状態遷移は3ステップごとに行う必要がある。3ステップごとの状態遷移は、時点t−3の状態から時点tの状態へのパスが各状態に8通りあるので、図4に示したようになる。図4の中で左側に示した「符号器の状態」は、時点に拘わらず、その状態(シフトレジスタの状態)を、左側をMSBとして表示したものである。また、右側に示した「符号器の入力」は、その状態に合流する場合に符号器に入力されるビット列を、左側をMSB(時間的に先に入力されるビット)として表示したものである。
【0029】
この中で、時点tの状態S1に着目した説明図が図5である。ある時点t−3からt−1の間に符号器に入力される3ビットが"xxx"で、時点tで"yxxx"に合流するパスの3時点前の状態には、"000y"、"001y"、"010y"、"011y"、"100y"、"101y"、"110y"、"111y"の8通りが存在する。ここでは、図3の符号器の回路図の中のシフトレジスタの表記法(左方向にシフト)に合わせて、左側を上位側(MSB)として表記している。ここで8通りのパタンが存在する上位3ビットは、符号器に3ビットが入力されるとシフトされて消えて行く部分である。ブランチ番号iは、この3時点前のシフトレジスタの状態の上位3ビットを10進表示したものに対応付けられる。したがって、状態S1に着目すると、その3時点前の状態は、下位1ビット"y"が"0"で符号器入力"xxx"が"001"の場合に状態S1に流入するので、その候補は状態S0(i=0)、S2(i=1)、S4(i=2)、S6(i=3)、S8(i=4)、S10(i=5)、S12(i=6)、S14(i=7)の8通り存在することになる。
【0030】
図5において、記号λ(S,t)及びλ(S,t-3)は、それぞれ時点t及び時点t-1における状態Sのパスメトリックを表すものとする。前述の符号化方式と変調方式を例に取ると、状態遷移は3ステップごとに行われる。即ち、時点番号tが3の倍数のときに、図1(b)のサブシンボル・デインタリーバより受信第1変調サブシンボルz(2n)とその再生搬送波レベルc(2n)、及び受信第2変調サブシンボルz(2n+1)とその再生搬送波レベルc(2n+1)が与えられる。各状態Sに、その直前の状態番号をブランチ番号iごとにテーブルF0(i,S)により求め、そのブランチiに対応する第1変調サブシンボルをテーブルF1(i,S)で、第2変調サブシンボルをテーブルF2(i,S)により求める。なお、これらの値と、この時点で取得される上記受信情報を用いて、以下の最小値を求める。
λ(S,t)=min{(|F1(i,S)−z(2n)|×|cx(2n)|)2
+(|F2(i,S)−z(2n+1)|×|cx(2n+1)|)2+λ(F0(i,S),t-3)}(i=0〜7)
そこで、その最小値をその状態Sのパスメトリックとして記憶するとともに、最小値を与えるブランチ番号iをパスメモリM(S,n)に記憶する。ここで、変数nは時点番号tと、3n=tの関係にある。
【0031】
ここで使用するテーブルF0(i,S)、F1(i,S)、F2(i,S)は、以下の方法により与えられる。まず、iをブランチ番号(0〜7)、Sを状態番号(0〜15)、bをビット番号(0〜6)として、次の関数を定義する。
d(i,S,b)=mod(int((16i+S)/2b),2)
ここで、int(x)はxの整数部、mod(x,2)はxを2で除した余りである。d(i,S,b)は、状態番号がSでブランチ番号がiのとき、この時点までに符号器に入力されたビット列を算出する関数で、現時点の符号器のシフトレジスタのLSB(D1)をビット0(b=0)、3時点前の符号器のシフトレジスタのMSB(D4)をビット6(b=6)としている。
【0032】
関数d(i,S,b)を用いると、3時点前の状態番号F0(i,S)は次式により与えられる。
F0(B,S)=d(i,S,6)×8+d(i,S,5)×4+d(i,S,4)×2+d(i,S,3)
次に、第1の変調サブシンボル値F1(B,S)は次式により与えられる。
F1(i,S)=(1-2×y0)×{(1-2×y1)×(3-2×y2)+4}
ただし、
y0=mod(Σg1(v)d(i,S,v+2),2)(総和はv=0〜4)
y1=mod(Σg2(v)d(i,S,v+2),2)(総和はv=0〜4)
y2=mod(Σg1(v)d(i,S,v+1),2)(総和はv=0〜4)
で、F1(i,S)はy0,y1,y2の3ビットグレイ符号(±1,±3,±5,±7)である。
【0033】
第2の変調サブシンボル値F2(B,S)は次式により与えられる。
F2(i,S)=(1-2×y3)×{(1-2×y4)×(3-2×y5)+4}
ただし、
y3=mod(Σg2(v)d(i,S,v+1),2)(総和はv=0〜4)
y4=mod(Σg1(v)d(i,S,v),2)(総和はv=0〜4)
y5=mod(Σg2(v)d(i,S,v),2)(総和はv=0〜4)
で、F2(i,S)はy3,y4,y5の3ビットグレイ符号(±1,±3,±5,±7)である。
y0,y1は3時点前から2時点前の間に送出される符号語、y2,y3は2時点前から1時点前の間に送出される符号語、y4,y5は1時点前から現時点までの間に送出される符号語である。なお、g1(v)、g2(v)は畳込み符号の生成多項式の係数で、
g1(4)=1,g1(3)=1,g1(2)=0,g1(1)=0,g1(0)=1
g2(4)=1,g2(3)=0,g2(2)=1,g2(1)=1,g2(0)=1
である。
【0034】
以上が、変形ビタビ復号の基本アルゴリズムである。次に、このアルゴリズムを用いた復号動作を、図11のバーストフォーマットを例に、図7、図8、図9の流れ図を参照しながら説明する。図11に示したような一般的なバーストフォーマットにより信号を伝送する場合を例として、多値変調方式の同期検波について説明する。通常、多値変調方式のバースト信号は、送信立上りのランプ時間の後、一連の同期シンボルに続いてデータシンボルが配置されるが、その中に一定間隔でパイロットシンボルを挿入する。パイロットシンボルは同期シンボルと同様、送受信間で既知の値のシンボルである。本実施の形態では、64QAMの例として、パイロットシンボルの値は、良好なS/Nを得るために、一律
I+jQ=7+7j
としている。
【0035】
図7の復調処理手順(図1(b)の同期検波処理部4の動作)では、A/D変換部・LPF部より出力されたサンプリングデータ(I'(k)、Q'(k))の中から、「シンボル同期獲得処理」ブロックで同期シンボルを検出して、シンボルタイミングを抽出し、「受信シンボル抽出」ブロックで同期シンボルに続くパイロットシンボルとデータシンボルを抽出する。ここで得られる受信シンボルの値rx(t)は複素数である。なお、変数tは同期シンボル以降の絶対シンボル番号を表し、第1のパイロットシンボルのシンボル番号を0、最後尾のパイロットシンボルのシンボル番号をK+p0−1としている。Kはデータシンボルの個数、p0はパイロットシンボルの個数である。
【0036】
rx(t)が抽出されると、データシンボル番号をk、パイロットシンボル番号を≡、2つのパイロットシンボルの間にあるデータシンボルの相対番号をhとして逐次、以下の式により搬送波再生を行う。
cx(k)=[{rx(b1)-rx(b0)}/b2×h+rx(b0)]/[7+7j]
cx(k)は再生搬送波を表す複素数で、k番目のデータシンボルを、その前後に位置するパイロットシンボルで1次補間している。b0は前に位置するパイロットシンボル絶対シンボル番号、b1は後に位置するパイロットシンボル絶対シンボル番号、7+7jは予め定義されているパイロットシンボルの値である。線形変調においては、変調波は搬送波に変調成分(I+jQ)を掛けたものであるから、準同期検波で得られたデータシンボルの値rx(b0+h)を再生搬送波cx(k)で除することにより同期検波することができる。cx(k)、rx(b0+h)は複素数であり、cx(k)で除することにより振幅と位相が同時に補正されることとなる。ここで得られた複素数の実部がIch、虚部がQchの成分である。その結果は、次式によりIchを偶数番号のサブシンボル、Qchを奇数番号のサブシンボルとして記憶する。
y(2k)=Re[rx(b0+h)/cx(k)]・・・Ich
y(2k+1)=Im[rx(b0+h)/cx(k)]・・・Qch
【0037】
続いて、サブシンボル・デインタリーバにより、サブシンボルとこれに付随する再生搬送波の絶対値の組をインタリーブ関数ilv(k)関数により、デインタリーブを行う。ここで、変数kはサブシンボル番号である。通常の復調では、ここで得られた複素数rx(b0+h)/cx(k)(=y(2k)+j・y(2k+1))と信号空間上で最も近いシンボル点の信号が送信されたものと判定し、それに対応したビット列を出力するが、ここでは軟判定を行うため、その実部をy(2k)、虚部をy(2k+1)として同期検波出力(図1(b)ではI[n],Q[n]に相当)としている。
【0038】
図8の復号処理手順では、復調処理手順で得られた受信サブシンボル値z(・)と再生搬送波の絶対値w(・)により、軟判定による変形ビタビ復号を行う。PM(S)を状態Sにおけるパスメトリック値、M(S,n)を時点3nにおける状態Sのパスメモリ値とする。初期化処理としてパスメモリM(S,n)とパスメトリックPM(0)には0を、状態0以外のPM(S)には適当に大きな数値(ここでは215)を入れておく。これは、初期の状態遷移においては存在しないブランチを選択させないための措置である。ここで状態番号Sは0〜15、状態遷移番号nは0〜K−1である。
【0039】
時点t=3n,3n+1,3n+2に対応する受信サブシンボルと再生搬送波の絶対値は復調処理手順で既に記憶されている以下の配列変数により与えられる。
受信サブシンボル :z(2n),z(2n+1)
再生搬送波の絶対値 :w(2n),w(2n+1)
したがって、状態遷移番号nごとに、状態Sが0から15に対して、ブランチ番号iを0から7まで変えながらブランチメトリックbmとパスメトリックpmを以下の式により計算する。
bm={|F1(i,S)-z(2n)|×w(2n)}2+{|F2(i,S)-z(2n+1)|×w(2n)}2・・・・・・式1
pm=bm+PM(F0(i,S))
状態Sにおいてパスメトリックが最小となるブランチ番号iを逐次比較することにより求め、このときのパスメトリック値を配列変数TPM(S)に一時記憶するとともに、パスメモリM(S,n)を更新する。全ての状態Sについてこの処理が終了すると、パスメトリックPM(S)をTPM(S)の値に更新する。この処理をnの値が0からK−1まで順次実行する。
【0040】
図9のトレースバック処理では、復号処理手順で得られたパスメモリM(S,n)を用いて、状態遷移を逆に辿ること(これをトレースバックと呼ぶ。)により、符号器への推定入力系列を得ることができる。本実施の形態では、畳込み符号はテールビットにより状態0に終結するものとしている。したがって、パスメモリの状態0、状態遷移番号K−1を起点として、トレースバックを行うものとする。nをK−1、Sを0として、配列変数TB(n)に初期値のM(0,K-1)を代入し、逐次、nをデクリメントしながら以下の式により計算を行うことにより、復号が完了する。
S=F0(TB(n+1),S)
TB(n)=M(S,n)
RD(3n)=mod(int(TB(n)/4),2)
RD(3n+1)=mod(int(TB(n)/2),2)
RD(3n+2)=mod(TB(n),2)
RD(・)は、軟判定変形ビタビ復号により得られた復号ビット列である。また、F0(i,S)は前述の状態Sのブランチ番号iに対応する3時点前の状態を示す関数(テーブル)である。以上が、図7、図8、図9を参照した軟判定変形ビタビ復号による復号手順の説明である。
【0041】
上記の復号処理手順におけるブランチメトリックの算出方法において、式1に示したように単なるユークリッド距離の2乗ではなく、それに搬送波の絶対値の2乗を掛けている理由について説明する。送信されたデータシンボルの正規のシンボル点をsx+j・sy、そのデータシンボルの準同期検波出力をrx+j・ry、そのときの再生搬送波をcx+j・cyのように複素数で表すものとすると、正規シンボル点と同期検波後のデータシンボル点との成分ごとのユークリッド距離Di、Dqは、
Di=Re{(sx+j・sy)−(rx+j・ry)/( cx+j・cy)}
Dq=Im{(sx+j・sy)−(rx+j・ry)/( cx+j・cy)}
で与えられる。
【0042】
一方、準同期検波時にデータシンボルに相加された熱雑音をnx+j・nyで表すものとする。熱雑音の場合、その同相成分nxと直交成分nyは互いに独立した正規分布N(0,σ)に従うことが知られている。(熱雑音電力の平均値は2σ2となる。)回線の振幅変動がA(倍)、位相変動がθ(rad)であった場合、準同期検波出力rx+j・ryは次式で与えられる。
rx+j・ry=(sx+j・sy)・A・exp(j・θ)+ nx+j・ny
したがって、再生搬送波cx+j・cyが理想的であった場合、
cx+j・cy=A・exp(j・θ)
となるので、
(sx+j・sy)−(rx+j・ry)/(cx+j・cy)
=(sx+j・sy)−(sx+j・sy)−(nx+j・ny)/(cx+j・cy)
=−(nx+j・ny)/(cx+j・cy)
の関係が成立する。したがって、前述のユークリッド距離は、
Di=Re{(nx+j・ny)/(cx+j・cy)}
Dq=Im{(nx+j・ny)/(cx+j・cy)}
と書き換えることができる。
【0043】
次に、ユークリッド距離に搬送波の絶対値(振幅)を乗ずると、次式のようになる。
Di'=Di・|cx+j・cy|=Re{(nx+j・ny) exp(−j・θ)}
Dq'=Dq・|cx+j・cy|=Im{(nx+j・ny) exp(−j・θ)}
前述したように、熱雑音の同相成分と直交成分は無相関であることから、Di'及びDq'の分布は、やはり正規分布N(0,σ)に従う。Di'及びDq'を代表してdと表記すると、その確率密度関数p(d)の対数(以降、これを対数尤度と略記する。)は、
−d2/(2σ2)−1/2・ln(2π)−ln(σ)
となる。以上の考察から、ブランチメトリックを算出する場合、単にブランチごとに想定されるサブシンボル点と同期検波出力されたサブシンボル値のユークリッド距離Di又はDqの2乗値を求めるだけでなく、それに搬送波の絶対値|cx+j・cy|の2乗を掛けることにより、直接、熱雑音に対する対数尤度を得ることが可能となることが分かる。
【0044】
なお、定数項−1/2・ln(2π)−ln(σ)、及び係数1/(2σ2)は、時点、状態、ブランチに関して共通であり、比較演算においては相殺されるので省略可能である。また、比較演算において尤度の大きい方を選択するが、その際、対数尤度の負数−(−d2)=d2を使用する場合は、値の小さい方を選択すればよいことになる。一方、ユークリッド距離のみで評価すると、フェージング変動等がある場合、時点ごとに増幅度が異なるため、同期検波出力に相加される熱雑音の標準偏差が異なることとなる。ブランチメトリックのみの比較であれば相殺されるが、ビタビ・アルゴリズムでは前の時点のパスメトリック値と加算した値でブランチ間の比較を行うため、正しい尤度関数が与えられないことになる。
【0045】
図10を参照しながら、インタリーブの方法を説明する。インタリーブは、バーストエラーをランダムエラーに変換する方法である。一般的なインタリーブでは、データ数をN(=m×n)とすると、データをn個ごとに区切ってm行n列に配列し、これを列ごとに読み出すことにより隣接するデータ間の間隔を拡大する。このとき、m=nであれば次隣接以降のデータとの間隔も同時に確保されるが、m、nの一方の値が極端に小さいと、バーストエラーをランダムエラーに変換することができなくなる。図11のバースト信号フォーマットの例では、データシンボル数が48、即ち、サブシンボル数が96であることから、これを上述のような行列にする場合、6×16、または、8×12が一般的である。これを極力正方行列に近い形でインタリーブを行う方法として、本実施例では、図10に示すような不完全な行列(10×10の行列で10行目が4個不足)を作り、不足箇所をスキップすると言う方法を取っている。ここでは、データ数をNとすると、これの平方根の値以上で最小の整数をm、及びnとし、m×n−NをLとする。即ち、Nは96であることから、この平方根9.797・・・以上で最小の整数は10であることから、m=n=10、L=4となる。
【0046】
このインタリーブは、図10の関数ilv(k)で与えられる。ここでkはデータの読み出し順序番号、ilv(k)はそれに対応するデータ書き込み順序番号である。行列が完全な部分(k=0〜59)では、インタリーブ関数は次式で与えられる。
ilv(k)=mod(k,m)×n+int(k/m)
一方、最終行の後半の列が不足している部分(k=60〜95)のインタリーブ関数は次式により与えられる。
ilv(k)=mod(k-m(n-L),m-1)×n+int((k-m(n-L))/(m-1))+n-L
なお、ここで、mod(x,y)はxをyで割った余り、int(x/y)はxをyで割った値の整数部を表す。
【0047】
軟判定の効果を、図12のグラフに示す。これらのグラフは、フェージング変動がない場合(静特性)と、フェージング変動がある場合(フラットフェージング)と、先行波と遅延波1波のマルチパスでフェージング変動がある場合(マルチパスフェージング)について、訂正前と硬判定訂正後と軟判定訂正後のビット誤り率をシミュレーションにより計算した結果である。軟判定では、硬判定よりビット誤り率が低下していることがわかる。
【0048】
上記のように、本発明の実施の形態では、誤り訂正伝送方式を、畳込み符号器の出力を多値変調シンボルに変換してから、サブシンボル単位でインタリーブを行い、直交変調して送信し、受信したデータを振幅データとともにサブシンボル単位でデインタリーブし、符号語のビット数とサブシンボルのビット数の最小公倍数を処理単位ビット数として、複数符号語に対応する複数時点間の状態遷移をまとめて、サブシンボルの振幅情報を使って軟判定ビタビ復号する(変形ビタビ復号を行う)構成としたので、任意の符号に対して任意の多値変調方式を選択しても軟判定が可能となり、誤り率を低減させて伝送効率を高めることができる。
【0049】
但し、変形ビタビ復号にはビタビ復号より計算量が多いと言う問題がある。符号化効率をk/n、多値変調のサブシンボルサイズをqビット/サブシンボルとし、nとqの最小公倍数LCM(n,q)をa×nで表すと、aは変形ビタビ復号における1回の状態遷移の時点数を与える。変形ビタビ復号の1回の状態遷移におけるメトリック計算量(回数)は、ブランチ数をBm、状態数をSとすると、Bm×Sとなる。ブランチ数Bmはa時点間の遷移であるから2k a個となる。一方、通常のビタビ復号のa時点間のメトリック計算量はa×B×Sとなるが、この時のブランチ数は2kである。以上のことから、変形ビタビ復号の単位時点あたりのメトリック計算量は、ビタビ復号の2k(a-1)/a倍となることが分かる。なお、a=1は通常のビタビ復号を表している。
【0050】
因みに、k=1の場合、a=2では1倍となり計算量は増えないが、a=3では1.333倍(本実施例の値)、a=4では2倍、a=5では3.2倍と急激に増大する。また、k=2とすると、a=2で2倍、k=3ではa=2で4倍となる。従って、k=1の場合はaが4以下、k=2の場合はaが2であれば、通常のビタビ復号の2倍以下の計算量で軟判定復号を行うことができるが、これを越えると計算量は急激に増大することになる。変形ビタビ復号の導入にあたっては、このような特徴を考慮して、変調方式(qの値)、符号化方式(k及びnの値)、及び、演算素子(DSP)の選定を行うことが望ましい。
【0051】
【発明の効果】
以上の説明から明らかなように、本発明では、誤り訂正伝送装置を、kビットの情報系列入力ごとにnビットの符号語を出力する符号化率k/nの畳込み符号化手段と、畳込み符号化手段から出力された符号語のビット系列からqビットのサブシンボル2つからなるシンボルを組み立てるシンボル符号化手段と、サブシンボルを単位としてインタリーブするサブシンボルインタリーブ手段と、インタリーブしたサブシンボルで搬送波を直交変調して送信する送信手段と、受信信号を同期検波してサブシンボルとサブシンボル単位の搬送波振幅情報とを得る受信手段と、搬送波振幅情報とともにサブシンボルをデインタリーブするサブシンボルデインタリーブ手段と、サブシンボル単位で軟判定する軟判定ビタビ復号手段とを具備する構成としたので、畳込み符号の符号化率と多値変調のシンボルの最適な組合せを選択して軟判定ビタビ復号ができ、伝送誤り率を極限まで低くすることができるという効果が得られる。
【図面の簡単な説明】
【図1】本発明の実施の形態における誤り訂正伝送装置の送受信機の機能ブロック図、
【図2】本発明の実施の形態における誤り訂正伝送装置を従来例と比較して説明する流れ図、
【図3】本発明の実施の形態における誤り訂正伝送装置での符号器の構成を示す図、
【図4】本発明の実施の形態における誤り訂正伝送装置の状態遷移をすべて示した図、
【図5】本発明の実施の形態における誤り訂正伝送装置の状態遷移のブランチメトリックを計算する様子を説明する図、
【図6】本発明の実施の形態における誤り訂正伝送装置で状態遷移を計算した結果を示す図、
【図7】本発明の実施の形態における誤り訂正伝送装置での復調手順を示す流れ図、
【図8】本発明の実施の形態における誤り訂正伝送装置での復号手順を示す流れ図、
【図9】本発明の実施の形態における誤り訂正伝送装置でのトレースバックの手順を示す流れ図、
【図10】本発明の実施の形態における誤り訂正伝送装置で用いるインタリーブ関数の説明図、
【図11】本発明の実施の形態における誤り訂正伝送装置でのバーストフォーマットの説明図、
【図12】本発明の実施の形態における誤り訂正伝送装置の誤り訂正特性のグラフ、
【図13】従来の畳込み符号の軟判定方法を説明する図、
【図14】従来の畳込み符号の軟判定結果を説明する図、
【図15】従来の畳込み符号を使う無線機の構成を示す図である。
【符号の説明】
1 畳込み符号器
2 符号化部
3 サブシンボルインタリーバ
4 同期検波処理部
5 サブシンボルデインタリーバ
6 軟判定ビタビ復号器
[0001]
BACKGROUND OF THE INVENTION
The present invention relates to an error correction transmission apparatus, and more particularly to an error correction transmission apparatus that performs soft-decision Viterbi decoding by transmitting a convolutional code using a multilevel modulation scheme.
[0002]
[Prior art]
In digital communication, transmission data subjected to error correction coding is converted into transmission symbols, modulated and transmitted. The receiver decodes the error correction code to obtain information data. In various digital communications, convolutional codes that are advantageous for burst errors are used. The Viterbi algorithm is used as a method for decoding the convolutional code. The Viterbi algorithm is a decoding method that efficiently performs maximum likelihood decoding using an iterative structure of a convolutional code. Basically, the bit string that can be taken at each time point on the trellis diagram and the received bit string (or the modulation symbol corresponding to the bit string) are compared, and the path (maximum likelihood path) with the largest likelihood function is selected. The transmission signal is estimated without performing a brute force method with all of the code sequence patterns existing in (1).
[0003]
Decoding methods using the Viterbi algorithm include hard decision and soft decision. Hard decision decoding uses a Hamming distance as a likelihood function, and is a method of determining a path after determining a received signal as a binary value. On the other hand, soft decision decoding uses the Euclidean distance as a likelihood function, and is a method for determining a path by treating a received signal as an analog value. Since soft decision decoding makes a decision based on the analog value of the received signal, it has higher error correction capability than hard decision decoding. Refer to Non-Patent Document 1 for a decoding method of an error correction code using a conventional soft decision Viterbi algorithm.
[0004]
As a multi-level modulation system with high frequency utilization efficiency, there is a multi-level QAM system (QPSK, 16QAM, 64QAM, etc.) in which code identification points are arranged in a lattice pattern by a linear modulation system, and is used in many systems. In the linear modulation method, it is possible to independently use two channels of a carrier in-phase component (Ich) and a carrier quadrature component (Qch). Therefore, the modulation symbol can be represented by a complex number such as (I + jQ). Here, (I + jQ) is referred to as a modulation symbol (or simply a symbol), and when referring to each of I and Q, it is referred to as a modulation sub-symbol (or simply a sub-symbol).
[0005]
By the way, the soft decision Viterbi algorithm cannot be used unconditionally when the convolutional code is transmitted by the multi-level modulation method. The reason is that the transmission unit (subsymbol) of the multi-level modulation method may be 1 bit or multiple bits, but amplitude information at the time of demodulation can be obtained only in the transmission unit. This is because when the number of bits is 2 bits or more, it is impossible to know amplitude information in 1-bit units.
[0006]
A conventional soft decision Viterbi decoding method will be described with reference to the trellis diagram shown in FIG. Taking the coding rate R = 1/2 and the modulation scheme as QPSK as an example, there are two state transition paths for one step of the encoder. This is the case where the input bit value is 0 and 1. In the Viterbi algorithm, in each case, in order to efficiently compare the transmission sequence and the reception sequence, the transmission symbol corresponding to the branch joining each state at each time point is compared with the reception amplitude, and the Euclidean distance is compared. Is obtained and added to the path metric of the state one point before, and the branch with the smaller value is selected to determine the paths and path metrics for all states (S0 to S15). When attention is paid to one surviving path, the result is as shown in FIG. Here, M is the value of the path memory. Such processing is executed from time point 1 to time point N × R (N is the code length and R is the coding rate). When the convolutional code is terminated to the state 0 by the tail bit, since the last state is S0, the state transition is traced in reverse from the S0 at the time N × R in the direction of the time 0 according to the value of the path memory. When this is done (this is called traceback), a decoded bit string can be obtained.
[0007]
FIG. 15 shows a configuration of a conventional radio device that performs soft-decision Viterbi decoding by transmitting a convolutional code using a multi-level modulation method. Here, since a bit interleaver is arranged immediately after the convolutional encoder on the transmission side, generally, if the modulation method is not 1-bit / sub-symbol QPSK or the like on the reception side, the original arrangement is changed by the sub-symbol deinterleaver. I can't get it back.
[0008]
[Non-Patent Document 1]
Hideki Imai: "Code Theory" (The Institute of Electronics and Communication Engineers, published in 1997) pp.280-312.
[0009]
[Problems to be solved by the invention]
In the conventional error correction transmission system, the soft decision can be applied only when the sub-symbol of multilevel modulation has a 1-bit configuration (1 bit / sub-symbol), and there is a problem that the error correction capability cannot be sufficiently increased. . The reason is as follows.
[0010]
2 for the number of multi-level modulation symbols2q, Sub-symbols I and Q are represented by q bits. Incidentally, q = 1 for 4 values, q = 2 for 16 values, q = 3 for 64 values, and q = 4 for 256 values. On the other hand, the coding rate of the convolutional code is expressed as R = k / n by the number of input sequences k and the number of output sequences n (the number of bits of the code block. Hereinafter, the code block is abbreviated as a code word). . If q is a divisor of n, one codeword can be expressed by an integer number of sub-symbols, so that the probability that a received symbol is a transmission symbol corresponding to each branch for each state transition in one step (conditional probability) (This is called a likelihood function.) However, if q is not a divisor of n, one codeword cannot be expressed by an integer number of subsymbols. Therefore, the conditional probability of each branch for each state transition of one step cannot be defined. Therefore, although hard decision decoding is possible, normal soft decision Viterbi decoding that evaluates the state transition for every k bits of encoder input is impossible.
[0011]
In the case of a convolutional code with a coding rate R = 1/2, if 1 bit / subsymbol QPSK (the same applies to π / 4 shift QPSK) or 2 bits / subsymbol 16QAM, one codeword is an integer. Since it can be expressed by the number of sub-symbols, normal soft decision Viterbi decoding is possible. However, when bit interleaving is performed, in 16QAM, information of one code word is separated into two sub-symbols and can be extracted only in a mixed form with information of other code words. Also, since 64QAM is 3 bits / subsymbol, it is impossible to express one codeword by one subsymbol. In the case of a convolutional code with a coding rate R = 2/3, QPSK and 64QAM can be used, but 16QAM cannot be used. In addition, when bit interleaving is performed, information of a single codeword cannot be extracted with 64QAM. As described above, in the conventional method, only a specific multilevel modulation method (hereinafter referred to as symbol size) can be used for a convolutional code of a specific coding rate, and the optimal multilevel is used. The transmission efficiency cannot be increased by selecting the modulation method.
[0012]
The present invention solves the above-mentioned conventional problem, and enables a soft decision to be made even if a convolutional code having an arbitrary coding rate is transmitted using a multilevel modulation scheme having an arbitrary symbol size, thereby reducing the error rate. The purpose is to lower the transmission efficiency.
[0013]
[Means for Solving the Problems]
In order to solve the above-described problem, according to the present invention, an error correction transmission apparatus includes a coding rate k / n convolutional coding unit that outputs an n-bit codeword for each k-bit information sequence input, Symbol encoding means for assembling symbols consisting of two q-bit sub-symbols from the bit sequence of the codeword output from the multi-code encoding means, sub-symbol interleaving means for interleaving in units of sub-symbols, Transmitting means for orthogonally modulating a carrier wave and transmitting; receiving means for synchronously detecting a received signal to obtain subsymbols and carrier amplitude information in subsymbol units; and subsymbol deinterleaving for deinterleaving subsymbols together with carrier amplitude information And a soft decision Viterbi decoding means for soft decision in units of sub-symbols.
[0014]
With this configuration, soft-decision Viterbi decoding can be performed even if a multilevel modulation scheme of an arbitrary symbol size is selected for a convolutional code of an arbitrary coding rate, so that the error rate is reduced. Transmission efficiency can be increased.
[0015]
Further, the symbol encoding means is provided with means for associating the least common multiple LCM (q, n) of q and n with the processing unit bit number p and corresponding the p-bit code word to the p-bit sub-symbol. The Viterbi decoding means is provided with an evaluation means for calculating a branch metric for each state transition of the convolutional coding means corresponding to code words for p bits. With this configuration, soft decision Viterbi decoding can be performed even when the number of bits of the codeword is not divisible by the number of bits of the subsymbol, so that the error rate can be reduced and the transmission efficiency can be increased.
[0016]
The evaluation means is provided with calculation means for calculating the Euclidean distance between the code word for p bits and the sub-symbol for p bits. With this configuration, soft-decision Viterbi decoding can be performed more precisely than when the Hamming distance is used, so that the error rate can be reduced and the transmission efficiency can be increased.
[0017]
The receiving means is provided with means for multiplying the normalized synchronous detection output by the carrier level at each time point and returning it to the original coordinate system, and the calculating means calculates the branch metric using the square of the Euclidean distance as the logarithmic likelihood. Means were provided. With this configuration, it is possible to accurately perform soft decision Viterbi decoding by removing the influence of thermal noise, thereby reducing the error rate and increasing the transmission efficiency.
[0018]
DETAILED DESCRIPTION OF THE INVENTION
Hereinafter, embodiments of the present invention will be described in detail with reference to FIGS.
[0019]
(Embodiment)
In the embodiment of the present invention, the output of the convolutional encoder is converted into a multi-level modulation symbol, then interleaved in sub-symbol units, orthogonally modulated, transmitted, received, and received subsymbols obtained by synchronous detection A set of values (analog values) and reproduced carrier level information (collectively referred to as “sub-symbol amplitude information”) is deinterleaved in units of sub-symbols, and the number of bits of the code word and the number of sub-symbols The error correction transmission apparatus performs soft-decision Viterbi decoding using amplitude information of sub-symbols by state transition for each of a plurality of codewords, with the least common multiple of the number of bits as the number of processing unit bits.
[0020]
FIG. 1 is a functional block diagram of a transceiver of an error correction transmission apparatus according to an embodiment of the present invention. FIG. 1A is a configuration diagram of a transmitter. FIG.1 (b) is a block diagram of a receiver. In FIG. 1, a convolutional encoder 1 is a circuit that performs convolutional encoding of an information sequence input. The encoding unit 2 is a circuit that collectively converts a plurality of bits into one sub-symbol. The sub symbol interleaver 3 is means for interleaving in units of sub symbols. The synchronous detection processing unit 4 is a circuit that performs synchronous detection by extracting quasi-synchronous detection, A / D conversion, band-limited by an LPF configured by a digital filter, and extracting synchronous timing from sampling data. The sub-symbol deinterleaver 5 is means for rearranging data interleaved in units of sub-symbols in the original order. The soft decision Viterbi decoder 6 is means for performing Viterbi decoding by making a soft decision in units of a plurality of steps of state transition.
[0021]
FIG. 2 is a flowchart for explaining the error correction transmission apparatus according to the embodiment of the present invention in comparison with the conventional example. FIG. 3 is an example of a circuit diagram of the convolutional encoder. FIG. 4 is a trellis diagram showing all state transitions. FIG. 5 is a trellis diagram for explaining a state transition branch metric calculation. FIG. 6 is a diagram illustrating state transition for each of a plurality of codewords focusing on one surviving path. Here, M is the value of the path memory.
[0022]
FIG. 7 is a flowchart showing a demodulation procedure of the error correction transmission system in the embodiment of the present invention. FIG. 8 is a flowchart showing a decoding procedure. FIG. 9 is a flowchart showing a traceback procedure. FIG. 10 is an explanatory diagram of the interleave function. FIG. 11 is an explanatory diagram of a burst format. FIG. 12 is a graph of static characteristics of error correction, a graph of error correction characteristics under flat fading, and a graph of error correction characteristics under multipath fading.
[0023]
The operation of the error correction transmission system in the embodiment of the present invention configured as described above will be described. First, an outline of the operation of the transceiver will be described with reference to FIG. The information sequence input SD [i] is input to the convolutional encoder 1. The output of the convolutional encoder 1 is gray-coded every q bits by the encoding unit 2 and mapped to symbols (I [m], Q [m]) of multilevel modulation. The subsymbol interleaver 3 performs interleaving (I [n], Q [n]) in units of subsymbols. The subsequent operation is the same as that of a normal quadrature modulation transmitter.
[0024]
In the receiver, the received signal is quasi-synchronously detected (I '(t), Q' (t)), and this is sampled and A / D converted at a frequency several times the baud rate frequency (for example, 8 times) and digital low-pass. The sampling data (I ′ (k), Q ′ (k)) output through the filter (LPF) is sent to the synchronous detection processing unit 4. The synchronous detection processing unit 4 detects a synchronous symbol from the transmitted sampling data, extracts a symbol timing, and regenerates a carrier wave using a pilot symbol defined in a burst format (cx (n)) Then, the absolute value (W (n)) is calculated, and synchronous detection (I [n], Q [n]) is performed by the synchronous detection unit using the regenerated carrier wave. The sub-symbol information (I [n], W [n], Q [n], W [n]) obtained here is deinterleaved by the sub-symbol deinterleaver 5 (I [m], W [m] , Q [m], W [m]). Soft decision Viterbi decoder 6 performs soft decision in units of sub-symbols.
[0025]
The error correction transmission apparatus according to the embodiment of the present invention is generalized as follows. An n-bit code word is output for each k-bit information sequence input by a convolutional encoding means with a coding rate k / n. A sub-symbol sequence is generated by dividing the bit sequence of the codeword output from the convolutional coding means into q bits. Interleave in units of subsymbols. Two interleaved sub-symbols are taken out as Ich and Qch, and the carrier wave is orthogonally modulated and transmitted. On the receiving side, the received signal is synchronously detected to obtain sub-symbols (Ich, Qch) and sub-symbol unit carrier amplitude information (W). The sub-symbol is deinterleaved together with the carrier amplitude information. Let the least common multiple LCM (q, n) of q and n be the number of processing unit bits p, and code words for p bits correspond to sub-symbols for p bits. For each state transition of the convolutional encoding means corresponding to the p-bit codeword, a value obtained by multiplying the Euclidean distance between the p-bit codeword and the p-bit sub-symbol by the carrier amplitude and squared. A branch metric is calculated to make a soft decision.
[0026]
When performing soft decision decoding, when the modulation method is 16QAM (2 bits / subsymbol), codes such as coding rate R = k / 3 (k = 1 to 2), k / 5 (k = 1 to 4) are used. When the modulation method is 64QAM (3 bits / subsymbol), codes such as coding rate R = 1/2 and k / 4 (k = 1 to 3) have no state transition for each step (time point). It becomes possible. 3 steps (LMC (2,3) = 6 bits) when R = k / 3 in 16QAM, 2 steps (LMC (2,5) = 10 bits) when R = k / 5 in 16QAM, 64QAM 3 steps (LMC (3,2) = 6 bits) when R = 1/2, and every 3 steps (where LMC (4,3) = 12 bits) when R = k / 4 with 64QAM Transition is required. In this way, the method of determining the path by calculating the branch metric and path metric based on the state transition for each of the plurality of steps is referred to as “modified Viterbi decoding” in order to distinguish it from normal Viterbi decoding. .
[0027]
With reference to FIG. 2, the present invention will be described in comparison with a conventional example in the case of transmitting a code having a generator polynomial degree of 5, a coding rate R = 1/2, and an information point of 100 bits by 64QAM. The processing up to the point where the information sequence input (100 bits) is convolutionally encoded (210 bits) is the same as the conventional example. Conventionally, bit interleaving is followed by conversion to multilevel modulation symbols (35 symbols). On the other hand, in the present invention, after conversion to multi-level modulation symbols (70 subsymbols), interleaving (70 subsymbols) is performed in units of subsymbols. After that, sub-symbols are mapped to the burst signal (70 sub-symbols), orthogonally modulated and transmitted. On the receiving side of the conventional example, data detection is performed by synchronous detection (35 symbols), gray code is decoded (210 bits), deinterleaved in bit units (210 bits), and then hard decision Viterbi decoding (100 bits) )I do. On the other hand, in the present invention, data subsymbols are extracted from the quasi-synchronous detection output (70 subsymbols), deinterleaved in units of subsymbols (70 subsymbols), and then soft decision Viterbi decoding (100 bits) is performed.
[0028]
Next, with reference to FIG. 4 and FIG. 5, in the processing block of soft decision Viterbi decoding in FIG. An example will be described in which a code having a constraint length of 5 and a number of states of 16) and a coding rate R = 1/2 is transmitted by 64QAM. As described above, when the modulation sub-symbol has a 3-bit configuration and the coding rate R = 1/2, the state transition needs to be performed every three steps in order to execute the soft decision. The state transition every three steps is as shown in FIG. 4 because there are eight paths from the state at time t-3 to the state at time t in each state. The “encoder state” shown on the left side in FIG. 4 is the state (shift register state) displayed on the left side as the MSB regardless of the time point. In addition, “input of encoder” shown on the right side is a bit string input to the encoder when joining the state, and the left side is displayed as MSB (bits input earlier in time). .
[0029]
Among these, FIG. 5 is an explanatory diagram focusing on the state S1 at time t. The state before 3 time points in the path where the 3 bits input to the encoder between a certain time point t-3 and t-1 are “xxx” and join to “yxxx” at time point t is “000y”, “ There are eight types of 001y, “010y”, “011y”, “100y”, “101y”, “110y”, and “111y”. Here, the left side is represented as the upper side (MSB) in accordance with the notation of the shift register (shifted to the left) in the circuit diagram of the encoder of FIG. Here, the upper 3 bits in which there are 8 patterns are portions that are shifted and disappear when 3 bits are input to the encoder. The branch number i is associated with a decimal representation of the upper 3 bits of the state of the shift register three times before. Therefore, focusing on the state S1, the state before the three time points flows into the state S1 when the lower 1 bit “y” is “0” and the encoder input “xxx” is “001”. States S0 (i = 0), S2 (i = 1), S4 (i = 2), S6 (i = 3), S8 (i = 4), S10 (i = 5), S12 (i = 6), There are 8 types of S14 (i = 7).
[0030]
In FIG. 5, symbols λ (S, t) and λ (S, t−3) represent path metrics of state S at time t and time t−1, respectively. Taking the above-described encoding method and modulation method as an example, state transition is performed every three steps. That is, when the time number t is a multiple of 3, the received first modulation sub-symbol z (2n), its regenerated carrier level c (2n), and the received second modulation are received from the sub-symbol deinterleaver in FIG. Subsymbol z (2n + 1) and its recovered carrier level c (2n + 1) are given. In each state S, the immediately preceding state number is obtained for each branch number i using the table F0 (i, S), and the first modulation sub-symbol corresponding to the branch i is obtained using the table F1 (i, S). The sub symbol is obtained from the table F2 (i, S). The following minimum value is obtained using these values and the reception information acquired at this time.
λ (S, t) = min {(| F1 (i, S) −z (2n) | × | cx (2n) |)2
+ (| F2 (i, S) −z (2n + 1) | × | cx (2n + 1) |)2+ Λ (F0 (i, S), t-3)} (i = 0 to 7)
Therefore, the minimum value is stored as the path metric of the state S, and the branch number i giving the minimum value is stored in the path memory M (S, n). Here, the variable n has a relationship of the time point number t and 3n = t.
[0031]
The tables F0 (i, S), F1 (i, S), and F2 (i, S) used here are given by the following method. First, the following function is defined where i is a branch number (0 to 7), S is a state number (0 to 15), and b is a bit number (0 to 6).
d (i, S, b) = mod (int ((16i + S) / 2b), 2)
Here, int (x) is an integer part of x, and mod (x, 2) is a remainder obtained by dividing x by 2. d (i, S, b) is a function for calculating a bit string input to the encoder up to this point when the state number is S and the branch number is i. The LSB (D1 ) Is bit 0 (b = 0), and the MSB (D4) of the shift register of the encoder three times before is set to bit 6 (b = 6).
[0032]
When the function d (i, S, b) is used, the state number F0 (i, S) three times before is given by the following equation.
F0 (B, S) = d (i, S, 6) × 8 + d (i, S, 5) × 4 + d (i, S, 4) × 2 + d (i, S, 3)
Next, the first modulation sub-symbol value F1 (B, S) is given by the following equation.
F1 (i, S) = (1-2 × y0) × {(1-2 × y1) × (3-2 × y2) +4}
However,
y0 = mod (Σg1 (v) d (i, S, v + 2), 2) (total is v = 0 ~ 4)
y1 = mod (Σg2 (v) d (i, S, v + 2), 2) (total is v = 0-4)
y2 = mod (Σg1 (v) d (i, S, v + 1), 2) (total is v = 0-4)
F1 (i, S) is a 3-bit gray code (± 1, ± 3, ± 5, ± 7) of y0, y1, y2.
[0033]
The second modulation sub-symbol value F2 (B, S) is given by
F2 (i, S) = (1-2 × y3) × {(1-2 × y4) × (3-2 × y5) +4}
However,
y3 = mod (Σg2 (v) d (i, S, v + 1), 2) (total is v = 0-4)
y4 = mod (Σg1 (v) d (i, S, v), 2) (total is v = 0-4)
y5 = mod (Σg2 (v) d (i, S, v), 2) (total is v = 0-4)
F2 (i, S) is a 3-bit gray code (± 1, ± 3, ± 5, ± 7) of y3, y4, y5.
y0 and y1 are codewords sent between 3 and 2 time points, y2 and y3 are codewords sent between 2 and 1 time points, y4 and y5 are from 1 time point to the current time point Codewords sent during G1 (v) and g2 (v) are the coefficients of the convolutional code generator polynomial.
g1 (4) = 1, g1 (3) = 1, g1 (2) = 0, g1 (1) = 0, g1 (0) = 1
g2 (4) = 1, g2 (3) = 0, g2 (2) = 1, g2 (1) = 1, g2 (0) = 1
It is.
[0034]
The above is the basic algorithm of modified Viterbi decoding. Next, a decoding operation using this algorithm will be described with reference to the flowcharts of FIGS. 7, 8, and 9, taking the burst format of FIG. 11 as an example. Multi-level modulation synchronous detection will be described by taking as an example the case where a signal is transmitted in a general burst format as shown in FIG. Normally, in a burst signal of a multilevel modulation system, data symbols are arranged following a series of synchronization symbols after a ramp time of transmission rise, and pilot symbols are inserted therein at regular intervals. Similar to the synchronization symbol, the pilot symbol is a symbol having a known value between transmission and reception. In the present embodiment, as an example of 64QAM, pilot symbol values are uniformly set to obtain a good S / N.
I + jQ = 7 + 7j
It is said.
[0035]
In the demodulation processing procedure of FIG. 7 (the operation of the synchronous detection processing unit 4 of FIG. 1B), sampling data (I ′ (k), Q ′ (k)) output from the A / D conversion unit / LPF unit. Among them, a “symbol synchronization acquisition process” block detects a synchronization symbol, extracts a symbol timing, and a “received symbol extraction” block extracts a pilot symbol and a data symbol following the synchronization symbol. The received symbol value rx (t) obtained here is a complex number. The variable t represents the absolute symbol number after the synchronization symbol, the symbol number of the first pilot symbol is 0, and the symbol number of the last pilot symbol is K + p0-1. K is the number of data symbols, and p0 is the number of pilot symbols.
[0036]
When rx (t) is extracted, carrier recovery is performed sequentially using the following equation, assuming that the data symbol number is k, the pilot symbol number is ≡, and the relative number of the data symbol between the two pilot symbols is h.
cx (k) = [{rx (b1) -rx (b0)} / b2 × h + rx (b0)] / [7 + 7j]
cx (k) is a complex number representing a regenerated carrier wave, and the kth data symbol is linearly interpolated with pilot symbols positioned before and after it. b0 is a pilot symbol absolute symbol number positioned in front, b1 is a pilot symbol absolute symbol number positioned later, and 7 + 7j is a value of a pilot symbol defined in advance. In linear modulation, a modulated wave is obtained by multiplying a carrier wave by a modulation component (I + jQ). Therefore, a data symbol value rx (b0 + h) obtained by quasi-synchronous detection is divided by a reproduced carrier wave cx (k). Thus, synchronous detection can be performed. cx (k) and rx (b0 + h) are complex numbers, and the amplitude and the phase are corrected simultaneously by dividing by cx (k). The real part of the complex number obtained here is the component of Ich, and the imaginary part is the component of Qch. As a result, Ich is stored as an even-numbered subsymbol and Qch is stored as an odd-numbered subsymbol according to the following equation.
y (2k) = Re [rx (b0 + h) / cx (k)] ... Ich
y (2k + 1) = Im [rx (b0 + h) / cx (k)] ... Qch
[0037]
Subsequently, a sub-symbol / deinterleaver deinterleaves a pair of sub-symbols and the absolute value of a reproduced carrier wave accompanying the sub-symbol using an interleave function ilv (k) function. Here, the variable k is a subsymbol number. In normal demodulation, the complex number rx (b0 + h) / cx (k) (= y (2k) + j · y (2k + 1)) obtained here is the signal at the closest symbol point in the signal space. It is determined that it has been transmitted, and a corresponding bit string is output. Here, in order to perform a soft decision, synchronous detection output (FIG. 1 (FIG. In b), it corresponds to I [n], Q [n].
[0038]
In the decoding processing procedure of FIG. 8, modified Viterbi decoding by soft decision is performed based on the received sub-symbol value z (•) and the absolute value w (•) of the reproduced carrier wave obtained in the demodulation processing procedure. Let PM (S) be the path metric value in state S, and M (S, n) be the path memory value in state S at time 3n. As initialization processing, 0 is stored in the path memory M (S, n) and path metric PM (0), and an appropriately large numerical value (2 15 here) is stored in PM (S) other than the state 0. This is a measure for preventing a branch that does not exist in the initial state transition from being selected. Here, the state number S is 0 to 15, and the state transition number n is 0 to K-1.
[0039]
The reception sub-symbols corresponding to the time points t = 3n, 3n + 1, and 3n + 2 and the absolute values of the regenerated carrier waves are given by the following array variables already stored in the demodulation processing procedure.
Receive sub-symbol: z (2n), z (2n + 1)
Absolute value of reproduced carrier wave: w (2n), w (2n + 1)
Therefore, for each state transition number n, the branch metric bm and the path metric pm are calculated by the following equations while the branch number i is changed from 0 to 7 for the state S from 0 to 15.
bm = {| F1 (i, S) -z (2n) | × w (2n)}2+ {| F2 (i, S) -z (2n + 1) | × w (2n)}2・ ・ ・ ・ ・ ・ Formula 1
pm = bm + PM (F0 (i, S))
The branch number i having the smallest path metric in the state S is obtained by successive comparison, and the path metric value at this time is temporarily stored in the array variable TPM (S) and the path memory M (S, n) is updated. . When this process is completed for all the states S, the path metric PM (S) is updated to the value of TPM (S). This process is sequentially executed from the value n of 0 to K-1.
[0040]
In the traceback process of FIG. 9, the path memory M (S, n) obtained by the decoding process procedure is used to reversely trace state transitions (this is called traceback), thereby estimating the encoder. An input sequence can be obtained. In the present embodiment, the convolutional code is terminated to state 0 by the tail bit. Therefore, it is assumed that the traceback is performed starting from the state 0 of the path memory and the state transition number K-1. By substituting the initial value M (0, K-1) for the array variable TB (n), where n is K-1 and S is 0, and successively calculating by the following equation while decrementing n: Decoding is complete.
S = F0 (TB (n + 1), S)
TB (n) = M (S, n)
RD (3n) = mod (int (TB (n) / 4), 2)
RD (3n + 1) = mod (int (TB (n) / 2), 2)
RD (3n + 2) = mod (TB (n), 2)
RD (·) is a decoded bit string obtained by soft decision modified Viterbi decoding. Further, F0 (i, S) is a function (table) indicating the state three points before the time corresponding to the branch number i of the state S described above. The above is the description of the decoding procedure by the soft decision modified Viterbi decoding with reference to FIG. 7, FIG. 8, and FIG.
[0041]
The reason why the branch metric calculation method in the decoding procedure described above is not simply the square of the Euclidean distance as shown in Equation 1 but is multiplied by the square of the absolute value of the carrier wave will be described. The normal symbol point of the transmitted data symbol is represented by sx + j · sy, the quasi-synchronous detection output of the data symbol is represented by rx + j · ry, and the recovered carrier at that time is represented by a complex number such as cx + j · cy Then, the Euclidean distances Di and Dq for each component between the normal symbol point and the data symbol point after synchronous detection are
Di = Re {(sx + j ・ sy) − (rx + j ・ ry) / (cx + j ・ cy)}
Dq = Im {(sx + j ・ sy) − (rx + j ・ ry) / (cx + j ・ cy)}
Given in.
[0042]
On the other hand, the thermal noise added to the data symbol during quasi-synchronous detection is represented by nx + j · ny. In the case of thermal noise, it is known that the in-phase component nx and the quadrature component ny follow a normal distribution N (0, σ) independent of each other. (The average value of thermal noise power is 2σ2.) When the line amplitude fluctuation is A (times) and the phase fluctuation is θ (rad), the quasi-synchronous detection output rx + j · ry is given by .
rx + j ・ ry = (sx + j ・ sy) ・ A ・ exp (j ・ θ) + nx + j ・ ny
Therefore, if the recovered carrier cx + j · cy is ideal,
cx + j ・ cy = A ・ exp (j ・ θ)
So,
(sx + j ・ sy) − (rx + j ・ ry) / (cx + j ・ cy)
= (Sx + j ・ sy) − (sx + j ・ sy) − (nx + j ・ ny) / (cx + j ・ cy)
= − (Nx + j ・ ny) / (cx + j ・ cy)
The relationship is established. Therefore, the aforementioned Euclidean distance is
Di = Re {(nx + j ・ ny) / (cx + j ・ cy)}
Dq = Im {(nx + j ・ ny) / (cx + j ・ cy)}
Can be rewritten.
[0043]
Next, when the Euclidean distance is multiplied by the absolute value (amplitude) of the carrier wave, the following equation is obtained.
Di '= Di · | cx + j · cy | = Re {(nx + j · ny) exp (−j · θ)}
Dq '= Dq · | cx + j · cy | = Im {(nx + j · ny) exp (−j · θ)}
As described above, since the in-phase component and the quadrature component of thermal noise are uncorrelated, the distribution of Di ′ and Dq ′ also follows the normal distribution N (0, σ). Denoting d as representative of Di ′ and Dq ′, the logarithm of the probability density function p (d) (hereinafter abbreviated as log likelihood) is
−d2/ (2σ2) −1/2 ・ ln (2π) −ln (σ)
It becomes. From the above consideration, when calculating a branch metric, not only the square value of the Euclidean distance Di or Dq of the sub-symbol value assumed for each branch and the sub-symbol value output for synchronous detection is calculated, It can be seen that by multiplying the square of the absolute value | cx + j · cy |, it is possible to directly obtain the log likelihood for thermal noise.
[0044]
Note that the constant term −1 / 2 · ln (2π) −ln (σ) and the coefficient 1 / (2σ2) Is common to the time, state, and branch, and can be omitted because it is canceled in the comparison operation. Further, in the comparison operation, the one with the larger likelihood is selected. At this time, the negative number of the log likelihood − (− d2) = d2When using, the smaller value should be selected. On the other hand, when evaluating only by the Euclidean distance, when there is fading fluctuation or the like, the amplification degree differs at each time point, so the standard deviation of the thermal noise added to the synchronous detection output is different. If the comparison is made only with the branch metric, it is canceled out. However, since the Viterbi algorithm performs the comparison between the branches with the value added to the path metric value at the previous time point, the correct likelihood function is not given.
[0045]
The interleaving method will be described with reference to FIG. Interleaving is a method for converting a burst error into a random error. In general interleaving, assuming that the number of data is N (= m × n), the data is divided into n rows and arranged in m rows and n columns, and the interval between adjacent data is determined by reading this data column by column. Expanding. At this time, if m = n, an interval from the next adjacent data is also ensured at the same time, but if one of m and n is extremely small, the burst error cannot be converted into a random error. In the example of the burst signal format of FIG. 11, the number of data symbols is 48, that is, the number of subsymbols is 96. Therefore, in order to make this a matrix as described above, 6 × 16 or 8 × 12 is generally used. Is. As a method of interleaving this as close to a square matrix as possible, in this embodiment, an incomplete matrix as shown in Fig. 10 (10 × 10 matrix with 4 missing 10th row) is created. Taking a way to say skip. Here, when the number of data is N, m and n are the smallest integers greater than or equal to the square root value, and L is m × n−N. That is, since N is 96, the minimum integer is equal to or greater than the square root of 9.797, so that m = n = 10 and L = 4.
[0046]
This interleaving is given by the function ilv (k) in FIG. Here, k is the data reading order number, and ilv (k) is the corresponding data writing order number. When the matrix is a complete part (k = 0 to 59), the interleave function is given by
ilv (k) = mod (k, m) × n + int (k / m)
On the other hand, the interleaving function of the portion (k = 60 to 95) where the latter half of the last row is missing is given by the following equation.
ilv (k) = mod (k−m (n−L), m−1) × n + int ((k−m (n−L)) / (m−1)) + n−L
Here, mod (x, y) represents a remainder obtained by dividing x by y, and int (x / y) represents an integer part of a value obtained by dividing x by y.
[0047]
The effect of soft decision is shown in the graph of FIG. In these graphs, when there is no fading fluctuation (static characteristics), when there is fading fluctuation (flat fading), and when there is fading fluctuation in the multipath of the preceding wave and one delayed wave (multipath fading), It is the result of calculating the bit error rate before correction, after hard decision correction, and after soft decision correction by simulation. It can be seen that the bit error rate is lower in the soft decision than in the hard decision.
[0048]
As described above, in the embodiment of the present invention, the error correction transmission method is such that the output of the convolutional encoder is converted into multi-level modulation symbols, and then interleaved in units of sub-symbols, orthogonally modulated and transmitted. The received data is deinterleaved with the amplitude data in sub-symbol units, and the state transition between multiple time points corresponding to multiple code words is made with the least common multiple of the number of bits of the code word and the number of sub-symbols as the unit of processing In summary, since soft decision Viterbi decoding (modified Viterbi decoding is performed) using the amplitude information of the sub-symbol is made, soft decision can be made even if any multi-level modulation scheme is selected for any code. Therefore, it is possible to increase the transmission efficiency by reducing the error rate.
[0049]
However, the modified Viterbi decoding has a problem that the calculation amount is larger than that of the Viterbi decoding. If the coding efficiency is k / n, the sub-symbol size of multilevel modulation is q bits / sub-symbol, and the least common multiple LCM (n, q) of n and q is represented by a × n, a is 1 in the modified Viterbi decoding. Gives the number of times of state transition. The metric calculation amount (number of times) in one state transition of modified Viterbi decoding is Bm × S, where Bm is the number of branches and S is the number of states. Since the branch number Bm is a transition between time points a, 2k aIt becomes a piece. On the other hand, the metric calculation amount between time points a in normal Viterbi decoding is a × B × S, but the number of branches at this time is 2kIt is. From the above, the metric calculation amount per unit time of modified Viterbi decoding is 2 for Viterbi decoding.k (a-1)It turns out that it becomes / a times. Note that a = 1 represents normal Viterbi decoding.
[0050]
Incidentally, when k = 1, the calculation amount does not increase when a = 2 when a = 2, but is 1.333 times when a = 3 (value of this embodiment), twice when a = 4, and 3.2 times when a = 5. Increases rapidly. Further, if k = 2, it is doubled when a = 2, and when k = 2, it is four times when a = 2. Therefore, when k = 1, a is 4 or less, and when k = 2, if a is 2, soft decision decoding can be performed with a calculation amount less than twice that of normal Viterbi decoding. If it exceeds, the amount of calculation will increase rapidly. In introducing modified Viterbi decoding, it is desirable to select a modulation method (value of q), a coding method (values of k and n), and an arithmetic element (DSP) in consideration of such characteristics. .
[0051]
【The invention's effect】
As is apparent from the above description, according to the present invention, the error correction transmission apparatus comprises a coding rate k / n convolutional coding means for outputting an n-bit code word for each k-bit information sequence input, Symbol encoding means for assembling symbols consisting of two q-bit sub-symbols from the bit sequence of the codeword output from the multi-code encoding means, sub-symbol interleaving means for interleaving in units of sub-symbols, and interleaved sub-symbols Transmitting means for orthogonally modulating a carrier wave and transmitting; receiving means for synchronously detecting a received signal to obtain subsymbols and carrier amplitude information in subsymbol units; and subsymbol deinterleaving for deinterleaving subsymbols together with carrier amplitude information And soft decision Viterbi decoding means for soft decision in units of sub-symbols. So by selecting an optimal combination of symbols of the coding rate and the multi-level modulation of convolutional codes can soft-decision Viterbi decoding, there is an advantage that it is possible to reduce the transmission error rate to the minimum.
[Brief description of the drawings]
FIG. 1 is a functional block diagram of a transceiver of an error correction transmission apparatus according to an embodiment of the present invention;
FIG. 2 is a flowchart for explaining an error correction transmission apparatus according to an embodiment of the present invention in comparison with a conventional example;
FIG. 3 is a diagram showing a configuration of an encoder in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 4 is a diagram showing all the state transitions of the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 5 is a diagram illustrating a state of calculating a branch metric of state transition of the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 6 is a diagram showing a result of calculating a state transition in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 7 is a flowchart showing a demodulation procedure in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 8 is a flowchart showing a decoding procedure in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 9 is a flowchart showing a traceback procedure in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 10 is an explanatory diagram of an interleave function used in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 11 is an explanatory diagram of a burst format in the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 12 is a graph of error correction characteristics of the error correction transmission apparatus according to the embodiment of the present invention;
FIG. 13 is a diagram for explaining a conventional convolutional code soft decision method;
FIG. 14 is a diagram for explaining a soft decision result of a conventional convolutional code;
FIG. 15 is a diagram illustrating a configuration of a radio using a conventional convolutional code.
[Explanation of symbols]
1 Convolutional encoder
2 Encoding unit
3 Sub-symbol interleaver
4 Synchronous detection processing section
5 Sub symbol deinterleaver
6 Soft decision Viterbi decoder

Claims (5)

kビットの情報系列入力ごとにnビットの符号語を出力する符号化率k/nの畳込み符号化手段と、前記畳込み符号化手段から出力された符号語のビット系列からqビットのサブシンボル2つからなるシンボルを組み立てるシンボル符号化手段と、前記サブシンボルを単位としてインタリーブするサブシンボルインタリーブ手段と、インタリーブしたサブシンボルで搬送波を直交変調して送信する送信手段と、受信信号を同期検波してサブシンボルとサブシンボル単位の搬送波振幅情報とを得る受信手段と、前記搬送波振幅情報とともにサブシンボルをデインタリーブするサブシンボルデインタリーブ手段と、サブシンボル単位で軟判定する軟判定ビタビ復号手段とを具備し、前記シンボル符号化手段に、qとnの最小公倍数 LCM( , ) を処理単位ビット数pとして、pビット分の複数の符号語をpビット分の複数のサブシンボルに対応させる手段を設け、前記軟判定ビタビ復号手段に、pビット分の複数の符号語に対応する前記畳込み符号化手段の状態遷移ごとにブランチメトリックを計算する評価手段を設けたことを特徴とする誤り訂正伝送装置。A convolutional coding means of coding rate k / n that outputs an n-bit codeword for each input of k-bit information series, and a q-bit sub-code from the bit sequence of the codeword output from the convolutional coding means Symbol encoding means for assembling symbols consisting of two symbols, sub-symbol interleaving means for interleaving the sub-symbol as a unit, transmitting means for orthogonally modulating a carrier wave with the interleaved sub-symbol and transmitting, and synchronous detection of the received signal Receiving means for obtaining sub-symbols and carrier amplitude information in units of sub-symbols, sub-symbol de-interleaving means for de-interleaving the sub-symbols together with the carrier amplitude information, and soft-decision Viterbi decoding means for soft-decision in units of sub-symbols The symbol encoding means processes the least common multiple LCM ( q , n ) of q and n. A unit for associating a plurality of code words for p bits with a plurality of sub-symbols for p bits as the number of logical unit bits p is provided, and the soft decision Viterbi decoding unit corresponds to a plurality of code words for p bits. An error correction transmission apparatus comprising: an evaluation unit that calculates a branch metric for each state transition of the convolutional encoding unit. 前記評価手段に、pビット分の符号語とpビット分のサブシンボルとの間のユークリッド距離の2乗をブランチメトリックとして計算する計算手段を設けたことを特徴とする請求項1記載の誤り訂正伝送装置。 2. The error correction according to claim 1 , wherein said evaluation means includes calculation means for calculating a square of Euclidean distance between a code word for p bits and a sub-symbol for p bits as a branch metric. Transmission equipment. 前記計算手段に、ユークリッド距離と搬送波振幅との積の2乗をブランチメトリックとして計算する手段を設けたことを特徴とする請求項2記載の誤り訂正伝送装置。3. The error correction transmission apparatus according to claim 2 , wherein said calculating means is provided with means for calculating a square of a product of Euclidean distance and carrier wave amplitude as a branch metric . 入力情報系列のkビットを符号化率k/nの畳込み符号化手段に入力するごとにnビットの符号語を出力し、サブシンボルのビット数qと符号語のビット数nの最小公倍数Each time k bits of the input information sequence are input to the convolutional encoding means having the coding rate k / n, an n-bit code word is output, and the least common multiple of the number of sub-symbol bits q and the number of code word bits n LCM(LCM ( q ,, n )) を処理単位ビット数pとして、pビット分の複数の符号語をpビット分の複数のサブシンボルに対応させ、前記符号語のビット系列からqビットのサブシンボル2つからなるシンボルを組み立て、前記シンボルの系列を、前記サブシンボルを単位としてインタリーブし、インタリーブしたサブシンボルで搬送波を直交変調して送信し、受信信号を同期検波してサブシンボルとサブシンボル単位の搬送波振幅情報とを得て、前記搬送波振幅情報とともにサブシンボルをデインタリーブし、pビット分の複数の符号語に対応する前記畳込み符号化手段の状態遷移ごとに、pビット分の複数の符号語とpビット分の複数のサブシンボルとの間のユークリッド距離の2乗をブランチメトリックとして計算して軟判定することを特徴とする誤り訂正伝送方法。Is a processing unit bit number p, a plurality of code words for p bits are associated with a plurality of sub-symbols for p bits, and a symbol consisting of two sub-symbols of q bits is assembled from the bit sequence of the code word, A sequence of symbols is interleaved in units of the sub-symbols, a carrier wave is orthogonally modulated with the interleaved sub-symbols and transmitted, and a received signal is synchronously detected to obtain sub-symbols and sub-symbol unit carrier amplitude information A sub-symbol is deinterleaved together with the carrier wave amplitude information, and for each state transition of the convolutional encoding means corresponding to a plurality of code words for p bits, a plurality of code words for p bits and a plurality of code bits for p bits. Error correction transmission characterized by soft decision by calculating the square of Euclidean distance between sub-symbols as branch metric Law. ユークリッド距離と搬送波振幅との積の2乗をブランチメトリックとして計算することを特徴とする請求項5記載の誤り訂正伝送方法。 6. The error correction transmission method according to claim 5, wherein the square of the product of the Euclidean distance and the carrier amplitude is calculated as a branch metric .
JP2003077083A 2003-03-20 2003-03-20 Error correction transmission device Expired - Fee Related JP4025226B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2003077083A JP4025226B2 (en) 2003-03-20 2003-03-20 Error correction transmission device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2003077083A JP4025226B2 (en) 2003-03-20 2003-03-20 Error correction transmission device

Publications (2)

Publication Number Publication Date
JP2004289353A JP2004289353A (en) 2004-10-14
JP4025226B2 true JP4025226B2 (en) 2007-12-19

Family

ID=33291924

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2003077083A Expired - Fee Related JP4025226B2 (en) 2003-03-20 2003-03-20 Error correction transmission device

Country Status (1)

Country Link
JP (1) JP4025226B2 (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4904963B2 (en) 2006-07-21 2012-03-28 富士通株式会社 Communication system, communication method, transmitter and receiver
JP5586504B2 (en) * 2011-02-28 2014-09-10 三菱電機株式会社 Decoding device
EP3910800B1 (en) * 2019-02-22 2023-10-04 Mitsubishi Electric Corporation Wireless communication system, wireless communication device, transmitting device, and receiving device

Also Published As

Publication number Publication date
JP2004289353A (en) 2004-10-14

Similar Documents

Publication Publication Date Title
JP3822249B2 (en) Method and means for detecting communication signals with non-uniform error protection
US7237183B2 (en) Parallel decoding of a BCH encoded signal
US6654926B1 (en) Soft decision maximum likelihood encoder and decoder
US6910170B2 (en) Pre-decoder for a turbo decoder, for recovering punctured parity symbols, and a method for recovering a turbo code
JP3987274B2 (en) Multi-level modulation transmission device
US6543023B2 (en) Parity-check coding for efficient processing of decoder error events in data storage, communication and other systems
JP3759964B2 (en) Multi-level coding using time diversity
CN101247203B (en) Apparatus and method for determining a detected punctured position in punctured convolutional codes
US7224743B2 (en) Efficient decoding of trellis coded modulation waveforms
JPH06104942A (en) Data transmission system
US8009773B1 (en) Low complexity implementation of a Viterbi decoder with near optimal performance
KR20030036660A (en) Method and apparatus for a complementary encoder/decoder
US5822340A (en) Method for decoding data signals using fixed-length decision window
JP4025226B2 (en) Error correction transmission device
CA2153956A1 (en) Transmission system and apparatus therefor
JP2004023691A (en) Error correction encoding/decoding method, transmitting device, and receiving device
WO2003017500A1 (en) Coded modulation scheme for a wireless communication system and methods thereof
JP2010130271A (en) Decoder and decoding method
EP2406908B1 (en) Mimo communication method and devices
JP2710696B2 (en) Soft-decision Viterbi decoding method
CN1602589B (en) TURBO decoding method and apparatus for wireless communications
JPH08265175A (en) Coder, decoder and transmission system
James et al. Multiple error correction using non-binary Redundant Residue Number System
US7123668B2 (en) Simple detector and method for QPSK symbols
KR102611828B1 (en) Reed-solomon decoder for error correction

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20050317

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20070123

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20070322

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20071004

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Free format text: PAYMENT UNTIL: 20101012

Year of fee payment: 3

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

Free format text: PAYMENT UNTIL: 20111012

Year of fee payment: 4

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

Free format text: PAYMENT UNTIL: 20121012

Year of fee payment: 5

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

Free format text: PAYMENT UNTIL: 20131012

Year of fee payment: 6

LAPS Cancellation because of no payment of annual fees