KR100390416B1 - 터보 디코딩 방법 - Google Patents
터보 디코딩 방법 Download PDFInfo
- Publication number
- KR100390416B1 KR100390416B1 KR10-2000-0060746A KR20000060746A KR100390416B1 KR 100390416 B1 KR100390416 B1 KR 100390416B1 KR 20000060746 A KR20000060746 A KR 20000060746A KR 100390416 B1 KR100390416 B1 KR 100390416B1
- Authority
- KR
- South Korea
- Prior art keywords
- processing
- decoding
- result
- reverse
- learning
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, 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/37—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
- H03M13/39—Sequence estimation, i.e. using statistical methods for the reconstruction of the original codes
- H03M13/3905—Maximum a posteriori probability [MAP] decoding or approximations thereof based on trellis or lattice decoding, e.g. forward-backward algorithm, log-MAP decoding, max-log-MAP decoding
- H03M13/3933—Decoding in probability domain
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, 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/29—Coding, 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
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, 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/29—Coding, 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/2957—Turbo codes and decoding
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, 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/37—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
- H03M13/39—Sequence estimation, i.e. using statistical methods for the reconstruction of the original codes
- H03M13/3972—Sequence estimation, i.e. using statistical methods for the reconstruction of the original codes using sliding window techniques or parallel windows
Landscapes
- Physics & Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Error Detection And Correction (AREA)
- Detection And Correction Of Errors (AREA)
Abstract
본 발명은 차세대 이동통신에 관한 것으로, 특히 슬라이딩 윈도우 방식을 이용한 터보 코드의 디코딩 방법에 관한 것이다. 이와 같은 본 발명에 따른 터보 디코딩 방법은 수신 시퀀스를 최대 사후(Maximum A Posteriori) 알고리즘을 이용하여 디코딩하는데 있어, 수신 시퀀스를 최대 사후(Maximum A Posteriori) 알고리즘을 이용하여 디코딩하는데 있어, 상기 수신 시퀀스의 일정 길이동안 역방향 프로세싱에 의한 학습(learning)을 수행하고, 상기 수신 시퀀스의 학습 이후에 역방향 프로세싱에 의한 제1 결과값을 계산하고, 이와 동시에 순방향 프로세싱에 의한 제2 결과값을 계산하여, 상기 제1 결과값 이전에 저장된 수신 시퀀스에 대한 역방향 프로세싱에 의한 제3 결과값을 이용하여 디코딩 비트 출력을 결정하여 이루어진다. 따라서, 발명은 역방향 프로세서를 하나만 사용하므로 회로의 크기와 연산량(전력소모)을 줄일 수 있고, 일정한 길이 단위로 수행되어지는 프로세싱의 마지막 윈도우를 채움으로써 트렐리스 터미네이션의 특성을 살려 더 나은 디코딩 능력을 갖는다.
Description
본 발명은 차세대 이동통신에 관한 것으로, 특히 슬라이딩 윈도우 방식을 이용한 터보 코드의 디코딩 방법에 관한 것이다.
알려진 바와 같이 터보 코드는 두 개의 순환 계통적 컨벌루션 부호화기(RSC ; Recursive Systematic Convolutional Encoder)가 내부 인터리버(Interleaver)를 통하여 병렬적으로 연결되어 생성된 부호로써, 차세대 이동 통신 규격에서 고전송율의 데이터를 전송하기 위한 코딩 방식으로 이용되고 있다.
이러한 터보 코드는 생성된 정보 비트열에 대하여 블록 단위로 처리하고 있는데, 특히 큰 정보 비트열을 인코딩하는 경우 컨벌루션 부호에 대하여 매우 우수한 코딩이득을 가지고 있으며, 수신단에서 간단한 성분코드에 대한 디코딩을 반복적으로 행함으로써 매우 우수한 오류 정정 능력을 가지는 것으로 알려져 있다.
최근에는 이동통신 환경 하에서 고속 데이터 전송을 지원할 수 있는 비교적간단한 터보 디코딩 기법이 제안되었는데, 이 구조에서는 입력되는 수신 코드워드가 두 개의 컨벌루션널 디코더를 교대로 통과하도록 하여 그 구조의 복잡도를 상당히 줄였다. 그러나, 반복적으로(iteratively) 컨벌루션 디코더를 통과시키기 위해서는 컨벌루션널 디코더의 출력이 "0" 또는 "1"로 경판정(hard decision)된 값이 아니라 "0"이거나 "1"일 확률의 비에 해당하는 소프트한 값이 요구된다. 이를 위해 정보 비트의 사후(A Posteriori) 확률값을 계산하여, 그 확률값이 최대가 되도록 복호하는 최대 사후(Maximum A Posteriori;이하 MAP이라 약칭함) 디코딩 기법이 제안되었다.
일반적으로 터보 부호의 정보원은 불연속 시간과 한정된 상태를 갖는 "마코프 프로세스(Markov process)"이다. 따라서, 정보원은 이진 격자도로 설명될 수 있다.
이진 격자에서 Sk는 시간 k에서의 부호화기의 메모리 상태를 나타내고 "xk=xk,1,k,xk,n"는 부호율이 1/n인 부호화기의 출력을 나타낸다.(xk={0,1}). 여기서 정보원의 상태 "Sk=m"는 모두 M가지의 상태들을 갖는다.(m=0,1,2,..., M-1) 시간이 k-1에서 k로 천이할 때 터보 부호화기의 입력 비트 dk는 부호화기의 상태 Sk-1를 Sk로 변환시킨다. 정보의 상태 시퀀스 S=(S0,...,ST)는 시간 k=0에서 시작해서 시간 k=T에서 종료된다. 이때 부호화기의 초기 상태인 S0는 제로이다.
상기 터보 부호화기의 출력 시퀀스 x는 BPSK 또는 QPSK로 변조되고, 이산 메모리 채널에서 페이딩을 겪는다. 그러므로, 수신단에서 수신된 시퀀스는 "y=(y1,k,yk,k,yL)"가 된다. 여기서 yk=(yk,1,k,yk,n)이다.
따라서, MAP 알고리즘은 상기 수신된 시퀀스를 이용해서 정보의 상태 천이 사후확률을 추정하기 위한 알고리즘이다. 또한 정보 비트의 사후확률 P(dk=1|y)와 P(dk=0|y)를 계산해야 한다. 그러면, 최종적으로 원하는 LLR(log likelihood ratio) 형태의 복호화기의 출력을 구할 수 있다.
이때, 정보 비트의 상태 천이 사후확률 ""은 다음 수학식 2와 같이 구해진다.
상기 수학식 2에서 yj<k는 처음 시간부터 k-1까지의 수신 시퀀스 yj를 나타내며, yj>k는 시간 k+1부터 마지막 수신 시퀀스까지를 나타낸다.
상기 수학식 2에서 ""는 "α(Sk-1)"로 정의되고, 이로부터"α(Sk)"가 정의되고, 상기 ""는 "β(Sk)"로 정의된다.
최적의 사후 확률을 얻기 위해서는 상기 "β(Sk)"을 구하기에 앞서 일정 길이동안의 기간이 필요하다. 이를 "학습" 기간이라고 하고, 이 학습 기간 이후에 계산되어진 "β(Sk)"가 디코더 출력 비트 결정을 위해 이용된다.
이하 상기 α(Sk)는 알파값, 상기 β(Sk)는 베타값으로 지칭된다.
도 1은 종래 기술에 따른 MAP 디코딩 타이밍도를 나타낸 도면이다.
도 1에서 X축은 시간의 흐름을 나타내며, 각 프로세서가 시간의 흐름에 따라 어느 심볼을 처리하는가를 나타낸 것이다. 순방향 프로세서의 심볼의 번호는 증가하며 역방향 프로세서의 심볼 번호는 감소한다. 그리고, 빗금친 구간에서 역방향 프로세서는 "학습" 중임을 나타낸다. 그리고, 곡선의 화살표는 비트 결정에 필요한 알파, 베타값들의 의존도를 보이고 있다.
도 1을 참고하면, 상기 역방향 프로세서 두 개를 사용하여 제1 역방향 프로세서가 "학습(learning)"을 하는 동안 제2 역방향 프로세서가 디코더의 비트 결정에 필요한 베타값을 계산한다. 즉, 하나의 MAP 디코딩이 시작되면 제1 역방향 프로세서가 2L부터 1L까지 "학습" 과정을 수행한다. 이 동안 제2 역방향 프로세서는 정지 상태로 있다. 여기서 L은 수신된 시퀀스의 노드 길이를 나타낸다.
이후에 제1 역방향 프로세서는 1L부터 0까지의 베타값을 계산하며, 이미 계산되어 저장된 0~IL까지의 알파값을 함께 사용하여 1L부터 0까지의 디코더의 비트를 결정한다. 이 시간동안 제2 역방향 프로세서는 3L부터 2L까지의 심볼을 이용하여 "학습"을 수행한다.
다음 구간에서는 제2 역방향 프로세서가 2L부터 1L까지의 베타값을 계산하여 2L부터 1L까지의 디코더의 비트를 결정한다. 이 동안 제1 역방향 프로세서는 4L부터 3L까지의 심볼을 이용하여 "학습"을 수행한다.
디코더 출력 블록에서 볼 수 있듯이, 비트 결정은 1L부터 0까지, 2L부터 1L까지 순서로 이루어지므로 L만큼씩 출력을 저장했다가 끝에서부터 읽어내는 후입선출(Last In First Out : LIFO) 과정을 거쳐 바른 순서의 결과를 얻게 된다.
[참고문헌]
[1](A.J Viterbi, "An intuitive justification and a simplified implementation of the MAP decoder for convolutional codes" IEEE Journal on Selected Areas in Communications, vol.16, no.2, Feb. 1998.)
이와 같은 종래 기술에서는 거의 모든 심볼에 대해서 역방향 프로세싱을 두 번씩 수행한다. 결과적으로 매번의 MAP 디코딩마다 두 번의 역방향 프로세싱이 필요하게 되므로 연산량이 증가하게 되고, 이는 전력소모를 증가시켜 배터리로 동작하는 무선 이동장비의 사용시간을 줄이는 문제점이 있다.
또한, 연산량을 감소시키기 위하여 하나의 역방향 프로세서만을 사용하게 되는 경우에는 디코딩 타임이 두 배로 증가하는 문제점이 있다.
또한, L길이동안 학습 과정과, 순방향 프로세싱과, 역방향 프로세싱을 수행하게 되면, 터보 코드의 트렐리스 종단(ST=0) 상태에서 완료되는 특성을 충분히 살리지 못해서, 터보 코드의 코딩 이득이 저하되는 문제점도 발생된다.
또한, 상기 결과값을 저장하기 위한 메모리의 크기가 "depth 60*width 56(3GPP WCDMA 터보 부호기 가정)"으로 작긴 하지만 요즘 일반적으로 사용하는 메모리의 깊이(depth)는 이보다 훨씬 커서 많은 메모리를 낭비하게 된다.
따라서, 본 발명의 목적은 이상에서 언급한 종래 기술의 문제점을 감안하여 안출한 것으로서, 하나의 역방향 프로세서를 이용하여 적은 연산량과 작은 메모리를 요구하는 터보 디코딩 방법을 제공하기 위한 것이다.
또한, 본 발명의 다른 목적은 하나의 역방향 프로세서를 이용하여 트렐리스 종단을 최대한 활용하는 터보 디코딩 방법을 제공하기 위한 것이다.
이상과 같은 목적을 달성하기 위한 본 발명의 방법상 특징에 따르면, 수신 시퀀스를 최대 사후(Maximum A Posteriori) 알고리즘을 이용하여 디코딩하는데 있어, 상기 수신 시퀀스의 일정 길이동안 역방향 프로세싱에 의한 학습(learning)을 수행하고, 상기 수신 시퀀스의 학습 이후에 역방향 프로세싱에 의한 제1 결과값을 계산하고, 이와 동시에 순방향 프로세싱에 의한 제2 결과값을 계산하여, 상기 제1 결과값 이전에 저장된 상기 수신 시퀀스에 대한 역방향 프로세싱에 의한 결과값인 제3 결과값을 이용하여 디코딩 비트 출력을 결정한다.
바람직하게, 상기 역방향 또는 순방향 프로세싱 시간이 W이고, 상기 수신 시퀀스 길이를 W로 나눈 나머지가 W0이고, 정수 N에 대하여, 수신 시퀀스의 시간"W0+NW+L"부터 "W0+NW"의 심볼로 역방향 프로세싱에 의해 학습(learning)을 수행하고, 이후에 "W0+NW"부터 "W0+(N-1)W"까지의 심볼로 역방향 프로세싱에 의한 제1 결과값을 저장하고, 이와 동시에 0(N=1) 또는"W0+(N-2)W"(N은 2이상의 정수)부터 "W0+(N-1)W"까지의 심볼로 순방향 프로세싱에 의한 제2 결과값을 계산하여, "W0+(N-1)W"부터 "W0+(N-2)W"까지 계산되어 저장된 제1 결과값과 함께 디코딩 비트 결정을 수행한다.
한편, 상기 N이 0인 경우에, 상기 수신 시퀀스의 시간 "W0+L"부터 "W0"의 심볼로 역방향 프로세싱에 의해 학습(learning)을 수행하고, 이후에 "W0"부터 0까지의 심볼로 역방향 프로세싱에 의한 제1 결과값을 저장한다.
상기 제1 결과값은 듀얼 포트 램(DPRAM)의 어느 한 포트를 통하여 저장되고, 또 다른 포트를 통하여 읽혀지는데, 상기 듀얼 포트 램(DPRAM)의 포트들을 통해 저장 또는 읽혀지는 주소는 상기 W0또는 W 길이마다 증가 또는 감소된다.
또한, 상기 듀얼 포트 램(DPRAM)의 포트들을 통해 저장 또는 읽혀지는 주소는 상기 W0또는 W 길이마다 상호 배타적으로 증가 또는 감소된다.
또한, 상기 디코딩 비트의 결정 출력이 순서대로 이루어지므로 후입선출(Last In First Out)이 제거되는 것을 특징으로 한다.
도 1은 종래 기술에 따른 MAP 디코딩 타이밍도를 나타낸 도면.
도 2는 본 발명에 따른 MAP 디코딩 타이밍도를 나타낸 도면.
이하 본 발명의 바람직한 일 실시 예에 따른 구성 및 작용을 첨부된 도면을 참조하여 설명한다.
앞에서 설명한 바와 같이 MAP 알고리즘은 수신된 시퀀스(yk)를 이용해서 정보 비트의 사후확률(A Posteriori)[P(dk=1|y)와 P(dk=0|y)]을 추정하고, 이 정보의 사후확률로부터 최종적으로 LLR(Log Likelihood Ratio) 형태의 복호화기의 출력을 구하기 위한 알고리즘이다. 상기 LLR 형태의 복호화기의 출력은 수학식 1을 통하여 설명되어져 있다.
이때, 정보 비트의 사후 확률을 구하기 위해서는 "P(dk=1|y)"와 "P(dk=0|y)" 각각에 대해 상태 천이 사후확률을 구해야 하는데, 이 각각의 상태 천이 사후확률은 세 가지의 곱셈 항목에 의하여 구할 수 있다. 상기 상태 천이 사후확률에 대한 세 가지의 곱셈 항목은 수학식 2를 통하여 설명되어져 있다.
즉, 수학식 2를 참고로 하면 제1 항목(α(Sk-1))은 수신 시퀀스가 시간 0부터 k-1에 해당하는 확률이고, 상태 Sk-1이 m'을 갖는 조인트 확률 함수로 표현되고, 다음 수학식 3과 같이 나타낸다.
상기 수학식 3으로부터는 시간 1부터 k를 갖는 수신 시퀀스(yj<k+1)에서, 상태 Sk-1이 m'이고, 상태 Sk가 m인 상태천이에 대한 조인트(Joint) 확률 밀도 함수로 표현이 되고, 다음 수학식 4와 같이 나타낸다.
제2 항목(γ(Sk-1,Sk))은 상태 Sk-1가 상태 Sk로 천이할 때 관계하는 가지 메트릭(branch metric)으로써, 상태 Sk-1이 m'인 조건하에서 다음 상태 Sk가 m이고, 이때 수신된 시퀀스는 yk를 갖는 조건 확률 함수로 표현이 되고, 다음 수학식 5와 같이 나타낸다.
제3 텀(β(Sk))은 상태 Sk가 m인 조건하에서 수신 시퀀스 넘버가 k+1 이상이 되는 수신 시퀀스(yj>k)가 될 조건 확률 함수로 표현이 되고, 다음 수학식 6과 같이 나타낸다.
상기 dk는 터보 부호화되기 전의 정보 비트열을 나타내고, Sk는 시간 k에서의 부호화기의 메모리 상태(m={0,1...,M-1})를 나타내는 것으로, 모두 M가지의 상태를가지며, 시간이 k-1에서 k로 천이할 때 상기 입력비트 dk는 부호화기의 상태 Sk-1를 Sk로 변환된다.
즉, MAP 디코딩에서 상기 "α(Sk)"는 수학식 4와 같이 순방향 재귀(forward recursion) 방법에 의하여 구할 수 있으며, 계산된 알파값이 디코더의 출력 비트를 결정하는데 바로 이용된다. 상기 "α(Sk)"는 하나의 순방향(알파) 프로세서에 의하여 수행된다.
또한, 상기 "β(Sk)"는 수학식 6과 같이 역방향 재귀(backward recursion) 방법에 의하여 구할수 있으며, 이 "β(Sk)"가 최적의 사후 확률을 구하는데 이용되기 위해서는 일정 기간이 필요하다. 이 일정 기간을 "학습(learning)" 기간이라고 하고, 이 학습 기간 이후에 한 개의 역방향(베타) 프로세서에 의하여 계산되어진 "β(Sk)"가 디코더의 출력 비트를 결정하는데 이용된다.
이하 상기 α(Sk)는 알파값, 상기 β(Sk)는 베타값으로 지칭된다.
도 2는 본 발명에 따른 MAP 디코딩 타이밍도를 나타낸 도면이다.
도 2를 참조하면, 역방향 프로세서는 임의의 W0+L부터 W0까지의 심볼을 가지고 "학습"을 시작한다. 상기 "학습" 에 대한 기간은 전체 MAP 디코딩에서 "L" 길이동안 이루어진다. 상기 "학습"에는 종래 기술과 같이 수신 시퀀스의 L비트에 해당하는 심볼을 사용한다.
다음 W0에서부터 0까지의 심볼을 가지고 베타값을 계산하여 메모리에 저장한다.
다음으로 W0+L+W부터 W0+W까지의 심볼을 가지고 "학습" 과정을 시작하고, W0+W부터 W0까지의 심볼로 베타값을 계산하여 메모리에 저장한다. 이와 동시에 순방향 프로세서는 0에서 W0까지의 심볼을 가지고 알파값을 계산하여, 상기 역방향 프로세서에 의해 저장된 W0에서 0까지의 베타값을 같이 이용하여 디코더 출력의 비트를 결정한다. 상기 베타값 또는 알파값의 계산은 W 길이동안 이루어진다.
계속해서 W0+2W+L부터 W0+2W까지의 심볼을 가지고 "학습" 과정을 시작하고, W0+2W부터 W0+W까지의 심볼로 베타값을 계산하여 메모리에 저장한다. 이와 동시에 순방향 프로세서는 상기 W0부터 W0+W까지의 심볼을 가지고 알파값을 계산하여, 상기 역방향 프로세서에 의해 저장된 W0+W부터 W0까지의 베타값을 같이 이용하여 디코더 출력의 비트를 결정한다.
이와 같이 "학습"과, 역방향 프로세싱, 순방향 프로세싱, 디코딩을 반복해서 하나의 코드 블록에 대한 MAP 디코딩을 완료한다.
한편, 도 2의 아래 두 줄에는 역방향 프로세싱의 결과인 베타값을 저장하는 듀얼 포트 램(RAM)(DPRAM)의 어드레스를 나타내었다. 포트 A로는 베타값을 저장하고, 포트 B로는 베타값을 읽어내는 것을 가정하였다.
단, 상기 "학습"기간 중에 계산되어진 베타값은 저장하지 않는다.
상기 W0부터 0까지 계산된 베타값은 포트 A의 W0부터 0까지 감소하는 어드레스의 순서대로 저장되고, 이후에 상기 베타값은 포트 B를 통하여 0부터 W0까지 증가하는 어드레스 순서대로 읽어져 상기 0부터 W0까지 계산된 알파값과 함께 디코더의 출력 비트를 결정하는데 이용된다.
또한, 상기 "W0+W"부터 "W0"까지 계산된 베타값은 포트 A의 0부터 W까지 증가하는 어드레스의 순서대로 저장되고, 이후에 상기 베타값은 포트 B를 통하여 W부터 0까지 감소하는 어드레스 순서대로 읽어져 상기 "W0"부터 "W0+W"까지 계산된 알파값과 함께 디코더의 출력 비트를 결정하는데 이용된다.
즉, 상기 포트 A와 포트 B는 상기 일정 길이동안 계산되어진 베타값을 증가 또는 감소하는 어드레스의 순서대로 저장하거나 읽어서 출력하는데, 상기 포트 A에 저장된 베타값이 증가되는 어드레스 순서대로 저장된 경우에는 포트 B를 통하여 감소하는 어드레스 순서대로 읽어지고, 감소되는 어드레스 순서대로 저장된 경우에는 포트 B를 통하여 증가하는 어드레스 순서대로 읽어져서 출력된다.
즉, 상기 포트 A와 포트 B는 상호 배타적으로 증가 또는 감소하는 어드레스 순서에 따라 동작한다.
만약, 쓰고 있는 어드레스가 항상 같은 방향으로 진행한다면 즉, 포트 A의 어드레스는 W 또는 W0에서 0으로 감소하고 포트 B의 어드레스는 0에서 W 또는 W0로증가하기를 반복한다면, 저장된 베타값을 채 읽어내지 않은 상태에서 새로운 값이 갱신되어 버린다. 이를 방지하려면 베타 저장 메모리를 두 배로 늘리거나, 본 발명에서 제안된 방법을 사용해야 하는 것이다.
본 발명에서는 하나의 역방향 프로세싱이 W0+NW+L (N=0,1,2....)에서 시작되므로 이 시작점은 슬라이딩 윈도우마다 W만큼씩 증가한다. 그리고, 역방향 프로세싱의 끝점은 0(N=0) 또는 W0+(N-1)W(N=1,2...)으로써 역시 W만큼씩 증가시키면 된다. 모든 "학습"에는 종래 기술과 같이 수신 시퀀스의 L비트에 해당하는 심볼을 사용한다.
상기 W0는 (수신 시퀀스 길이)%W (%는 모듈로 연산)로 결정한다. 단, 모듈로 결과가 0이면 W를 사용한다.
예를 들어, 수신 시퀀스 길이가 3840비트이고, W가 256이라면 W0는 W와 같이 256으로 결정된다. 수신 시퀀스 길이가 3841비트라면 W0는 1이 된다. 이렇게 W0를 결정하면 마지막 역방향 프로세싱 단위가 항상 W가 된다. 이렇게 함으로써 3GPP WCDMA와 같이 트렐리스 터미네이션(3GPP TS25.212 V2.2.1 Turbo Coding section, Oct.1999)을 사용하는 터보 코드의 성질을 최대한 살릴 수 있다.
이것은 테일 비트를 사용한 컨벌루션 코드를 비터비 디코더로 디코딩할 때 코드 블록의 맨 마지막 역추적 깊이(trace-back depth) 만큼은 스테이트 0에서 시작해서 한꺼번에 디코딩하는 것과 같은 개념이다.
예를 들어, W를 256으로 결정했을 때 3841비트의 코드 블록은 1비트가 남게 되고, 본 발명에서처럼 맨 앞 윈도에서 1비트를 처리하거나, 아니면 맨 뒤의 윈도우에서 1비트를 처리하는 방법을 생각할 수 있다. 그런데, 각 코드 블록의 끝에서는 터미네이션 특성을 이용할 수 있으므로 이를 이용하여 1비트를 디코딩하는 것보다는 256 비트를 디코딩하는 것이 보다 나은 디코딩 성능을 얻을 수 있는 방법이다.
한편, MAP 디코딩에서 필요한 메모리의 크기를 비교하면 종래 기술에서는 60depth를 필요로 하는 반면, 본 발명의 디코더는 256depth를 사용하므로 많이 늘어난 것처럼 보이지만, 본 발명의 구현에 사용한 "Xilinx Virtex" 칩의 내부 블록 램(RAM)의 최소 깊이(depth)가 256이므로 실제 회로를 구현하는 관점에서는 차이가 없을 수도 있다.
이상의 설명에서와 같이 본 발명은 역방향 프로세서를 하나만 사용하므로 회로의 크기와 연산량(전력소모)을 줄일 수 있다.
마지막 윈도우를 채움으로써 트렐리스 터미네이션의 특성을 살려 더 나은 디코딩 능력을 갖는다.
디코더 결과를 순서대로 얻을 수 있으므로 LIFO에 필요한 메모리 및 회로를 제거할 수 있고, 전력 소모면에서 개선효과가 있다.
베타값을 저장하는 듀얼 포트 램(DPRAM)의 읽고 쓰는 어드레스를 조절하여 이 메모리의 크기를 반으로 줄일 수 있다.
이상 설명한 내용을 통해 당업자라면 본 발명의 기술 사상을 일탈하지 아니하는 범위에서 다양한 변경 및 수정이 가능함을 알 수 있을 것이다.
따라서, 본 발명의 기술적 범위는 실시예에 기재된 내용으로 한정하는 것이 아니라 특허 청구 범위에 의해서 정해져야 한다.
Claims (7)
- 수신 시퀀스를 최대 사후(Maximum A Posteriori) 알고리즘을 이용하여 디코딩하는데 있어,상기 수신 시퀀스의 일정 길이동안 역방향 프로세싱에 의한 학습(learning)을 수행하고, 상기 수신 시퀀스의 학습 이후에 역방향 프로세싱에 의한 제1 결과값을 계산하고, 이와 동시에 순방향 프로세싱에 의한 제2 결과값을 계산하여, 상기 제1 결과값 이전에 저장된 상기 수신 시퀀스에 대한 역방향 프로세싱에 의한 결과값인 제3 결과값을 이용하여 디코딩 비트 출력을 결정하는 것을 특징으로 하는 터보 디코딩 방법.
- 제 1항에 있어서, 상기 역방향 또는 순방향 프로세싱 시간이 W이고, 상기 수신 시퀀스 길이를 W로 나눈 나머지가 W0이고, 정수 N에 대하여,수신 시퀀스의 시간 "W0+NW+L"부터 "W0+NW"의 심볼로 역방향 프로세싱에 의해 학습(learning)을 수행하고, 이후에 "W0+NW"부터 "W0+(N-1)W"까지의 심볼로 역방향 프로세싱에 의한 제1 결과값을 저장하고, 이와 동시에 0(N=1) 또는"W0+(N-2)W"(N은 2이상의 정수)부터 "W0+(N-1)W"까지의 심볼로 순방향 프로세싱에 의한 제2 결과값을 계산하여, "W0+(N-1)W"부터 "W0+(N-2)W"까지 계산되어 저장된 제1 결과값과 함께 디코딩 비트 결정을 수행하는 것을 특징으로 하는 터보 디코딩 방법.
- 제 2항에 있어서, 상기 N이 0인 경우에, 상기 수신 시퀀스의 시간 "W0+L"부터 W0의 심볼로 역방향 프로세싱에 의해 학습(learning)을 수행하고, 이후에 W0부터 0까지의 심볼로 역방향 프로세싱에 의한 제1 결과값을 저장하는 것을 특징으로 하는 터보 디코딩 방법.
- 제 1항에 있어서, 상기 제1 결과값은 듀얼 포트 램(DPRAM)의 어느 한 포트를 통하여 저장되고, 또 다른 포트를 통하여 읽혀지는 것을 특징으로 하는 터보 디코딩 방법.
- 제 4항에 있어서, 상기 듀얼 포트 램(DPRAM)의 포트들을 통해 저장 또는 읽혀지는 주소는 상기 W0또는 W 길이마다 증가 또는 감소되는 것을 특징으로 하는 터보 디코딩 방법.
- 제 4항에 있어서, 상기 듀얼 포트 램(DPRAM)의 포트들을 통해 저장 또는 읽혀지는 주소는 상기 W0또는 W 길이마다 상호 배타적으로 증가 또는 감소되는 것을 특징으로 하는 터보 디코딩 방법.
- 제 1항에 있어서, 상기 디코딩 비트의 결정 출력이 순서대로 이루어지므로 후입선출(Last In First Out)이 제거되는 것을 특징으로 하는 터보 디코딩 방법.
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2000-0060746A KR100390416B1 (ko) | 2000-10-16 | 2000-10-16 | 터보 디코딩 방법 |
CNB011415584A CN1254121C (zh) | 2000-10-16 | 2001-10-15 | 特博码的解码方法 |
JP2001317504A JP3954347B2 (ja) | 2000-10-16 | 2001-10-15 | ターボデコーディング方法 |
US09/977,252 US7003041B2 (en) | 2000-10-16 | 2001-10-16 | Device and method for decoding turbo codes |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2000-0060746A KR100390416B1 (ko) | 2000-10-16 | 2000-10-16 | 터보 디코딩 방법 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20020030169A KR20020030169A (ko) | 2002-04-24 |
KR100390416B1 true KR100390416B1 (ko) | 2003-07-07 |
Family
ID=19693688
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR10-2000-0060746A KR100390416B1 (ko) | 2000-10-16 | 2000-10-16 | 터보 디코딩 방법 |
Country Status (4)
Country | Link |
---|---|
US (1) | US7003041B2 (ko) |
JP (1) | JP3954347B2 (ko) |
KR (1) | KR100390416B1 (ko) |
CN (1) | CN1254121C (ko) |
Families Citing this family (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100388780B1 (ko) * | 2000-12-30 | 2003-06-25 | 주식회사 하이닉스반도체 | 이동통신 기지국의 디코더에서 메모리 용량 축소 방법 |
JP4185314B2 (ja) * | 2002-06-07 | 2008-11-26 | 富士通株式会社 | 情報記録再生装置、光ディスク装置及び、データ再生方法 |
US7154965B2 (en) * | 2002-10-08 | 2006-12-26 | President And Fellows Of Harvard College | Soft detection of data symbols in the presence of intersymbol interference and timing error |
JP2005167513A (ja) * | 2003-12-01 | 2005-06-23 | Matsushita Electric Ind Co Ltd | 復号装置及び復号方法 |
US7849377B2 (en) * | 2003-12-22 | 2010-12-07 | Koninklijke Philips Electronics N.V. | SISO decoder with sub-block processing and sub-block based stopping criterion |
JP4366652B2 (ja) | 2004-04-23 | 2009-11-18 | 横河電機株式会社 | 伝送器及びその二重化方法 |
WO2005125019A1 (ja) * | 2004-06-17 | 2005-12-29 | Mitsubishi Denki Kabushiki Kaisha | ターボ符号の誤り訂正復号方法及びターボ符号の誤り訂正復号装置 |
GB0804206D0 (en) * | 2008-03-06 | 2008-04-16 | Altera Corp | Resource sharing in decoder architectures |
US8578255B1 (en) * | 2008-12-19 | 2013-11-05 | Altera Corporation | Priming of metrics used by convolutional decoders |
KR200458216Y1 (ko) * | 2009-12-14 | 2012-01-30 | (주)아모레퍼시픽 | 에어리스 펌프 |
CN102571107B (zh) * | 2010-12-15 | 2014-09-17 | 展讯通信(上海)有限公司 | LTE系统中高速并行Turbo码的解码系统及方法 |
US8910029B2 (en) * | 2011-02-08 | 2014-12-09 | Intel Mobile Communications GmbH | Iterative decoder |
CN103746710B (zh) * | 2013-12-30 | 2017-04-05 | 华为技术有限公司 | 一种译码器和译码方法 |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6128765A (en) * | 1998-08-20 | 2000-10-03 | General Electric Company | Maximum A posterior estimator with fast sigma calculator |
US6292918B1 (en) | 1998-11-05 | 2001-09-18 | Qualcomm Incorporated | Efficient iterative decoding |
US6189126B1 (en) * | 1998-11-05 | 2001-02-13 | Qualcomm Incorporated | Efficient trellis state metric normalization |
US6580767B1 (en) * | 1999-10-22 | 2003-06-17 | Motorola, Inc. | Cache and caching method for conventional decoders |
JP2002076921A (ja) * | 2000-09-01 | 2002-03-15 | Nec Corp | 誤り訂正符号復号方法及び装置 |
US6829313B1 (en) * | 2000-07-17 | 2004-12-07 | Motorola, Inc. | Sliding window turbo decoder |
US6813743B1 (en) * | 2000-07-31 | 2004-11-02 | Conexant Systems, Inc. | Sliding window technique for map decoders |
US6452979B1 (en) * | 2000-09-06 | 2002-09-17 | Motorola, Inc. | Soft output decoder for convolutional codes |
JP2004080508A (ja) * | 2002-08-20 | 2004-03-11 | Nec Electronics Corp | 誤り訂正符号の復号方法、そのプログラム及びその装置 |
-
2000
- 2000-10-16 KR KR10-2000-0060746A patent/KR100390416B1/ko not_active IP Right Cessation
-
2001
- 2001-10-15 JP JP2001317504A patent/JP3954347B2/ja not_active Expired - Fee Related
- 2001-10-15 CN CNB011415584A patent/CN1254121C/zh not_active Expired - Fee Related
- 2001-10-16 US US09/977,252 patent/US7003041B2/en not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
US20020097816A1 (en) | 2002-07-25 |
JP2002204173A (ja) | 2002-07-19 |
JP3954347B2 (ja) | 2007-08-08 |
CN1349361A (zh) | 2002-05-15 |
KR20020030169A (ko) | 2002-04-24 |
CN1254121C (zh) | 2006-04-26 |
US7003041B2 (en) | 2006-02-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5933462A (en) | Soft decision output decoder for decoding convolutionally encoded codewords | |
JP3604955B2 (ja) | 畳込み復号装置 | |
JP3861084B2 (ja) | 特に移動無線システム用とした、複合型ターボ符号/畳み込み符号デコーダ | |
US7467347B2 (en) | Method for decoding error correcting code, its program and its device | |
US20030097633A1 (en) | High speed turbo codes decoder for 3G using pipelined SISO Log-Map decoders architecture | |
US6799295B2 (en) | High speed turbo codes decoder for 3G using pipelined SISO log-map decoders architecture | |
KR20080098391A (ko) | 양방향 슬라이딩 윈도우 아키텍처를 갖는 map 디코더 | |
KR100390416B1 (ko) | 터보 디코딩 방법 | |
US6563890B2 (en) | Maximum a posteriori probability decoding method and apparatus | |
EP1471677A1 (en) | Method of blindly detecting a transport format of an incident convolutional encoded signal, and corresponding convolutional code decoder | |
JP5700035B2 (ja) | 誤り訂正符号復号装置、誤り訂正符号復号方法および誤り訂正符号復号プログラム | |
US8904266B2 (en) | Multi-standard viterbi processor | |
CN108134612B (zh) | 纠正同步与替代错误的级联码的迭代译码方法 | |
JP2004349901A (ja) | ターボ復号器及びそれに用いるダイナミック復号方法 | |
US7178090B2 (en) | Error correction code decoding device | |
JP2001230677A (ja) | ターボ復号器 | |
Tsai et al. | A memory-reduced log-MAP kernel for turbo decoder | |
KR100436434B1 (ko) | 상태 메트릭을 갖는 터보 복호기 및 그를 이용한 계산 방법 | |
Ahmed et al. | Viterbi algorithm performance analysis for different constraint length | |
KR20010113792A (ko) | 재귀적 컨벌루션형 심벌들을 디코딩하기 위한 방법 및 장치 | |
JP2006115534A (ja) | 誤り訂正符号の復号方法、そのプログラム及びその装置 | |
KR20020066556A (ko) | 터보 코드 복호화 장치 및 방법 | |
JP4525658B2 (ja) | 誤り訂正符号復号装置 | |
JP2006115534A5 (ko) | ||
JP2001230679A (ja) | ターボ復号器 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A201 | Request for examination | ||
N231 | Notification of change of applicant | ||
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20130514 Year of fee payment: 11 |
|
FPAY | Annual fee payment |
Payment date: 20140523 Year of fee payment: 12 |
|
FPAY | Annual fee payment |
Payment date: 20150522 Year of fee payment: 13 |
|
LAPS | Lapse due to unpaid annual fee |