KR100803129B1 - Error correction method in digital broadcasting receiving system - Google Patents

Error correction method in digital broadcasting receiving system Download PDF

Info

Publication number
KR100803129B1
KR100803129B1 KR1020060021326A KR20060021326A KR100803129B1 KR 100803129 B1 KR100803129 B1 KR 100803129B1 KR 1020060021326 A KR1020060021326 A KR 1020060021326A KR 20060021326 A KR20060021326 A KR 20060021326A KR 100803129 B1 KR100803129 B1 KR 100803129B1
Authority
KR
South Korea
Prior art keywords
memory
polynomial
error
syndrome
order term
Prior art date
Application number
KR1020060021326A
Other languages
Korean (ko)
Other versions
KR20070091779A (en
Inventor
김진우
Original Assignee
엘지전자 주식회사
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 엘지전자 주식회사 filed Critical 엘지전자 주식회사
Priority to KR1020060021326A priority Critical patent/KR100803129B1/en
Publication of KR20070091779A publication Critical patent/KR20070091779A/en
Application granted granted Critical
Publication of KR100803129B1 publication Critical patent/KR100803129B1/en

Links

Images

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B65CONVEYING; PACKING; STORING; HANDLING THIN OR FILAMENTARY MATERIAL
    • B65DCONTAINERS FOR STORAGE OR TRANSPORT OF ARTICLES OR MATERIALS, e.g. BAGS, BARRELS, BOTTLES, BOXES, CANS, CARTONS, CRATES, DRUMS, JARS, TANKS, HOPPERS, FORWARDING CONTAINERS; ACCESSORIES, CLOSURES, OR FITTINGS THEREFOR; PACKAGING ELEMENTS; PACKAGES
    • B65D85/00Containers, packaging elements or packages, specially adapted for particular articles or materials
    • B65D85/30Containers, packaging elements or packages, specially adapted for particular articles or materials for articles particularly sensitive to damage by shock or pressure
    • B65D85/38Containers, packaging elements or packages, specially adapted for particular articles or materials for articles particularly sensitive to damage by shock or pressure for delicate optical, measuring, calculating or control apparatus
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B65CONVEYING; PACKING; STORING; HANDLING THIN OR FILAMENTARY MATERIAL
    • B65DCONTAINERS FOR STORAGE OR TRANSPORT OF ARTICLES OR MATERIALS, e.g. BAGS, BARRELS, BOTTLES, BOXES, CANS, CARTONS, CRATES, DRUMS, JARS, TANKS, HOPPERS, FORWARDING CONTAINERS; ACCESSORIES, CLOSURES, OR FITTINGS THEREFOR; PACKAGING ELEMENTS; PACKAGES
    • B65D5/00Rigid or semi-rigid containers of polygonal cross-section, e.g. boxes, cartons or trays, formed by folding or erecting one or more blanks made of paper
    • B65D5/42Details of containers or of foldable or erectable container blanks
    • B65D5/44Integral, inserted or attached portions forming internal or external fittings
    • B65D5/50Internal supporting or protecting elements for contents
    • B65D5/5028Elements formed separately from the container body
    • B65D5/5035Paper elements
    • B65D5/5038Tray-like elements formed by folding a blank and presenting openings or recesses
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B65CONVEYING; PACKING; STORING; HANDLING THIN OR FILAMENTARY MATERIAL
    • B65DCONTAINERS FOR STORAGE OR TRANSPORT OF ARTICLES OR MATERIALS, e.g. BAGS, BARRELS, BOTTLES, BOXES, CANS, CARTONS, CRATES, DRUMS, JARS, TANKS, HOPPERS, FORWARDING CONTAINERS; ACCESSORIES, CLOSURES, OR FITTINGS THEREFOR; PACKAGING ELEMENTS; PACKAGES
    • B65D81/00Containers, packaging elements, or packages, for contents presenting particular transport or storage problems, or adapted to be used for non-packaging purposes after removal of contents
    • B65D81/02Containers, packaging elements, or packages, for contents presenting particular transport or storage problems, or adapted to be used for non-packaging purposes after removal of contents specially adapted to protect contents from mechanical damage
    • B65D81/025Containers made of sheet-like material and having a shape to accommodate contents
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B65CONVEYING; PACKING; STORING; HANDLING THIN OR FILAMENTARY MATERIAL
    • B65DCONTAINERS FOR STORAGE OR TRANSPORT OF ARTICLES OR MATERIALS, e.g. BAGS, BARRELS, BOTTLES, BOXES, CANS, CARTONS, CRATES, DRUMS, JARS, TANKS, HOPPERS, FORWARDING CONTAINERS; ACCESSORIES, CLOSURES, OR FITTINGS THEREFOR; PACKAGING ELEMENTS; PACKAGES
    • B65D81/00Containers, packaging elements, or packages, for contents presenting particular transport or storage problems, or adapted to be used for non-packaging purposes after removal of contents
    • B65D81/02Containers, packaging elements, or packages, for contents presenting particular transport or storage problems, or adapted to be used for non-packaging purposes after removal of contents specially adapted to protect contents from mechanical damage
    • B65D81/05Containers, packaging elements, or packages, for contents presenting particular transport or storage problems, or adapted to be used for non-packaging purposes after removal of contents specially adapted to protect contents from mechanical damage maintaining contents at spaced relation from package walls, or from other contents
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B65CONVEYING; PACKING; STORING; HANDLING THIN OR FILAMENTARY MATERIAL
    • B65DCONTAINERS FOR STORAGE OR TRANSPORT OF ARTICLES OR MATERIALS, e.g. BAGS, BARRELS, BOTTLES, BOXES, CANS, CARTONS, CRATES, DRUMS, JARS, TANKS, HOPPERS, FORWARDING CONTAINERS; ACCESSORIES, CLOSURES, OR FITTINGS THEREFOR; PACKAGING ELEMENTS; PACKAGES
    • B65D2585/00Containers, packaging elements or packages specially adapted for particular articles or materials
    • B65D2585/68Containers, packaging elements or packages specially adapted for particular articles or materials for machines, engines, or vehicles in assembled or dismantled form
    • B65D2585/86Containers, packaging elements or packages specially adapted for particular articles or materials for machines, engines, or vehicles in assembled or dismantled form for electrical components

Landscapes

  • Engineering & Computer Science (AREA)
  • Mechanical Engineering (AREA)
  • Error Detection And Correction (AREA)

Abstract

본 발명은 디지털 방송 수신 시스템에서의 오류 정정 방법에 관한 것으로서, 수신된 디지털 방송 데이터를 재생하는 과정에서 오류를 정정하기 위해 사용되는 소거 RS 디코더는 오류 위치 다항식 및 오류 크기 다항식을 구하기 위한 키 방정식(key equation) 연산을 해야 한다. 그러나, 키 방정식 연산은 전체 연산의 수행 시간 중 가장 많은 부분을 차지하고 하드웨어 복잡도가 가장 크다. 본 발명은 이상과 같은 문제점을 해결하기 위한 것으로, 키 방정식 연산에서 2-메모리 회귀적(recursive) 연산 방법을 사용하여 기존의 소거 RS 디코더에 비해 하드웨어 복잡도를 감소시킬 수 있는 디지털 방송 수신 시스템에서의 오류 정정 방법을 제공하는 데 있다.The present invention relates to an error correction method in a digital broadcasting reception system, wherein an erasing RS decoder used to correct an error in a process of playing received digital broadcasting data includes a key equation for obtaining an error position polynomial and an error magnitude polynomial. key equation). However, key equation operations take the largest part of the total computation time and have the largest hardware complexity. The present invention is to solve the above problems, in a digital broadcast receiving system that can reduce the hardware complexity compared to the conventional erasing RS decoder by using a 2-memory recursive operation method in the key equation operation To provide an error correction method.

