US 7661037 B2 Abstract Improved LDPC code structure and concatenation rules for IEEE 802.11n systems, providing two code sets per rate, one longer codeword and one shorter codeword. The longer codeword length is determined by the system parameters, while the shorter codeword length is ⅓ of the longer codeword length. A LDPC concatenation rule is provided, wherein a maximum of one extra OFDM symbol is added in padding in order to reduce the code set granularity. In order to provide improved code performance, more bits are shortened compared with puncturing, by transmitting the extra OFDM symbol. Further, all the required puncturing and shortening bits are distributed across all codewords. This scheme provides a preferred tradeoff between code complexity and over-the-air efficiency.
Claims(20) 1. In a wireless communication system, an encoding method for coding data for transmission, comprising the steps of:
encoding the data into Low Density Parity Check (LDPC) codewords using LDPC code sets including codewords,
adding padding bits by concatenating a maximum of one additional OFDM symbol to a codeword, thereby minimizing code set granularity; and
distributing all required puncturing and shortening bit positions across all codewords, for tradeoff between code complexity and over-the-air efficiency, wherein, and the codewords are punctured shortened LDPC codewords.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
obtaining the packet length;
selecting an LDPC code length as a function of the packet length;
if the transmission rate is higher than the threshold, then performing shortening and puncturing before padding,
otherwise, performing shortening only.
10. The method of
11. The method of
12. The method of
selecting the threshold such that when the transmission rate is above the threshold, then applying shortening and puncturing with one OFDM symbol added, while when the transmission rate is lower than the threshold applying shortening-only.
13. The method of
for a short packet length, selecting the shorter code set,
for a long packet length, selecting the longer code set.
14. The method of
for a short packet length, selecting a 576 length code set,
for a long packet length, selecting a 1728 length code set.
15. The method of
16. The method of
17. A transmitter in a wireless communication system comprising:
an encoder configured to encode data into Low Density Parity Check (LDPC) codewords using LDPC code sets including codewords, and to add padding bits by concatenating a maximum of one additional OFDM symbol to a codeword, thereby minimizing code set granularity, upon a transmission rate exceeding a threshold;
a shortening unit configured to shorten the code words; and
a puncturer configured to puncture the LDPC code words,
wherein more bits are shortened than punctured such that the shortening to puncturing ratio is high enough to prevent coding gain loss.
18. A wireless communication system comprising:
a shortening unit configured to shorten codewords;
an encoder configured to encode data into Low Density Parity Check (LDPC) codewords using LDPC code sets including codewords, and to add padding bits by concatenating a maximum of one additional OFDM symbol to a codeword, thereby minimizing code set granularity, upon a transmission rate exceeding a threshold; and
a puncturer configured to puncture the LDPC codewords,
wherein the codewords are punctured shortened LDPC codewords with more shortening than puncturing.
19. The wireless communication system of
20. In a wireless communication system, an encoding method for coding data for transmission, comprising the steps of:
encoding the data into Low Density Parity Check (LDPC) codewords using LDPC code sets including codewords, and
adding padding bits by concatenating a maximum of one additional OFDM symbol to a codeword, thereby minimizing code set granularity,
wherein the codewords are punctured shortened LDPC codewords with more shortening than puncturing.
Description The present invention relates to wireless systems, and in particular, to Low Density Parity Check encoding for wireless systems. Low Density Parity Check (LDPC) codes have recently attracted considerable attention owing to their capacity-approaching performance and low complexity iterative decoding. LDPC codes can be applied to a wide range of applications such as data encoding in wireless communications, satellite communications and storage. LDPC codes have also been adopted in standards such as DVB-S2 and 802.16e. Currently, LDPC codes are considered for the high throughput Wireless Local Area Networks (WLAN) as an optional code for encoding to improve system throughput. However, several issues must be addressed in order to match the LDPC code with the unique WLAN system characteristics. First is the code size. Since LDPC code works better with longer code size, the code size must be selected to be as large as possible to insure performance. However, since WLAN systems are random access based systems, the code size is limited by the SIFS (Short Inter Frame Space) decoding budget. Therefore, the largest code size is limited to around 2K bits. Second, since high-throughput WLAN uses aggregation to improve MAC efficiency, the transmitted PPDU is large, requiring several LDPC codewords. As such, there has been a need for a method of concatenating the LDPC codeword within a PPDU. Since transported data packets can be any size from typically about 40 bytes up to 12000 bytes and larger, the system must be able to encode variable length packets in a consistent manner. This consistency is required to ensure that the receiver always knows how to reconstruct the information field from the encoded transmitted data. A conventional WLAN transmitter includes a FEC (forward error correction) unit, a parser, frequency interleavers, QAM modulators and OFDM (orthogonal frequency division multiplexing) modulators. The FEC unit includes convolutional code encoder and the corresponding puncture, or LDPC encoders. Conventionally, the LDPC concatenation rule utilizes shortening for the last codeword. Each packet is encoded as an entity, wherein the data boundary of a packet is respected by the encoder. Headers are encoded at R=½ and BPSK modulation. The length of the packet that is to be encoded is all that is needed to encode or decode the packet using the following rules: -
- Rule 1: If Length<=N
_{i }bits, where N_{i }is the number of information bit in a LDPC codeword, then pad extra zeros to the information bit to N_{i}, encode the packet using just one LDPC codeword, shorten the codeword by removing the padded zeros from the systematic bits in the LDPC codeword. - Rule 2: If Length>N
_{i }bits, then compute N_{r}=modulo(Length, N_{i}) (in bits). Encode the first Length−N_{r }bits using full-length, unshortened codewords, and encode the remaining N_{i }bits using Rule 1. - Rule 3: Additional zeros are padded if necessary to meet the OFDM boundary.
- Rule 1: If Length<=N
However, the above approach has shortcomings. Referring to the performance graphs in In one embodiment, the present invention provides improved LDPC concatenation rules for data encoding in WLAN systems. In one implementation the present invention provides two code sets per rate: a long codeword and a short codeword. In order to ensure constant throughput, efficient hardware reuse and layer decoding algorithm, the present invention provides a basic LDPC block structure having a variant expanding factor with fixed base matrix size. Further, the present invention provides a LDPC concatenation rule, wherein a maximum of one extra OFDM symbol is added in order to reduce the code set granularity. In general, shortening improves the code performance while puncturing degrades the code performance. In order to guarantee that the code performance is better or the same compared with the original code, more bits are shortened compared with puncturing, by transmitting an extra OFDM symbol. Furthermore, the inventors have found that if the punctured bits are too many (e.g., when the punctured bits are greater than 30%-40% of code length), decoding fails regardless of the number of bits shortened. To prevent that result, all the required puncturing and shortening bits are distributed across all codewords. An additional benefit by distributing the shortening and puncturing bits across all codewords is that performance is uniformly improved through all codewords. This scheme provides a preferred tradeoff between code complexity and over-the-air efficiency. As such, the present invention provides a simplified solution to the prior art shortcomings, wherein only 2 codes per rate for both 20 MHz & 40 MHz systems are utilized, and the present invention is extendable to any system parameters. In addition, at most one extra OFDM symbol padding is needed and one code per packet provides uniform performance. Inherent recommendation for LDPC usage is that LDPC is optional, using only shortening the last codeword for high rate, and lower rate transmission requires more complicated concatenation rule. Nor is there a need to update code per packet, wherein easy code optimization is provides with improved system performance. These and other features and advantages of the present invention will be apparent from the following specification taken in conjunction with the following drawings. LDPC coding is a type of linear block coding and can be uniquely defined by a parity check matrix H. The code rate is R=M/N, where N is the number of columns in the H matrix, representing the size of the code, and M is the number of rows in the H matrix, representing the number of parity check equations. An example of a linear block code with N=7, M=3, is shown in relation (1) below:
There are two kinds of LDPC codes, regular and irregular. A regular LDPC code contains t number of 1's per-row (row weight) and s number of 1's per column (column weight), where s=t*(1−R). An irregular LDPC code contains uneven number of 1's per-column and per-row. For example, the H matrix in relation (1) is an irregular code. LDPC codes can be efficiently decoded using a message-passing algorithm. Such an algorithm operates on the decoder graph by iteratively updating the soft message. LDPC codes provide higher diversity order for multiple-input-multiple-output (MIMO) WLAN systems, and support encoding and shortening for multiple rates. The user information bits are passed through the shortening unit In one embodiment, the present invention provides improved LDPC code structure and concatenation rules for LPDC data encoding in WLAN systems (e.g., IEEE 802.11n OFDM MIMO systems). In one aspect the present invention provides two code sets per rate, a long one and a short one, for example, a length 1728 and a length 576 codeword. The long code size is chosen based on the coding performance and the decoding latency requirement. The short code size is chosen to be ⅓ of the long code word. Furthermore, both code sizes are selected to be an integer number of OFDM tones. The inventors have found that by choosing the code size to be integer number of OFDM tones, better padding efficiency can be achieved. For example, for a WLAN system with 48 OFDM tones, the 1728 and 576 codes which are integer numbers of 48 are preferred. Different code size should be chosen with different data tones based on this principle. For example, for 52 data tones system, 1872 and 624 codes should be selected. Example code rate, information bit and code word size combination for 48 tones system are shown in Table 2 below.
Further, in another aspect the present invention provides a LDPC concatenation rule, wherein in one implementation a maximum of one extra OFDM symbol is added in order to reduce the code set granularity. In general, shortening improves the code performance while puncturing degrades the code performance. In order to guarantee that the code performance is better or the same compared with the original code, more bits are shortened compared with puncturing, by transmitting an extra OFDM symbol. Furthermore, the inventors have found that if the punctured bits are too many, decoding fails regardless of the number of bits shortened. To prevent that result, all the required puncturing and shortening bits are distributed across all codewords. This scheme provides a preferred tradeoff between code complexity and over-the-air efficiency. An example of the above concatenation steps is illustrated by the pseudo-code in Table 3 below, which is an implementation of the steps in the flowchart of
As such, the present invention provides a simplified solution to the prior art shortcomings, wherein only 2 codes per rate for both 20 MHz & 40 MHz systems are utilized, and the present invention is extendable to any system parameters. In addition, at most one extra OFDM symbol padding is needed and one code per packet provides uniform performance. Inherent recommendation for LDPC usage is that LDPC is optional, using only shortening the last codeword for high rate, and lower rate transmission requires more complicated concatenation rule. Nor is there a need to update code per packet, wherein easy code optimization is provides with improved system performance. -
- Step
**400**: Input parameters—L (packet length), N_{cbps }(coded bits per OFDM symbol) and N_{dbps }(uncoded data bits per OFDM symbol). N_{ofdm}_{ — }_{tones }is the number of OFDM data tones in the system. - Step
**402**: Select LDPC codeLength, wherein for a short packet (e.g., L≦251 Bytes (packet length threshold)) the 576 code is selected, otherwise, for a long packet (e.g., L>251 Bytes) the 1728 code is selected. The packet length threshold is selected to make sure that with 1728 code the there is no coding gain loss due to shortening and puncturing. Packet length threshold of 251 bytes is selected based on system simulation using 48 data tones. A different packet length threshold should be selected for a different system. More bits are shortened than punctured such that the shortening to puncturing ratio is high enough to prevent coding gain loss. Further the puncturing ratio is limited to a maximum, wherein the maximum is also selected based on simulation observation. The inventors have found that in general, puncture ratio greater than e.g. 30-40% of the code length incurs large performance degradation. - Step
**404**: Determine if the transmission data rate is high (e.g., higher data rate corresponding to larger N_{dbps}). In the above system with 48 tones, when N_{dbps }is greater than 192 (which is corresponding to 48 Mbps transmission rate) high transmission rate diagram is used, otherwise, low transmission rate diagram is used. - Step
**406**: If transmission data rate is not high, then use shortening-only scheme and calculate the shortening bits as discussed (e.g., pseudo-code).FIG. 4 shows an example encoding procedure according to the present invention where shortening-only is applied (low data rate transmission), showing a codeword**500**(LENGTH*8+16) wherein shortening operation is performed for the last codeword**501**generating the shortened last codeword**502**, resulting in the transmission sequence**504**. InFIG. 4 , blocks**510**represent the information bits; block**512**represent the parity check bits after encoding; block**514**represents the all zero shortening bits which are inserted for encoding but not transmitted; block**516**is the extra padding bits which are transmitted to meet the OFDM boundary. - Step
**408**: If the transmission data rate is high, then use shortening-and-puncturing schemes with one extra OFDM symbol added, and calculate the shortening bits and puncturing bits as discussed (e.g., pseudo-code).FIG. 5 shows an example encoding procedure according to the present invention where the shortening-and-puncturing scheme is used (high data rate transmission), showing a codeword**600**(LENGTH*8+16) wherein shortening and puncturing operation is performed over every codeword**601**to generate a corresponding codeword**602**, resulting in the transmission sequence**604**. InFIG. 5 , the blocks**610**represents the information bits; blocks**612**represent the parity check bits after encoding; block**614**represents the all zero shortening bits which are inserted for encoding but not transmitted; blocks**616**represent the punctured parity bits which are removed from the parity bits and not transmitted; block**618**is the extra padding bits which are transmitted to meet the OFDM boundary.
- Step
In one example according to the present invention, the high/low rate threshold is selected based on the LDPC code length and system parameters. The shortening only scheme is very simple compared to shortening/puncturing scheme, so preferably the shortening only scheme is applied as much as possible. However, shortening only scheme incurs more than one OFDM symbol transmission overhead at low data rate. As such, the high/low rate threshold is selected so that when the transmission rate is above the threshold, applying shortening only scheme incur maximum one extra OFDM transmission, while when the transmission rate is lower than the threshold, more than one extra OFDM symbol is required for transmission. The exact threshold varies with the system parameters. In the example herein, with 48 tones, the threshold is selected as 196. An alternative embodiment of the present invention involves optimizing the packet size threshold for some smaller number. Further, the MCS selection threshold, which in the example above is set to 4*N The present invention has been described in considerable detail with reference to certain preferred versions thereof; however, other versions are possible. Therefore, the spirit and scope of the appended claims should not be limited to the description of the preferred versions contained herein. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |