The present invention relates to a method of reducing the delay of encoding time by improving the degree of parallelism of encoding. In particular, the present invention relates to a method of introducing a plurality of parallel encoding processes for a Quasi-Cyclic low density parity-check code having a dual diagonal structure, and substantially matching the encoding time of an extended code with the encoding time of the base code without making the encoding time of the extended code increase linearly in accordance with the decrease in the coding rate.
In Recent years, radio communication systems have been developed to allow very high speed data transmission. Therefore, there is a demand for a more efficient encoding method than a conventional encoding method. LDPC (Low Density Parity-Check) codes are one class of strong forward error correcting codes which have attracted attention in recent ten years. LDPC codes, which have a very long codeword length, is approaching the Shannon limit, and is therefore considered as an effective alternative technique of turbo codes, and there is a high possibility that these LDPC codes are used for the next generation mobile communication and space communication.
LDPC codes are one of codes defined based on a parity cheek matrix, and was proposed by Gallager in 1962. Also, an LDPC code has characteristics of including a small number j (j≧1) of 1's in each column of a check matrix and a small number k (k>j) of 1's in each row of the check matrix. Gallager proved that the general minimum distance of a codeword, which was acquired by encoding information using that check matrix, increased linearly following the increase in the codeword length, and the general rate of decoding errors in a BSC (Binary Symmetric Channel) decreased on an exponential scale in accordance with the codeword length.
Also, in 1981, Tanner proposed a concept of illustrating a codeword using a diagram model and associated an LDPC code check matrix with a bipartite graph comprised of two bidirectional nodes formed with rows and columns of a check matrix, referred to as “Tanner graph,” In a Tanner graph, each check matrix row is referred to as “check node” and each check matrix column is referred to as “variable node.” The variable nodes and check nodes in a Tanner graph are connected according to the arrangement of 1's in the check matrix, and decoding processing is performed by iteratively executing information transmission between connected nodes. LDPC codes represented by a Tanner graph can parallelize decoding processing, thereby significantly reducing the complexity of decoding processing. Further, Tanner has analyzed two information transmission algorithms of the min-sum algorithm and sum-product algorithm in detail and proved the optimality of the min-sum decoding algorithm and sum-product decoding algorithm based on a Tanner graph having a finite length and no loop. However, the Tanner graph actually adopts a random graph structure and unavoidably has a loop of a short loop length (hereinafter “small loop”). An occurrence of such a short loop may cause overlapping transmission of decoding information, and, consequently, it is not possible to satisfy the presumption of independence between decoding information (e.g. messages) in iterative decoding process of LDPC coding, which gives a negative influence on the convergence performance of transmission decoding algorithms.
In 1996, Mackay and Spielman rediscovered that LDPC code provided performance as good as Turbo codes, and, when the codeword length was longer, provided better performance than Turbo code. By this means, LDPC codes became a new target of research and attracted wide attention.
Rechardson et al. started out with a study of a group of LDPC code structures that satisfy certain restriction, established the density evolution theory of infinite-length LDPC codes and provided important reference information to form finite-length LDPC codes. From this study, it was discovered that there was a threshold for decoding processing (i.e. decoding threshold) in the iterative transmission process of decoding information. To be more specific, Rechardson et al. discovered that it was possible to make the error rate of decoding information closer to zero by performing iterative decoding in the case where the signal to noise ratio was greater than a decoding threshold, and that, in the case where the signal to noise ratio was less than the decoding threshold, the error rate converged to a certain error rate, regardless of how long the codeword length of an adopted LDPC code was and how many times iterative decoding was performed. Also, Richardson et al. applied the central limit theorem and proved that the decoding threshold of a Tanner graph having a finite length, random graph structure and loop, were approximated to the decoding threshold of a Tanner graph having no loop. Accordingly, by accurately calculating the decoding threshold of LDPC code on a Tanner graph without loops based on the density evolution theory established on the Tanner graph without loops, and analyzing the convergence conditions of that decoding, it is possible to approximately estimate the performance of LDPC codes in a Tanner graph with a loop. Also, as proved by studies, the magnitude of decoding threshold closely relates to structure parameters of LDPC codes, an irregular LDPC code designed with optimal degree distribution can improve the decoding threshold, and therefore it is possible to use the density evolution theory to optimize LDPC code design.
An LDPC code configuration is based on two main rules for the purpose of removing small loops and allowing fast encoding.
One framework relates to an LDPC code configuration in which small loops are removed as much as possible based on an LDPC code having a random structure. Methods of forming that LDPC code include, for example, the progressive edge growth (“PEG”) method proposed by Hu Xiaoyu. This forming method is the method of preventing small loops as much as possible and increasing the loop length of loops in a Tanner graph of LDPC codes. An LDPC code formed by this method is suitable to a code having a random structure. Also, Tian Tao et al. proposed a Viterbi-like algorithm for selectively removing small loops, increasing the size of the stopping set and reducing the code error rate. The Viterbi-like algorithm analyzes the relationships between loops, stopping sets and their related columns in a check matrix (i.e. linear correlation columns) for LDPC codes, analyzes a coding performance restriction in the message transmission algorithm and measures the connection characteristics of a Tanner graph for the LDPC code by extrinsic message degree.
The other framework relates to a method of forming practical LDPC code, which has a certain algebraic structure and allows fast encoding, based on the algebraic theory. As a recent major achievement, there is finite geometric LDPC code based on a finite geometric structure. Finite geometric LDPC code removes loops with a loop length of 4 (i.e. loops of the shortest loop length) in a Tanner graph, so that it is possible to realize linear time encoding using a simple feedback shift register. Finite geometric LDPC code has a relatively good minimum distance. For example, in the case of a high coding rate and long codeword length (i.e. long code) in an AWGN (Additive White Gaussian Noise) communication path, the distance of the iterative decoding algorithm is only 0.4 dB from the Shannon limit.
Also, Tanner et al. designed a QC (Quasi-Cyclic) LDPC code. A QC LDPC code check matrix is formed with a cyclic matrix, which gives QC characteristics to the QC LDPC code, and therefore can realize effective encoding. Also, the algebraic structure of QC LDPC code is effective for realizing a VLSI circuit. Based on such characteristics, Tanner formed an LDPC convolutional code using a QC LDPC code cyclic matrix. A middle or short codeword length provides performance equivalent to regular codes having a random structure, and, a long codeword length (i.e. long code) provides performance slightly inferior to codes having a random structure.
With dramatic development of the LDPC code theory, process in practical use of LDPC codes is promoted. According to the IEEE 802.16e standard, which is a radio communication standard, an LDPC code is one of encoding modulation schemes combining encoding and modulation. Further, the IEEE802.16e standard adopts a QC LDPC code structure (with a codeword length from 576 to 2304 and a coding rate of 1/2, 2/3, 3/4 or 5/6) and divides multiplication of a large-size matrix into multiplication of small-size matrixes in parallel, thereby solving a problem of increasing the complexity of encoding of LDPC codes.
Also, encoded bits in an LDPC codeword provide different error protection characteristics. That is, encoded bits in an LDPC codeword provide different noise robustness capabilities. The currently proposed classification of LDPC encoded bits is performed based on the column degree of each encoded bit in an LDPC code check matrix. For example, Non-Patent Document 1 and Non-Patent Document 2 disclose documents relating to encoded bit classification.
Encoding is highly complex in LDPC codes. For example, the complexity of encoding increases in direct proportion to a square of the codeword length. Rechardson et al. proposed a method of dividing a check matrix into sub-matrixes to reduce the complexity of encoding. In the method of dividing a check matrix into sub-matrixes, first, a base matrix of in rows and n columns with a lower rank is defined. Further, by extending the base matrix using sub-matrixes of rank z×z upon actual encoding, a (m×z)×(n×z) check matrix (hereinafter “extended matrix”) used upon actual encoding is acquired. Each element of the base matrix is formed with a z×z sub-matrix. By extending the same base matrix according to the magnitude of z, it is possible to acquire a pair of LDPC codes having the same coding rate and different codeword lengths. Here, element “0” represents a z×z all-zero sub-matrix, other elements represent a sub-matrix acquired by cyclically shifting the columns of the z×z identity matrix based on the value indicated by {p(f, i, j)}. The value of z is equivalent to extended element zf, (fε[0, 18]) defined in the standard. Element “1” in the matrix represents the identity matrix that is not subject to cyclic shifting, and other cyclically shifted values {p(f, i, j)} are calculated according to following equation 1 using equivalent extended element zf and elements that are not “0” or “1” in the matrix (e.g. see Non-Patent Document 3).
As described above, according to the values of z, it is possible to acquire one systematic codeword of a discrete codeword length. The elements of the first to fourth columns in
Also, rate matching methods, which are usually used upon designing an LDPC code, include “shortening,” “puncturing” and “extension” of a cheek matrix. According to IEEE802.16, different check matrixes arc used for different coding rates without using the above-noted three rate matching methods, and, consequently, a problem arises that the flexibility of rate matching lacks. Therefore, with 3GPP LTE (3rd Generation Partnership Project Long Term Evolution), studies were conducted to perform rate matching by shortening and puncturing instead of providing different check matrixes for different coding rates. Of the three types of rate matching methods, the two types of rate matching methods of shortening and extension are methods for reducing the coding rate of a codeword, and puncturing is a method for increasing the coding rate of a codeword.
The rate matching by shortening is a method for adding some 0's (i.e. the “0” bits) to the head of information and performing encoding using the original check matrix (i.e. base matrix). Upon transmitting a codeword, the “0” bits added to perform rate matching are not transmitted.
With the rate matching by puncturing, by not transmitting part of the parity bits in a codeword acquired by encoding, the coding rate of transmission bits is increased.
With the rate matching by extension, parity bits are increased to change the original check matrix (i.e. base matrix) to decrease the coding rate.
Here, upon using an LDPC code acquired by encoding with a base matrix as a base code and adopting the base code of a medium coding rate, it is possible to increase the coding rate by puncturing and decrease the coding rate by shortening or extension. According to an existing result, upon using an LDPC code of a coding rate of 1/2 as a base code and decreasing the coding rate to 1/3 by shortening, the systematic bits are removed, and, consequently, the performance is inferior to Turbo codes under the same conditions. Therefore, upon rate matching from a medium coding rate to a lower coding rate, the method of adding parity bits to the base code by extension is effective.
Also, a base code has a dual diagonal structure and a QC structure. For example, assume that the base code adopts the configuration shown in
Non-Patent Document 2: Rahnavard, N., Fekri, F. “Unequal error protection using low-density parity-check codes”, 2004, “International Symposium on Information Theory 2004. Proceedings. 27 June-2 Jul. 2004 Page(s):449”
Non-Patent Document 3: IEEE Std. 802.16e—2005
An LDPC code adopts a recursive scheme for encoding processing. For example, after the parity bit corresponding to the j-th column is calculated, it is possible to start the calculation of the parity bit corresponding to the (j+1)-th column. Therefore, parity bits are increased by extension, and, consequently, the time required for encoding processing (i.e. encoding time) increases. Thus, the encoding time increased based on recursive encoding, that is, delay time increases in direct proportion to the increase of parity bits by extension.
It is therefore an object of the present invention to provide an encoding method and transmitting apparatus for reducing delay due to the increase in encoding time by improving the degree of parallel encoding of a QC LDPC code having a dual diagonal structure (i.e. zig-zag structure), substantially matching the encoding time of an extended LDPC code with the encoding time of the base code, and thereby solving a problem of increasing encoding time linearly in accordance with the decrease in the coding rate.
The encoding method according to an aspect of the present invention includes the steps of: extending a dual diagonal structure of a base matrix of m rows and n columns along a dual diagonal, based on a coding rate 1/k of an extended code (where k=3, 4, 5, . . . , k0 holds, and where 1/k0 is a minimum coding rate of the extended code) set in a check matrix of a low density parity check code, to form an extended matrix having the dual diagonal structure; shifting a first non-zero element of a parity bit part in a (i*m+1)-th (where i=1, 2, . . . , k0−2) row leftward to a (n−m+1)-th column along that row; calculating a parity bit in the (n−m+1)-th column using a first check relationship as a key factor; and calculating parity bits in a plurality of groups simultaneously in parallel by a recursive encoding method, based on check relationships of the non-zero elements shifted leftward to the (n−m+1)-th column.
The transmitting apparatus according to an aspect of the present invention employs a configuration having: an encoding section that performs low density parity check encoding of transmission data using a check matrix of a low density parity check code, to acquire a codeword comprised of systematic bits and parity bits; and a transmitting section that transmits the codeword, where the encoding section includes: extending a dual diagonal structure of a base matrix of m rows and n columns along a dual diagonal, based on a coding rate 1/k of an extended code (where k=3, 4, 5, . . . , k0 holds and 1/k0 is a minimum coding rate of the extended code) set in the check matrix of the low density parity check code, to form an extended matrix having the dual diagonal structure; shifting a first non-zero element of a parity bit part in a (i*m+1)-th (where i=1, 2, . . . , k0−2) row leftward to a (n−m+1)-th column along that row; calculating a parity bit in the (n−m+1)-th column using a first check relationship as a key factor; and calculating parity bits in a plurality of groups simultaneously in parallel by a recursive encoding method, based on check relationships of the non-zero elements shifted leftward to the (n−m+1)-th column.
According to the present invention, by introducing a plurality of encoding processes in parallel for an LDPC code having a dual diagonal structure, it is possible to change the structure of an extended matrix and calculate parity bits in a plurality of groups at the same time. Therefore, it is possible to substantially match the eventual encoding time with the encoding time of the base code before extension. Also, the advantage provided by the extension method of the present invention becomes significant in accordance with the decrease in the coding rate.
An embodiment of the present invention will be explained below in detail with reference to the accompanying drawings. Here, in the following explanation, the processing and functions of unnecessary parts, which are not closely related to the present invention, will be omitted to avoid complicated explanation of the present invention.
In transmitting apparatus 100, LDPC encoding section 101 receives as input transmission data. LDPC encoding section 101 performs LDPC encoding of the transmission data using an LDPC code check matrix, to acquire an LDPC codeword comprised of systematic bits and parity bits. Further, LDPC encoding section 101 outputs an encoded bit sequence (i.e. an LDPC encoded bit sequence) extracted from the LDPC codeword according to a coding rate received as input from control section 109, and outputs the encoded bit sequence to modulating section 102. The encoding method in LDPC encoding section 101 will be described later in detail.
Modulating section 102 generates a data symbol by modulating the LDPC encoded bit sequence received as input from LDPC encoding section 101, based on the modulation scheme of an M-ary modulation number received as input from control section 109, and outputs the data symbol to multiplexing section 103.
Multiplexing section 103 multiplexes a pilot signal, the data symbol received as input from modulating section 102 and a control signal received as input from control section 109, and outputs the generated, multiplexed signal to radio transmitting section 104.
Radio transmitting section 104 performs transmission processing such as D/A conversion, amplification and up-conversion on the multiplexed signal, and transmits the result from antenna 105 to receiving apparatus 200. By this means, an LDPC codeword is transmitted to receiving apparatus 200.
On the other hand, radio receiving section 106 receives a control signal transmitted from receiving apparatus 200, via antenna 105, performs reception processing such as down-conversion and A/D conversion on the control signal, and outputs the result to demodulating section 107. This control signal includes a CQI (Channel Quality Indicator) generated in receiving apparatus 200 and ACK/NACK signal. Here, the CQI reported from receiving apparatus 200 may be the average SINR, average SIR or MCS parameters.
Demodulating section 107 demodulates and outputs the control signal to decoding section 108.
Decoding section 108 decodes the control signal and outputs the CQI and ACK/NACK information included in that control signal, to control section 109.
Control section 109 determines the coding rate and M-ary modulation number matching the CQI received as input, and outputs a control signal indicating the determined coding rate and M-ary modulation number, to LDPC encoding section 101, modulating section 102 and multiplexing section 103. Further, control section 109 controls retransmission of transmission data based on an ACK/NACK signal received as input.
Next, a receiving apparatus according to an embodiment of the present invention will be explained.
In receiving apparatus 200, radio receiving section 202 receives a multiplexed signal transmitted from transmitting apparatus 100 (in
Demultiplexing section 203 demultiplexes the data signal into the data symbol and control signal. Further, demultiplexing section 203 outputs the data symbol to demodulating section 204 and outputs the control signal to LDPC decoding section 205.
Demodulating section 204 acquires received data by demodulating the data symbol, and outputs the received data to LDPC decoding section 205.
LDPC decoding section 205 performs LDPC decoding of the data received as input from demodulating section 204, based on the coding rate indicated by the control signal received as input from demultiplexing section 203, to acquire received data. Further, LDPC decoding section 205 performs an error detection of the received data and performs an ACK/NACK detection. Further, LDPC decoding section 205 outputs an ACK/NACK signal as a result of the ACK/NACK detection, to feedback information generating section 207.
On the other hand, channel quality estimating section 206 estimates channel quality (SINR) using the pilot signal received as input from radio receiving section 202. Further, channel quality estimating section 206 outputs the estimated SINR estimation value to feedback information generating section 207.
Feedback information generating section 207 generates a CQI matching the SINR estimation value received as input. Further, feedback information generating section 207 generates a frame for feedback information including the generated CQI and ACK/NACK signal received as input from decoding section 205. Further, feedback information generating section 207 outputs the feedback information to encoding section 208.
Encoding section 208 encodes and outputs the feedback information to modulating section 209.
Modulating section 209 generates a control signal by modulating the feedback information, and outputs the control signal to radio transmitting section 210.
Radio transmitting section 210 performs transmission processing such as D/A conversion, amplification and up-conversion on the control signal, and transmits the result from antenna 201 to transmitting apparatus 100 (in
Here, the transmitting section of receiving apparatus 200 (formed with encoding section 208, modulating section 209 and radio transmitting section 210) may employ the same configuration as the transmitting section of transmitting apparatus 100, or employ an arbitrary configuration.
Next, the encoding method in LDPC encoding section 101 (in
Here, to extend the base matrix, first, LDPC encoding section 101 of transmitting apparatus 100, which makes possible the encoding method of the present invention, sets the coding rate of a code after extension (i.e. extended code) to 1/k (K=3, 4, 5, . . . , k0). Here, 1/k0 is the minimum coding rate of an extended code. Further, LDPC encoding section 101 forms an extended matrix having a dual diagonal structure by extending the base matrix according to the following method. To be more specific, first, LDPC encoding section 101 directly extends the dual diagonal structure of the base matrix shown in
Here, in the encoding process of the base code, first, a calculation is performed in the (n−m+1)-th column. Further, after the calculation in the (n−m+1)-th column, calculations are performed sequentially and recursively in the subsequent columns, that is, from the (n−m+2)-th to n-th columns. Thus, in the case where the base code is extended in LDPC encoding section 101 based on the encoding method of the present embodiment, first, sonic non-zero elements on the dual diagonal are shifted to the (n−m+1)-th column in which a calculation was performed. By this means, first, LDPC encoding section 101 calculates the parity bit in the (n−m+1)-th column using the rows in which non-zero elements including the shifted non-zero elements are arranged in the (n−m+1)-th column. Next, using the elements in the (n−m+1)-th column, LDPC encoding section 101 performs a calculation in the (n−m+2)-th column and the (n−m+1+j*m)-th column (where j=1, 2, . . . , k0−2) at the same time. Further, using the (n−m+1+j*m)-th column, LDPC encoding section 101 calculates the parity bits in other columns by the recursive encoding scheme in specific ranges.
To be more specific, as shown in
Next, LDPC encoding section 101 sequentially calculates parity bits according to the recursive scheme. To be more specific, in the first time unit, LDPC encoding section 101 calculates the parity bits in the seventh (=n−m+1) column based on the relationships between the elements in the first row and other elements in the check matrix (i.e. check relationship). That is, the parity bits in the seventh (=n−m+1) column are calculated using the check relationship of the elements in the first row (in this case, the first check relationship) as key factors. Here, LDPC encoding section 101 can further acquire the element in the second row, seventh column, by utilizing the characteristics of the dual diagonal structure.
Next, calculating the parity bits in the seventh column in the first time unit gives in advance the elements in the second, seventh and thirteenth rows in the seventh column, so that, in the second time unit, LDPC encoding section 101 simultaneously calculates the parity bits in a plurality of groups (i.e. in the (n−m+2)-th column and the (n−m+1+j*m)-th column) in parallel, based on the check relationships of the non-zero elements in the seventh column. To be more specific, in the second time unit, LDPC encoding section 101 calculates the parity bit in the eighth column using the second row, calculates the parity bit in the thirteenth column using the seventh row and calculates the parity bit in the nineteenth column using the thirteenth row. Also, LDPC encoding section 101 acquires the elements in the third row, eighth column, the eight row, thirteenth column and the fourteenth row, nineteenth column, by utilizing the characteristics of the dual diagonal structure.
Similarly, the elements in the third row, eighth column, the eighth row, thirteenth column and the fourteenth row, nineteenth column are already calculated in the second time unit, so that, in the third time unit, LDPC encoding section 101 simultaneously calculates the parity bits in a plurality of groups in parallel, based on the check relationships of those elements. To be more specific, in the third time unit, LDPC encoding section 101 calculates the parity hit in the ninth column using the third row, calculates the parity bit in the fourteenth column using the eight row and calculates the parity bit in the twentieth column using the fourteenth row. Also, LDPC encoding section 101 acquires the parity bits in the fourth row, ninth column, the ninth row, fourteenth column and the fifteenth row, twentieth column, by utilizing the characteristics of the dual diagonal structure. Afterward, LDPC encoding section 101 sequentially performs the same processing until the parity bits in the tenth to twelfth columns, fifteenth to eighteenth columns and twenty-first to twenty-fourth columns are calculated.
Also, an LDPC code according to the present invention adopts a QC structure, and therefore the elements of the check matrix are each represented by one submatrix. To be more specific, 0's in
Further, using the extended matrix shown in
Also, instead of using a QC LDPC code having the above dual diagonal structure as a base code, by using an LDPC code having a structure with bidirectional encoding performance (e.g, the encoding structure in the IEEE802.16e standard) as a base code and realizing bidirectional encoding in parallel, it is possible to further shorten the encoding time (i.e. delay time). In this case, LDPC encoding section 101 needs to adjust the extended structure slightly.
The encoding process of bidirectional encoding will be explained using
Thus, LDPC encoding section 101 of transmitting apparatus 100 changes the dual diagonal structure as shown in
Thus, according to the present invention, by introducing a plurality of encoding processes in parallel for an LDPC code having a dual diagonal structure, the transmitting apparatus can change the structure of an extended matrix and calculate parity bits in a plurality of groups at the same time. Further, by performing a plurality of encoding processes in parallel in the transmitting apparatus, it is possible to shorten the encoding time. To be more specific, it is possible to substantially match the final encoding time with the encoding time of the base code before extension. Also, the advantage provided by this extension method becomes significant in accordance with the decrease of the coding rate.
The present invention has been described above with the best mode for carrying out the present invention. Here, it is obvious for a skilled person that other various changes, replacement and addition are possible without deviating from the spirit and scope of the present invention. Accordingly, the scope of the present invention should not be understood to be limited only by the above specific embodiment, and is limited by the accompanying claims.
The disclosure of Chinese Patent Application No. 200710186026.X, filed on Nov. 9, 2007, including the specification, drawings and abstract, is incorporated herein by reference in its entirety.
The encoding method and transmitting apparatus according to the present invention are applicable for use such as mobile communication systems and space communication.
Number | Date | Country | Kind |
---|---|---|---|
200710186026.X | Nov 2007 | CN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2008/003240 | 11/7/2008 | WO | 00 | 5/6/2010 |