RS, 오류, 디코더, 회귀적, 메모리 RS, error, decoder, recursive, memory

Description

디지털 방송 수신 시스템에서의 오류 정정 방법{ERROR CORRECTION METHOD IN DIGITAL BROADCASTING RECEIVING SYSTEM}Error correction method in digital broadcasting reception system {ERROR CORRECTION METHOD IN DIGITAL BROADCASTING RECEIVING SYSTEM}

도 1은 베레캄프 매세이 알고리즘을 사용한 소거 RS 디코딩 과정을 나타내는 흐름도이다.1 is a flowchart illustrating an erase RS decoding process using a Berekamp Massey algorithm.

도 2는 수정 신드롬 다항식의 연산 블록을 나타낸 도면이다.2 illustrates arithmetic blocks of a modified syndrome polynomial.

도 3은 본 발명의 바람직한 실시예에 따른 디지털 방송 수신 시스템에서의 2-메모리 회귀적(recursive) 연산 방법을 나타내는 구성 블록도이다.3 is a block diagram illustrating a two-memory recursive calculation method in a digital broadcasting reception system according to an embodiment of the present invention.

도 4는 2-메모리 회귀적(recursive) 연산을 시분할하여 나타낸 도면이다.4 is a time divisional representation of a two-memory recursive operation.

도 5는 프로토콜 스택을 OSI 3 계층으로 나타낸 구성 블록도이다.5 is a block diagram illustrating a protocol stack in an OSI 3 layer.

도 6은 MPE-FEC 프레임의 구조를 나타낸 도면이다.6 is a diagram showing the structure of an MPE-FEC frame.

<도면의 주요 부분에 대한 부호의 설명><Explanation of symbols for the main parts of the drawings>

301, 302 : 메모리301, 302: memory

본 발명은 디지털 방송 수신 시스템의 오류 정정 방법에 관한 것으로, 보다 상세하게는 DVB-H 수신 시스템에서 오류 정정을 위해 사용되는 소거(erasure) RS 디코더의 하드웨어 구조를 간소화하는 방법에 관한 것이다.The present invention relates to an error correction method of a digital broadcast reception system, and more particularly, to a method of simplifying a hardware structure of an erasure RS decoder used for error correction in a DVB-H reception system.

일반적인 RS 부호의 복호 과정은 신드롬 다항식(syndrome polynomial) 계산, 오류 위치 다항식(error locator polynomial) 및 오류 크기 다항식(error magnitude polynomial) 계산, 오류 위치 및 오류 값 계산, 오류 정정의 다섯 단계로 구분할 수 있다.The general RS code decoding process can be divided into five steps: calculation of syndrome polynomial, error locator polynomial and error magnitude polynomial, error location and error value calculation, and error correction. .

이 중에서 오류 위치 다항식 및 오류 크기 다항식을 구하기 위한 키 방정식(key equation) 연산은 전체 연산 수행 시간 중 가장 많은 부분을 차지하며 하드웨어 복잡도가 가장 크다. 따라서, 키 방정식 연산 구조는 RS 디코더의 성능을 결정하는 중요한 부분이다. 키 방정식 연산을 위한 알고리즘으로 베레캄프-매세이(Berlekamp-Massey) 알고리즘, 유클리드 알고리즘, 수정 유클리드 알고리즘 등이 있다.Among them, the key equation operation for calculating the error position polynomial and the error magnitude polynomial occupies the largest part of the total computation time and has the largest hardware complexity. Thus, the key equation operation structure is an important part of determining the performance of the RS decoder. Algorithms for computing key equations include the Berlekamp-Massey algorithm, the Euclidean algorithm, and the modified Euclidean algorithm.

