This application claims priority under 35 U.S.C. §119(a) to a Korean Patent Application filed in the Korean Intellectual Property Office on Apr. 20, 2007 and assigned Serial No. 2007-38599, the disclosure of which is incorporated herein by reference.
1. Field of the Invention
The present invention relates generally to a communication system, and in particular, to an apparatus and method for encoding Low Density Parity Check (LDPC) codes in a communication system.
2. Description of the Related Art
The next generation communication system is developed to support high-speed, high-capacity data transmission/reception for Mobile Stations (MSs). Particularly, in the next generation communication system, various schemes such as Hybrid Automatic Repeat reQuest (HARQ) and Adaptive Modulation and Coding (AMC) have been proposed for support of high-speed, high-capacity data transmission/reception, and the communication system should support various coding rates to use the HARQ and AMC schemes.
In addition, the next generation communication system considers using LDPC codes as well as turbo codes. LDPC codes are known to show high performance gain during high-speed data transmission, and can effectively correct errors caused by noises generated in a transmission channel, thereby contributing to an increase in reliability of data transmission. LDPC codes can be classified into Repeat Accumulate (RA) codes and Concatenated ZigZag (CZZ) codes. The RA codes are subclassified into regular RA codes and irregular RA codes, and the CZZ codes are subclassified into regular CZZ codes and irregular CZZ codes.
As described above, to use the HARQ and AMC schemes, the communication system should support various coding rates. There are various proposed schemes for supporting the various coding rates, and the typical one of the schemes is a puncturing scheme of supporting various coding rates using one catch-all codeword.
However, when the communication system using LDPC codes supports various coding rates using the puncturing scheme, an increase in puncturing rate causes degradation in performance of the LDPC codes. This is because the cycle structure on a Tanner graph of the LDPC code changes due to the use of the puncturing scheme. The term ‘cycle’ as used herein refers to a loop formed by edges connecting information nodes to check nodes in the Tanner graph of the LDPC code, and a length of the cycle is defined as the number of edges constituting the loop.
Therefore, there is a need for a Low Density Parity Check (LDPC) code encoding scheme for preventing performance degradation while using the puncturing scheme.
An aspect of the present invention is to address at least the problems and/or disadvantages identified above and to provide at least the advantages described below. Accordingly, an aspect of the present invention is to provide an apparatus and method for encoding LDPC codes in a communication system.
Another aspect of the present invention is to provide an apparatus and method for encoding LDPC codes in a communication system using a puncturing scheme.
According to one aspect of the present invention, there is provided an encoding apparatus of a Low Density Parity Check (LDPC) code for a communication system. The apparatus includes an LDPC code encoder for receiving information bits, and generating an LDPC code by encoding the information bits using an interleaving scheme, wherein the interleaving scheme is generated such that when the LDPC code is punctured, there is no short-length cycle in a Tanner graph of the punctured LDPC code.
According to another aspect of the present invention, there is provided a method for encoding a Low Density Parity Check (LDPC) code in an encoding apparatus of an LDPC code for a communication system. The method includes receiving information bits; and generating an LDPC code by encoding the information bits using an interleaving scheme; wherein the interleaving scheme is generated such that when the LDPC code is punctured, there is no short-length cycle in a Tanner graph of the punctured LDPC code.
The above and other aspects, features and advantages of the present invention will become more apparent from the following detailed description when taken in conjunction with the accompanying drawings in which:
Preferred embodiments of the present invention will now be described in detail with reference to the annexed drawings. In the following description, detailed description of known functions and configurations incorporated herein has been omitted for clarity and conciseness.
The present invention provides an apparatus and method for encoding Low Density Parity Check (LDPC) codes in a communication system. In particular, the present invention provides an apparatus and method for encoding LDPC codes taking into account the possible use of a puncturing scheme in a communication system. The LDPC codes can be classified into Repeat Accumulate (RA) codes and Concatenated ZigZag (CZZ) codes. The RA codes are subclassified into regular RA codes and irregular RA codes, and the CZZ codes are subclassified into regular CZZ codes and irregular CZZ codes. Although the apparatus and method for encoding LDPC codes will be described herein with reference to the regular RA codes, the irregular RA codes, the regular CZZ codes and the irregular CZZ codes, by way of example, the LDPC encoding apparatus and method proposed by the present invention can be applied to other codes as well as the regular RA codes, the irregular RA codes, the regular CZZ codes and the irregular CZZ codes.
Before a description of
Referring to
Therefore, when a signal reception apparatus decodes a punctured RA code transmitted by a signal transmission apparatus, the signal reception apparatus can decode the punctured RA code using the check node-merged Tanner graph rather than the Tanner graph of the punctured RA code. The use of the check node-merged Tanner graph instead of the Tanner graph of the punctured RA code for decoding of the punctured RA code increases the convergence rate of decoding and decreases the number of calculations, contributing to a reduction in the entire decoding complexity of the signal reception apparatus.
It is assumed in
A description will now be made of a cycle structure of punctured regular RA code, irregular RA code, regular CZZ code, and irregular CZZ code.
With reference to
Before a description of
Referring to
A description will now be made of a length-6 cycle structure of the punctured RA code. For convenience, to calculate the absolute value of π(x)−π(y), the π(x) and π(y) are regarded as normal integers, even though π(x) and π(y) are calculated by a modulo-qL operation.
(1) Length-2 Cycle Structure
The necessary condition for the existence of a length-2 cycle structure in the Tanner graph of the punctured RA code can be expressed as Equation (1).
|π(x)−π(y)|<d (1)
In Equation (1), nq≦x≠y<(n+1)q for nε{0, 1, . . . , L−1}
(2) Length-4 Cycle Structure
A length-4 cycle structure in the Tanner graph of the punctured RA code is roughly classified into two types: Type-I and Type-II, and the necessary condition for existence of the length-4 cycle structure can be expressed as Equation (2).
Type-I: |π(x)−π(y)|d and |π(x′)−π(y′)|<d,
Type-II: |π(x)−π(x′)|<2d (2)
In Equation (2), nq≦x≠x′<(n+1)q and mq≦y≠y′<(m+1)q for n≠mε{0, 1, . . . , L−1}.
(3) Length-6 Cycle Structure
A length-6 cycle structure in the Tanner graph of the punctured RA code is roughly classified into three types: Type-I, Type-II and Type-III, and the necessary condition for existence of the length-6 cycle structure can be expressed as Equation (3).
Type-I: |π(x)−π(y)|<d, |π(y)−π(z)|<d, and |π(z)−π(x)|<d,
Type-II: |π(x)−π(y)|<d and |π(x′)−π(y′)|<2d,
Type-III: |π(x)−π(x′)|<3d (3)
In Equation (3), nq≦x≠x′<(n+1)q, mq≦y≠y′<(m+1)q and kq≦z<(k+1)q for n≠m≠kε{0, 1, . . . , L−1}.
With reference to
Before a description of
Referring to
A description will now be made of a length-6 cycle structure of the CZZ code.
For the CZZ code, there is no parallel edge between information nodes and check nodes. Therefore, for a punctured CZZ code, there is no length-2 cycle in its Tanner graph.
(1) Length-4 Cycle Structure
The necessary condition for existence of a length-4 cycle structure in the Tanner graph of the punctured CZZ code can be expressed as Equation (4).
|πi(x)−πi(y)|<d and |πj(x)−πj(y)|<d (4)
In Equation (4), i≠j and x≠yε{0, 1, . . . , L−1}.
(2) Length-6 Cycle Structure
A length-6 cycle structure in the Tanner graph of the punctured CZZ code is roughly classified into two types: Type-I and Type-II, and the necessary condition for existence of the length-6 cycle structure can be expressed as Equation (5).
Type I: |πi(x)−πi(y)|<d, |πj(y)−πj(z)|<d, and |πk(x)−πk(z)|<d,
Type II: |πi(x)−πi(y)|<2d and |πj(x)−πj(y)|<d (5)
In Equation (5), i≠j≠k and x≠y≠zε{0, 1, . . . , L−1}.
An interleaver serves as an important factor for determining performance of the LDPC code. Therefore, an embodiment of the present invention will design a polynomial interleaver that can remove short-length cycles from a Tanner graph of a finite-length RA LDPC code punctured using Theorem 1-1, Theorem 1-2 and Theorem 2.
Theorem 1-1
The necessary and sufficient conditions in which a polynomial π(x) is a degree-k permutation polynomial over an integer ring Zp″ are satisfied when the polynomial π(x) is a permutation polynomial over Z(p) and π′(x)≠0 mod p for all integers xεZp″.
Theorem 1-2
The necessary and sufficient conditions in which a polynomial π(x) is a permutation polynomial over modulo N for any integer N=Πi=1mpin
Theorem 2
If d>1 is a divisor of k−1, there is no degree-d permutation polynomial π(x).
For convenience, it is assumed herein that N=qL.
A description will first be made of an operation of designing interleavers of a punctured regular RA code and a punctured irregular. RA code.
Assume that N=qL, where L=pn and p denotes a prime number. Then, it is possible to design a length-N polynomial interleaver for a (q×pn,pn)-RA code using Theorem 1-1 and Theorem 1-2. Fact 1 below indicates Theorem 1-1 and Theorem 1-2 for p=2 and q=2m.
Fact 1
For a (2m×2n,2n)-RA code, π(x)=akxk+ak−1xk−1+ . . . +a1x+a0 mod (2m×2n) can be an interleaver if ak≠0, a1 is odd, a2+a4+ . . . is even, and a3+a5+ . . . is even.
Using Fact 1, an interleaver of a RA code can be designed as follows.
(1) If there is no solution to Equation (1), the interleaver π can avoid length-2 cycles.
(2) If there is no common solution to Equation (2), the interleaver π can avoid Type-I and Type-II length-4 cycles.
(3) If there is no common solution to Equation (3), the interleaver π can avoid Type-I, Type-II and Type-III length-6 cycles.
In order to remove length-2 cycles in a Tanner graph of a punctured RA code, assuming that Λ={|π(i)−π(j)∥x≦i≠j≦x+q−1, xε{0, q, . . . , (L−1)×q}}, an interleaver π is designed such that there is no solution to Equation (1). That is, length-2 cycles are removed when the interleaver π is designed such that Λ∩{1, 2, . . . , d−1}=φ.
When interleavers of a punctured regular RA code and a punctured irregular RA code are designed in the foregoing manner, the length-2, length-4 and length-6 cycles can be removed.
A description will now be made of an operation of designing interleavers of a punctured regular CZZ code and a punctured irregular CZZ code.
Fact 2 is defined as follows.
Fact 2
πi(x)=akxk+ak−1xk−1+ . . . +a1x+a0 mod L (where 1≦i≦Nc) can be an interleaver for a CZZ code when πi(x) is a permutation polynomial modulo L for all i.
Using Fact 2, an interleaver of a CZZ code can be designed as follows.
(1) If there is no common solution to Equation (4) for all i≠j, π0, π1, . . . , πN
(2) If there is no common solution to Equation (5) for all i≠j≠k, π0, π1, . . . , πN
In order to remove length-4 cycles in the Tanner graph of the punctured CZZ code, assume that Λi={|πi(x)−πi(y)∥0≦x≠y<L} and Λj={|πj(x)−πj(y)∥0≦x≠y<L}. Thereafter, an interleaver πi and an interleaver πj are designed such that there are solutions to Equation (4). That is, the length-4 cycles are removed when the interleaver πi and the interleaver πj are designed such that Λi and Λj are disjointed for the same pair (x,y).
When interleavers of the punctured regular CZZ code and the punctured irregular CZZ code are designed in the foregoing manner, the length-4 and length-6 cycles can be removed.
With reference to
Before a description of
In addition, when degree-2 polynomial interleavers are used for the (4096,1024)-RA code, first punctured RA code, second punctured RA code and third punctured RA code, lengths of the cycles included in Tanner graphs of the corresponding codes are shown in Table 1.
In Table 1, ‘Rate’ indicates coding rates, and R1, R2 and R3 indicate degree-2 polynomial interleavers. As shown in Table 1, even though any degree-2 polynomial interleaver is used for the (4096,1024)-RA code of coding rate 5/1, a girth included in the Tanner graph is 10. Herein, the girth indicates the minimum cycle length. Unlike this, for the first punctured RA code, second punctured RA code and third punctured RA code, the girth included in the corresponding Tanner graph can be 2, 4 or 6 according to the type of the degree-2 polynomial interleaver. That is, when degree-2 polynomial interleavers R2 and R3 are used for the first punctured RA code, the girth included in the Tanner graph is 6; when a degree-2 polynomial interleaver R3 is used for the second punctured RA code, the girth included in the Tanner graph is 4; and when a degree-2 polynomial interleaver R3 is used for the third punctured RA code, the girth included in the Tanner graph is 2.
Assume that Binary Phase Shift Keying (BPSK) is used as a modulation scheme, a Brief-Propagation (BP) algorithm is used, a maximum of 30 repetitions is used, and an Additive White Gaussian Noise (AWGN) channel environment is used.
In this case, as shown in
With reference to
Before a description of
In addition, when degree-1 polynomial interleavers are used for the (4,3)-CZZ code, first punctured CZZ code, second punctured CZZ code and third punctured CZZ code, lengths of cycles included in Tanner graphs of the corresponding codes are shown in Table 2.
In Table 2, ‘Rate’ indicates coding rates, and C1, C2 and C3 indicate degree-I polynomial interleavers. As shown in Table 2, even though any degree-1 polynomial interleaver is used for the (4,3)-CZZ code of coding rate 5/1, the girth included in the Tanner graph is 10. Unlike this, for first punctured CZZ code, second punctured CZZ code and third punctured CZZ code, the girth included in the corresponding Tanner graph can be 6 or 4 according to the type of the degree-1 polynomial interleaver. That is, when the degree-1 polynomial interleaver C3 is used for the first punctured CZZ code, the girth included in the Tanner graph is 6; when the degree-1 polynomial interleaver C3 is used for the second punctured CZZ code, the girth included in the Tanner graph is 4; and when the degree-1 polynomial interleaver R3 is used for the third punctured CZZ code, the girth included in the Tanner graph is 4.
Similarly, assume that BPSK is used as a modulation scheme, a BP algorithm is used, a maximum of 30 repetitions is used, and an AWGN channel environment is used.
In this case, as shown in
A description has been made of an operation of designing interleavers such that there is no short-length cycle in the Tanner graphs of the punctured RA code and the punctured CZZ code. The performance is optimized by designing interleavers in the foregoing manner, encoding RA codes and CZZ codes with the designed interleavers, and decoding the RA codes and CZZ codes according thereto.
With reference to
Referring to
With reference to
Referring to
Input length-L information bits are intactly generated as an information vector I, and are also input to each of the Nc interleavers. Each of the Nc interleavers interleaves the length-L information bits according to a predetermined interleaving scheme, and outputs the interleaving result to its associated zigzag encoder. Herein, the Nc interleavers each are designed in the manner described with reference to
Each of the Nc zigzag encoders encodes the signal output from its associated interleaver using a zigzag coding scheme, and outputs a parity vector. Herein, a parity vector output from the zigzag encoder #1713-1 is a parity vector #1 P1, a parity vector output from the zigzag encoder #2713-2 is a parity vector #2 P2, and a parity vector output from the zigzag encoder #NC 713-NC is a parity vector #NC PN
As is apparent from the foregoing description, the present invention designs interleavers taking into account the possible use of the puncturing scheme in the communication system, thereby avoiding existence of short-length cycles in the Tanner graph of the punctured LDPC code. As a result, the present invention designs interleavers such that there is no short-length cycle in the Tanner graph, thereby contributing to an increase in performance of the punctured LDPC codes.
While the invention has been shown and described with reference to a certain preferred embodiment thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention as further defined by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2007-0038599 | Apr 2007 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
6633856 | Richardson et al. | Oct 2003 | B2 |
6789227 | De Souza et al. | Sep 2004 | B2 |
6895547 | Eleftheriou et al. | May 2005 | B2 |
7502987 | Kyung et al. | Mar 2009 | B2 |
7523375 | Spencer | Apr 2009 | B2 |
20030014718 | De Souza et al. | Jan 2003 | A1 |
20040034828 | Hocevar | Feb 2004 | A1 |
20050229091 | Narayanan et al. | Oct 2005 | A1 |
Number | Date | Country |
---|---|---|
1020050118056 | Dec 2005 | KR |
1020050119596 | Dec 2005 | KR |
Number | Date | Country | |
---|---|---|---|
20080270872 A1 | Oct 2008 | US |