도 1은 베레캄프 매세이 알고리즘을 사용한 소거 RS 디코딩 과정을 나타내는 흐름도이다.1 is a flowchart illustrating an erase RS decoding process using a Berekamp Massey algorithm.

도 1에 도시된 바와 같이, RS 인코딩(encoding)된 데이터가 수신되면 코드워드(codeword) 내의 오류 유무를 판단할 수 있는 신드롬(syndrome) 다항식 S(x)의 연산이 먼저 수행된다. 신드롬 다항식의 연산에서 오류가 발견되면 코드워드(codeword) 내에 오류가 있다는 의미이므로 오류 포지션 버퍼(error position buffer) 값을 읽어 오류(error) 발생 가능성이 높은 심볼 위치를 나타내는 소거 위치자 다항식(erasure locator polynomial) Γ(x)를 계산한다. 그 후 전술한 신드롬 다항식 S(x)와 소거 위치자 다항식 Γ(x)를 곱셈 연산하여 수정 신드롬 다항식 (modified syndrome polynomial)Ξ(x)을 계산한다(S110).As shown in FIG. 1, when RS encoded data is received, an operation of a syndrome polynomial S (x) capable of determining whether an error is present in a codeword is first performed. If an error is found in the operation of the syndrome polynomial, it means that there is an error in the codeword. polynomial) calculate Γ (x). Then, the modified syndrome polynomial S (x) and the erase locator polynomial Γ (x) are multiplied to calculate a modified syndrome polynomial Ξ (x) (S110).

다음에, 수정 신드롬 다항식 Ξ(x)을 베레캄프 알고리즘을 사용하여 오류 위치자 다항식 Λ(x)을 생성한다(S111).Next, an error locator polynomial Λ (x) is generated using the modified syndrome polynomial Ξ (x) using the Berekkamp algorithm (S111).

다음에, 생성된 오류 위치자 다항식 Λ(x)과 새로운 오류/소거 위치자 다항식(erasure/error locator polynomial) Ψ(x)과 오류 크기 다항식(error magnitude polynomial) Ω(x)를 구하여 오류 값(error value) eik과, 소거 값 fik을 계산하여 오류 정정을 수행한다(S112).Next, the resulting error locator polynomial Λ (x), the new error / erase locator polynomial Ψ (x), and the error magnitude polynomial Ω (x) are obtained. error value) e ik and an erase value f ik are calculated to perform error correction (S112).

그러나 상기한, 일반적인 다항식 연산 방법으로 구현된 하드웨어(hardware) 구조에서는 복잡도가 낮은 파이프라인(pipeline) 구조가 많이 알려져 있지만 수정 신드롬 다항식 Ξ(x)와 같은 2개의 다항식끼리의 곱셈 연산의 경우는 하드웨어 구조가 매우 복잡하게 된다.However, in the hardware structure implemented by the general polynomial operation method described above, a low complexity pipeline structure is known, but in the case of multiplication between two polynomials such as a modified syndrome polynomial Ξ (x), the hardware The structure is very complicated.

또한, 소거/ 오류 위치자 다항식(erasure/error locator polynomial) Ψ(x)과 오류 크기 다항식(error magnitude polynomial) Ω(x)도 마찬가지로, 수정 신드롬 다항식 Ξ(x)와 유사한 방식의 연산이 요구되어 소거 RS 디코더의 하드웨어 복잡도를 크게 증가시켰다.In addition, the erase / error locator polynomial Ψ (x) and error magnitude polynomial Ω (x) are similarly required to operate in a similar manner to the modified syndrome polynomial Ξ (x). The hardware complexity of the cancellation RS decoder has been greatly increased.

도 2는 수정 신드롬 다항식 Ξ(x)의 연산 블록을 나타낸 도면이다.2 is a diagram illustrating a calculation block of a modified syndrome polynomial Ξ (x).

도 2에 도시된 바와 같이, 이러한 수정 신드롬 다항식 Ξ(x) 연산을 사용할 경우 RS(255,191,t=32)의 소거 위치자 다항식 Ξ(x)의 연산에 필요한 구성 요소(component)는 최대 8비트의 플립-플롭 4096개와 8비트의 XOR 회로 2016개가 필요 하다. 이것은 단일 연산 블록으로 소거 연산자를 사용하지 않는 일반적인 RS 디코더에 있어서, 전체 복잡도의 50% 이상을 차지한다.As shown in FIG. 2, when using this modified syndrome polynomial Ξ (x) operation, a component required for the operation of the erase locator polynomial Ξ (x) of RS (255,191, t = 32) has a maximum of 8 bits. We need 4096 flip-flops and 2016 8-bit XOR circuits. This is more than 50% of the overall complexity for a typical RS decoder that does not use an erase operator in a single operation block.

전술한 바와 같이, DVB-H 수신 시스템의 수신 성능 개선을 위해 사용되고 있는 일반적인 소거 RS 디코더는 하드웨어 복잡도가 일반적인 RS 디코더에 비해 크게 증가되어 디지털 방송 수신 시스템을 소형으로 구현하기 힘들다는 문제점이 있었다.As described above, the general cancellation RS decoder used to improve the reception performance of the DVB-H reception system has a problem in that the hardware complexity is greatly increased compared to the general RS decoder, making it difficult to implement the digital broadcast reception system in a small size.

본 발명은 이상과 같은 문제점을 해결하기 위한 것으로서, 본 발명의 목적은 소거 RS 디코더의 하드웨어 복잡도를 개선하여 디지털 방송 수신 시스템을 구성하는 하드웨어 복잡도를 감소시키는 데 있다.The present invention has been made to solve the above problems, and an object of the present invention is to reduce the hardware complexity of the digital broadcast reception system by improving the hardware complexity of the erasing RS decoder.

이상과 같은 목적을 달성하기 위한 본 발명에 따른 디지털 방송 수신 시스템에서 소거 RS 디코딩을 수행하여 데이터의 오류를 정정하는 방법에 있어서,
(a) 신드롬 다항식 및 소거 위치자 다항식을 계산하는 단계;
(b) 상기 신드롬 다항식과 상기 소거 위치자 다항식을 곱셈 연산하여 구한 수정 신드롬 다항식을 2-메모리 회귀적(recursive) 연산하여 계산하는 단계; 및,
(c) 상기 (b)단계에서 계산된 값으로 베레캄프 매세이(Berelekamp-Massey) 알고리즘 연산하여 데이터의 오류 정정을 수행하는 단계를 포함하여 이루어지는 것을 특징으로 한다.
In the method for correcting the error of the data by performing erasure RS decoding in the digital broadcast receiving system according to the present invention for achieving the above object,
(a) calculating a syndrome polynomial and an erase locator polynomial;
(b) calculating a modified syndrome polynomial obtained by multiplying the syndrome polynomial and the erase locator polynomial by two-memory recursive calculation; And,
(c) performing the error correction of the data by performing a Berelekamp-Massey algorithm with the value calculated in step (b).

삭제delete

삭제delete

삭제delete

여기서, (b) 단계는 상기 신드롬 다항식과 상기 소거 위치자 다항식을 곱셈 연산하여 계산된 수정 신드롬의 각 차수항의 계수 값을 순차적으로 제 1 메모리(First MEM)에 저장하는 단계와 상기 제 1 메모리에 저장된 수정 신드롬의 최고 차수항부터 바로 다음 차수항끼리 순차적으로 2바이트씩 XOR(Exclusive OR) 연산하고, 연산된 중간 값(intermediate value)을 제 2 메모리에 저장하는 단계와 상기 제 2 메모리에 저장된 중간 값의 최고 차수항부터 바로 다음 차수항까지 순차적으로 2바이트씩 XOR 연산하고, 연산된 중간 값을 제 1 메모리에 저장하는 단계로 이루어지는 것이다.Here, step (b) sequentially stores the coefficient values of each order term of the modified syndrome calculated by multiplying the syndrome polynomial and the erase locator polynomial and in the first memory. XOR (Exclusive OR) operation of two bytes sequentially from the highest order term of the stored modified syndrome, and storing the calculated intermediate value in the second memory and the intermediate value stored in the second memory. XOR arithmetic operations are sequentially performed by two bytes from the highest order term of the value to the next order term, and the calculated intermediate value is stored in the first memory.

이때, XOR 연산된 중간 값을 저장하는 단계는 단방향으로 63회 반복하여 이루어지는 것이 바람직하다.At this time, the step of storing the intermediate value XOR operation is preferably performed by repeating 63 times in one direction.

본 발명은 DVB-H 수신 시스템의 수신 성능 개선을 위해 사용되고 있는 소거 RS 디코더의 XOR 연산에 플립-플롭(Flip-Flop)을 사용하지 않고 2-메모리 방식을 사용함으로써 DVB-H 수신 시스템 전체의 복잡도를 감소시키는 데 특징이 있다.The present invention provides a complexity of the entire DVB-H reception system by using a 2-memory method without using flip-flops in the XOR operation of an erased RS decoder which is used to improve the reception performance of the DVB-H reception system. It is characterized by reducing.

본 발명의 다른 목적, 특징 및 이점들은 첨부한 도면을 참조한 실시예들의 상세한 설명을 통해 명백해질 것이다.Other objects, features and advantages of the present invention will become apparent from the following detailed description of embodiments taken in conjunction with the accompanying drawings.

이하, 첨부된 도면을 참조하여 본 발명의 실시예의 구성과 그 작용을 설명하며, 도면에 도시되고 또 이것에 의해서 설명되는 본 발명의 구성과 작용은 적어도 하나의 실시예로서 설명되는 것이며, 이것에 의해서 상기한 본 발명의 기술적 사상과 그 핵심 구성 및 작용이 제한되지는 않는다.Hereinafter, with reference to the accompanying drawings illustrating the configuration and operation of the embodiment of the present invention, the configuration and operation of the present invention shown in the drawings and described by it will be described as at least one embodiment, By the technical spirit of the present invention described above and its core configuration and operation is not limited.

도 3은 본 발명의 바람직한 실시예에 따른 디지털 방송 수신 시스템에서의 2-메모리 회귀적(recursive) 연산 방법을 나타내는 구성 블록도이다.3 is a block diagram illustrating a two-memory recursive calculation method in a digital broadcasting reception system according to an embodiment of the present invention.

도 3에 도시된 바와 같이, 2개의 메모리(301, 302)는 각각 8비트 data-width의 64바이트 depth를 가진 싱글 포트(single port) RAM 구조이다. 총 64바이트의 e데이터를 64클록(clock)에 걸쳐 연속적으로 읽는 방법이 가장 빠른 처리이므로 XOR 연산 회로는 메모리 한 개당 한 개씩, 총 2개가 필요하다. 제1 메모리(301)에서 저장된 신드롬 값을 2바이트씩 읽어 XOR 연산을 수행하고, 상기 연산이 수행된 중간 값을 제 2 메모리(302)에 저장하는 과정을 총 63회 반복하면 제 1 단계(step) 단방향 연산은 끝이 난다. 다음 제2 단계(step) 연산을 행할 때는 제 1 메모리(301)에서 제 2 메모리(302)로 전술한 바와 같은 단방향 연산을 수행한 후 바로 제 2 메모리(302)에서 제 1 메모리(301)로 연산을 63회 반복하게 된다.As shown in FIG. 3, the two memories 301 and 302 each have a single port RAM structure having a 64 byte depth of 8 bits of data-width. The fastest way to read a total of 64 bytes of e-data over 64 clocks is the fastest process, so a total of two XOR arithmetic circuits are needed, one for each memory. When the XOR operation is performed by reading the syndrome value stored in the first memory 301 by 2 bytes and the process of storing the intermediate value of the operation performed in the second memory 302 is repeated 63 times, the first step is performed. ) The one-way operation ends. When performing the next step operation, the first memory 301 performs the one-way operation as described above from the second memory 302 to the first memory 301. The operation is repeated 63 times.

도 4는 2-메모리 회귀적(recursive) 연산을 단방향으로 시분할하여 나타낸 도면이다.4 is a time-divided diagram of a 2-memory recursive operation in one direction.

도시된 바와 같이, 제 1 메모리부(First MEM)에서 66클록 동안 제 1 단계(step)의 연산 결과를 제 2 메모리부(Second MEM)에 저장한 후 제 2 메모리부(Second MEM)에서 다시 66클록 동안 제 1 단계(step)의 XOR 연산을 통해 제1 메모리부(First MEM)에 결과를 저장한다. 이와 같이 회귀적인 연산을 반복하여 최대 32번까지 연산이 수행될 수 있으므로 수정 신드롬 다항식 Ξ(x) 연산을 위한 하드웨어(hardware) 구조도는 8비트 메모리 128개와 XOR 회로 2개가 요구된다.As shown in the figure, the operation result of the first step is stored in the second memory unit (Second MEM) for 66 clocks in the first memory unit (First MEM), and then again stored in the second memory unit (Second MEM). The result is stored in the first memory unit (First MEM) through the XOR operation of the first step during the clock. Since the recursive operation can be performed repeatedly up to 32 times, a hardware structure diagram for the modified syndrome polynomial Ξ (x) operation requires 128 8-bit memories and two XOR circuits.

상세히 설명하자면, XOR 연산은 한번에 2클록에 걸쳐 이루어진다. T=0에서는 제 1 메모리에 저장되어 있는 신드롬 값의 차수항(xn)의 계수를 추출하고, T=1에서는 제 1 메모리에 저장되어 있는 신드롬 값의 차수항(xn-1)의 계수를 추출한다. T=2에서는 제1 메모리에서 추출된 신드롬 값의 차수항(xn)의 계수와 차수항(xn-1)의 계수를 XOR(Exclusive OR) 연산하여 중간 값(intermediate value)의 차수항(xn')의 계수를 추출하고 동시에 제1 메모리에 저장되어 있는 신드롬 값의 차수항(xn-2)의 계수를 추출한다. T=3에서는 상기 XOR 연산된 중간 값의 차수항(xn')의 계수를 제2 메모리에 저장하고, 제1 메모리에서 추출된 상기 신드롬 값의 차수항(xn-1)의 계수와 상기 신드롬 값의 차수항(xn-2)의 계수를 XOR 연산하여 중간 값의 차수항(xn'-1)의 계수를 추출하고, 동시에 제1 메모리에 저장되어 있는 신드롬 값의 차수항(xn-3)의 계수를 추출한다. T=4에서는 상기 XOR 연산된 중간 값의 차수항(xn'-1)의 계수를 제2 메모리에 저장하고, 상기 추출된 신드롬 값의 차수항(xn-2)의 계수와 차수항(xn-3)의 계수를 XOR 연산하여 중간 값의 차수항(xn'-2)의 계수를 추출하며, 동시에 제 1 메모리에 저장되어 있는 신드롬 값의 차수항(xn-4)의 계수를 추출한다. T=5에서는 상기 추출된 중간 값의 차수항(xn'-2)의 계수를 제 2 메모리에 저장하고 상기 추출된 신드롬 값의 차수항(xn-3)의 계수와 차수항(xn-4)의 계수를 XOR 연산하여 중간값의 차수항(xn'-3)의 계수를 추출하며, 동시에 제 1 메모리에 저장되어 있는 신드롬 값의 차수항(xn-5)의 계수를 추출한다.Specifically, the XOR operation spans two clocks at a time. In T = 0, the coefficient of the order term (x n ) of the syndrome value stored in the first memory is extracted. In T = 1, the coefficient of the order term (x n-1 ) of the syndrome value stored in the first memory is extracted. Extract In T = 2, the coefficient of the order term (x n ) of the syndrome value extracted from the first memory and the coefficient of the order term (x n-1 ) are XORed to perform an OROR of the intermediate value ( x n ' ) coefficients are extracted and at the same time the coefficients of the order term (x n-2 ) of the syndrome value stored in the first memory. In T = 3, the coefficient of the order term x n ' of the XOR-operated intermediate value is stored in a second memory, the coefficient of the order term x n-1 of the syndrome value extracted from the first memory, and The coefficient of the order term (x n-2 ) of the syndrome value is XORed to extract the coefficient of the order term (x n'-1 ) of the intermediate value, and at the same time the order term (x) of the syndrome value stored in the first memory. extract the coefficient of n-3 ). In T = 4, the coefficients of the order term (x n'-1 ) of the XOR -operated intermediate value are stored in a second memory, and the coefficients and the order term (x n-2 ) of the extracted syndrome value are stored. x n-3) by performing an XOR operation of the coefficient extracting a coefficient of an intermediate value of a difference suhang (x n'-2) and, at the same time the coefficient of difference suhang (x n-4) of the syndrome value stored in the first memory Extract In T = 5, the coefficients of the extracted order term (x n'-2 ) of the intermediate value are stored in a second memory, and the coefficients of the order term (x n-3 ) and the order term (x n ) of the extracted syndrome value are stored. -4 ) extracts the coefficients of the intermediate order term (x n'-3 ) by XOR operation of the coefficients of the intermediate value, and simultaneously extracts the coefficients of the order term (x n-5 ) of the syndrome value stored in the first memory. do.

전술한 것은, 2-메모리 회귀적 연산의 단방향 연산 과정의 일 예로서, 소거 RS 디코딩 방식은 총 64개의 오류가 정정 가능하다. 따라서, T=0∼63까지의 회귀적 연산을 전술한 바와 같이 반복하여 최대 32회까지 연산을 수행하게 되는 것이다.As described above, as an example of the one-way operation of the two-memory regression operation, a total of 64 errors can be corrected in the erase RS decoding scheme. Therefore, the recursive operation of T = 0 to 63 is repeated as described above to perform the operation up to 32 times.

표 1은 일반적인 소거 RS 디코더와 본 발명의 바람직한 실시예에 따른 소거 RS 디코더의 하드웨어 구성 개수를 표로 나타낸 것이다.Table 1 shows the number of hardware configurations of a general erasing RS decoder and an erasing RS decoder according to a preferred embodiment of the present invention.

비록 기존 소거 RS 디코더에서 사용하는 다항식 연산에 비해 본 발명의 바람직한 실시예에 따른 방법으로는 메모리의 개수가 384개로 추가가 되었지만, 하드웨어의 복잡도 증가와 많은 공간을 차지하는 플립-플롭 회로를 사용하지 않아도 되고, XOR 회로의 개수도 6개로 구현할 수 있으므로, 기존 방식에 비해 하드웨어의 복잡도 감소와 함께 크기를 대폭 줄일 수 있다.Although the number of memories is increased to 384 by the preferred embodiment of the present invention, compared to the polynomial operation used in the conventional erasing RS decoder, the hardware complexity and the space-consuming flip-flop circuit are not used. In addition, since the number of XOR circuits can be implemented as six, the size of the hardware can be greatly reduced with the complexity of the hardware compared to the conventional method.

Figure 112006016174436-pat00001
Figure 112006016174436-pat00001

이하, 본 발명의 이해를 돕기 위해 DVB-H 방식의 프로토콜 스택(Protocol stack)과 MPE(Multi-Protocol Encapsulation : 멀티프로토콜 캡슐화)-FEC(FEC(Forward Error Correction : 순방향 오류 정정) 프레임 구조에 대하여 간략히 설명한다.Hereinafter, the DVB-H protocol stack and MPE (Multi-Protocol Encapsulation) -FEC (FEC) forward error correction (FEC) frame structure will be briefly described to facilitate understanding of the present invention. Explain.

도 5는 프로토콜 스택을 OSI 3 계층으로 나타낸 구성 블록도로 네트워크 계층(Network Layer), 데이터 링크 계층(Data Link Layer), 물리 계층(Physical Layer)으로 구분된다.FIG. 5 is a block diagram illustrating a protocol stack as an OSI 3 layer, and is divided into a network layer, a data link layer, and a physical layer.

도시된 바와 같이, TS 패킷 형태의 스트림에서 데이터그램 섹션 구조의 MPE, MPE-FEC, PSIP 정보를 분리해내고, 섹션 데이터그램에서 헤더와 CRC를 제거한 IP 데이터로 추출된다. TS 패킷에서 IP 데이터를 추출하는 과정은 모두 데이터 링크 계층에서 하게 된다. 데이터 링크 계층의 내부의 IP 데이터는 RS 디코더를 거쳐 오류 구간이 정정되어 다시 데이터 링크 계층의 내부 또는 외부에 위치하는 메모리에 저장이 되고 이 저장된 IP 데이터를 호스트에서 읽어 가 플레이하게 된다.As shown, MPE, MPE-FEC, and PSIP information of the datagram section structure are separated from the stream in the form of TS packets, and extracted as IP data from which the header and the CRC are removed from the section datagram. Extracting the IP data from the TS packet is all performed at the data link layer. The IP data in the data link layer is stored in a memory located inside or outside the data link layer through the RS decoder and the error interval is corrected, and the stored IP data is read from the host and played.

도 6은 MPE-FEC 프레임의 구조를 나타내는 것으로, MPE-FEC 프레임 구조는 255바이트로 이루어져 애플리케이션 데이터 테이블(application data table) 191바이트와 RS 데이터 테이블(data table) 64바이트로 이루어져 있다.FIG. 6 shows the structure of an MPE-FEC frame. The MPE-FEC frame structure consists of 255 bytes and consists of 191 bytes of an application data table and 64 bytes of an RS data table.

RS 디코딩을 위해서는 MPE data와 MPE-FEC data의 한 횡(row)이 필요하게 된다. 하지만 MPE와 MPE-FEC Section data payload는 세로 단위 즉, 종(column) 방향 단위로 연속적으로 기록이 되기 때문에 row 방향 단위로 순서대로 읽기 위해서는 넘버 오브 로우(no_of_row) 단위로 어드레스(Address)를 점프해가면서 읽어야 한다.RS decoding requires one row of MPE data and MPE-FEC data. However, since MPE and MPE-FEC Section data payloads are recorded continuously in vertical units, that is, column units, the addresses are jumped by number of row units to read them in order of row units. You should read as you go.

여기서 no_of_row는 DVB-H 스팩(spec)에서 256, 512, 768, 1024 4개로 정의하고 있으며, 각 no_of_row 단위로 자동으로 Address를 점프할 수 있도록 MAU가 설계되어 있다. 섹션 단위로 데이터가 들어올 때 MPE와 MPE-FEC의 Start Address, End Address, Start, End의 정보를 포함하고 있다. 섹션 구조를 파싱하여 Address를 MAU에게 알려주면, Start Address에서부터 시작하여 no_of_row 단위로 점프하여 데이터를 Read하고 Write 동작을 수행하게 된다. 전형적인 RS 디코더의 경우 32바이트의 심볼 오류를 정정하지만, 섹션 별로 CRC 체크(check)를 통해 오류 유무를 판단할 수 있는 DVB-H 데이터 링크 계층(data link layer)의 특성상 소거 RS 디코딩을 사용하여 한 개 횡(row)당 최대 64바이트의 오류를 정정할 수 있다.No_of_row is defined as four of 256, 512, 768, and 1024 in the DVB-H specification. The MAU is designed to automatically jump addresses in units of no_of_row. When the data is entered in the section unit, it includes the information of Start Address, End Address, Start, End of MPE and MPE-FEC. When parsing the section structure and telling the MAU the address, it starts with the Start Address and jumps to the no_of_row unit to read and write data. A typical RS decoder corrects for 32 bytes of symbol error, but due to the nature of the DVB-H data link layer, which can be determined by CRC check on a section-by-section basis, a clear RS decoding is used. Up to 64 bytes of error per row can be corrected.

이상, 전술한 본 발명의 바람직한 실시 예는 이상의 목적을 위해 개시된 것으로, 이러한 변경과 실시는 본 발명의 범위에 속하게 된다.Above, preferred embodiments of the present invention described above are disclosed for the above purposes, and such changes and implementations fall within the scope of the present invention.

이상에서 설명한 바와 같이 본 발명에 따른 디지털 방송 수신 시스템에서의 오류 정정 방법은 다음과 같은 효과가 있다.As described above, the error correction method in the digital broadcasting reception system according to the present invention has the following effects.

첫째는 소거 디코더(erasure decoder)를 사용하는 모든 방송 통신 시스템의하드웨어 복잡도 개선에 큰 도움을 줄 수 있고, 특히 다양한 송신 모드를 지원해야 하는 DVB-H 수신 시스템의 경우에 하드웨어 복잡도 개선에 큰 효과가 있다.First, it can greatly help to improve the hardware complexity of all broadcasting communication systems using erasure decoder. Especially, in the case of DVB-H reception system that needs to support various transmission modes, it has a great effect on hardware complexity improvement. have.

둘째는, IPDC(IP Data Casting)를 위해 도입되는 유사한 방송 수신 시스템의 데이터 링크 계층에 널리 적용 가능한 효과가 있다.Second, there is an effect that can be widely applied to the data link layer of a similar broadcast receiving system introduced for IPDC (IP Data Casting).

이상 설명한 내용을 통해 당업자라면 본 발명의 기술 사상을 이탈하지 아니하는 범위에서 다양한 변경 및 수정이 가능함을 알 수 있을 것이다.Those skilled in the art will appreciate that various changes and modifications can be made without departing from the spirit of the present invention.

따라서, 본 발명의 기술적 범위는 실시 예에 기재된 내용으로 한정되는 것이 아니라 특허 청구 범위에 의하여 정해져야 한다.Therefore, the technical scope of the present invention should not be limited to the contents described in the embodiments, but should be defined by the claims.

Claims (3)

디지털 방송 수신 시스템에서 소거 RS 디코딩을 수행하여 데이터의 오류를 정정하는 방법에 있어서,A method of correcting an error in data by performing erasing RS decoding in a digital broadcasting reception system, (a) 신드롬 다항식 및 소거 위치자 다항식을 계산하는 단계;(a) calculating a syndrome polynomial and an erase locator polynomial; (b) 상기 신드롬 다항식과 상기 소거 위치자 다항식을 곱셈 연산하여 구한 수정 신드롬 다항식을 2-메모리 회귀적(recursive) 연산하여 계산하는 단계; 및,(b) calculating a modified syndrome polynomial obtained by multiplying the syndrome polynomial and the erase locator polynomial by two-memory recursive calculation; And, (c) 상기 (b)단계에서 계산된 값으로 베레캄프 매세이(Berelekamp-Massey) 알고리즘 연산하여 데이터의 오류 정정을 수행하는 단계를 포함하여 이루어지는 것을 특징으로 하는 디지털 방송 수신 시스템에서의 오류 정정 방법.(c) performing a error correction of the data by performing a Berelekamp-Massey algorithm using the value calculated in step (b). . 제 1 항에 있어서,The method of claim 1, 상기 (b) 단계는Step (b) is 상기 신드롬 다항식과 상기 소거 위치자 다항식을 곱셈 연산하여 계산된 수정 신드롬의 각 차수항의 계수 값을 순차적으로 제 1 메모리(First MEM)에 저장하는 단계와Sequentially storing coefficient values of each order term of the modified syndrome calculated by multiplying the syndrome polynomial and the erase locator polynomial by a first memory; 상기 제 1 메모리에 저장된 수정 신드롬의 최고 차수항부터 바로 다음 차수항끼리 순차적으로 2바이트씩 XOR(Exclusive OR) 연산하고, 연산된 중간 값(intermediate value)을 제 2 메모리에 저장하는 단계와An XOR (Exclusive OR) operation of two bytes sequentially from the highest order term of the modified syndrome stored in the first memory, and storing the calculated intermediate value in the second memory; 상기 제 2 메모리에 저장된 중간 값의 최고 차수항부터 바로 다음 차수항까지 순차적으로 2바이트씩 XOR 연산하고, 연산된 중간 값을 제 1 메모리에 저장하는 단계로 이루어지는 것을 특징으로 하는 디지털 방송 수신 시스템에서의 오류 정정 방법.In the digital broadcast receiving system, the step of XOR operation by two bytes sequentially from the highest order term of the intermediate value stored in the second memory to the next order term, and storing the calculated intermediate value in the first memory Error correction method. 제 2 항에 있어서,The method of claim 2, 상기 XOR 연산된 중간 값을 저장하는 단계는 단방향으로 63회 반복하여 이루어지는 것을 특징으로 하는 디지털 방송 수신 시스템에서의 오류 정정 방법.And storing the intermediate value calculated by the XOR is repeated 63 times in a unidirectional direction.
KR1020060021326A 2006-03-07 2006-03-07 Error correction method in digital broadcasting receiving system KR100803129B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020060021326A KR100803129B1 (en) 2006-03-07 2006-03-07 Error correction method in digital broadcasting receiving system

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020060021326A KR100803129B1 (en) 2006-03-07 2006-03-07 Error correction method in digital broadcasting receiving system

Publications (2)

Publication Number Publication Date
KR20070091779A KR20070091779A (en) 2007-09-12
KR100803129B1 true KR100803129B1 (en) 2008-02-14

Family

ID=38689394

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020060021326A KR100803129B1 (en) 2006-03-07 2006-03-07 Error correction method in digital broadcasting receiving system

Country Status (1)

Country Link
KR (1) KR100803129B1 (en)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4868828A (en) * 1987-10-05 1989-09-19 California Institute Of Technology Architecture for time or transform domain decoding of reed-solomon codes
KR970017489A (en) * 1995-09-23 1997-04-30 김광호 RS decoder syndrome generator sharing circuit for inner code and sub code in digital VLC system
KR19980031644A (en) * 1996-10-31 1998-07-25 배순훈 Reed Solomon decoder for high-definition television
US6832042B1 (en) 2000-05-24 2004-12-14 Acer Laboratories Inc. Encoding and decoding system in an optical disk storage device

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4868828A (en) * 1987-10-05 1989-09-19 California Institute Of Technology Architecture for time or transform domain decoding of reed-solomon codes
KR970017489A (en) * 1995-09-23 1997-04-30 김광호 RS decoder syndrome generator sharing circuit for inner code and sub code in digital VLC system
KR19980031644A (en) * 1996-10-31 1998-07-25 배순훈 Reed Solomon decoder for high-definition television
US6832042B1 (en) 2000-05-24 2004-12-14 Acer Laboratories Inc. Encoding and decoding system in an optical disk storage device

Also Published As

Publication number Publication date
KR20070091779A (en) 2007-09-12

Similar Documents

Publication Publication Date Title
US7246294B2 (en) Method for iterative hard-decision forward error correction decoding
US7313583B2 (en) Galois field arithmetic unit for use within a processor
US7530007B2 (en) Iterative decoding of packet data
US7447980B2 (en) Error detection and correction in data transmission packets
KR20040075954A (en) Dual chien search blocks in an error-correcting decoder
US7941734B2 (en) Method and apparatus for decoding shortened BCH codes or reed-solomon codes
JP2006121686A (en) Method and device for effectively decoding low density parity check code
US8705669B2 (en) Low-latency viterbi survivor memory architecture and method using register exchange, trace-back, and trace-forward
US8397140B2 (en) Error correction coding for recovering multiple packets in a group view of limited bandwidth
US7403964B2 (en) Galois field multiplier array for use within a finite field arithmetic unit
KR20040075952A (en) Intra-decoder component block messaging
US6675340B1 (en) Forward error correction (FEC) for packetized data networks
US7231575B2 (en) Apparatus for iterative hard-decision forward error correction decoding
US7810015B2 (en) Decoding with a concatenated error correcting code
KR20040075953A (en) Chien search cell for an error-correcting decoder
JP2009509480A (en) Apparatus and method for error correction in mobile wireless applications incorporating erasure table data
JP3891568B2 (en) Method and apparatus for decoding error correction code
JP2001196938A (en) Device and method for decoding digital data
KR100803129B1 (en) Error correction method in digital broadcasting receiving system
JP2004007582A (en) Low-cost method and device for decoding product code
JP2002530002A (en) Fast precomputation circuit and method for finding error locator polynomial roots in Reed-Solomon decoder
US7840867B2 (en) Iterative n-dimensional decoding
US7254771B1 (en) Error-erasure decoding of interleaved reed-solomon code
KR100736620B1 (en) Error correction method in digital broadcasting receiver
JP2591332B2 (en) Error correction decoding device

Legal Events

Date Code Title Description
A201 Request for examination
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: 20101223

Year of fee payment: 4

LAPS Lapse due to unpaid annual fee