The present invention is generally directed to the field of data communication, and more specifically, to the decoding of codewords encoded with an LDPC (Low Density Parity-Check) code.
The present invention is more particularly, but not exclusively, directed to a data communication system utilizing the DVB-S2 (Digital Video Broadcast) standard.
Low-Density Parity-Check (LDPC) codes were introduced by Gallager in 1962 and rediscovered in 1996 by MacKay and Neal. For a long time they had no practical impact due to their computational and implementation complexity. This changed with advances in microelectronics that led to more computational power available for simulation, and which now enables implementation. Due to their excellent error correction performance they are considered for future telecommunication standards.
An LDPC code is a linear block code defined by its sparse M×N parity check matrix H. It contains j ones per column and k ones per row, respectively called row and column degrees. A (j,k) regular LDPC code has row and column degrees of uniform weight, otherwise the code is irregular. A parity check code can be represented by a bipartite graph. The M check nodes correspond to the parity constraints, and the N variable nodes represent the data symbols of the codeword. An edge in the graph corresponds to a one in the parity check matrix.
In the LDPC code encoder the packet to encode of size (N−M) is multiplied with a generator matrix G of size (N−M)×N. This multiplication leads to an encoded vector of length N. The generator matrix G and the parity check matrix H satisfy the relation GHt=0, where 0 is the null matrix.
Generally speaking, an LDPC code decoder comprises a decoding module which receives the encoded vector of length N, and delivers an intermediate vector of length N by using the parity check matrix H. Then a demapping module extracts from the intermediate vector the decoded vector of length (N−M).
More precisely, LDPC codes can be decoded using message passing algorithms, either in hard or soft decision form. The decoding is then an iterative process, which exchanges messages between variable and check nodes. Typically, a Belief Propagation (BP) algorithm is used, which exchanges soft-information iteratively between variable and check nodes. The code performance mainly depends on the randomness of the parity check matrix H, the codeword size N and the code rate R=(N−M)/N.
The channel coding part is a very important component in wireless communication systems, like UMTS, WLAN and WPAN. Especially in the domain of WLAN and WPAN, the latency of the decoding is of critical importance. Low Density Parity Check codes can be seen as a promising candidate for these kinds of systems in the near future. These codes are being deployed in the DVB-S2 standard, and in some optical fiber communication systems. More applications will follow in the near future.
The codes have some very interesting properties, which make them a natural choice for latency critical applications.
The new DVB-S2 standard features a powerful forward error correction FEC system, which enables transmission close to the theoretical limit. That is, enabled by using LDPC codes which can even out perform Turbo-Codes. To provide flexibility, 11 different code rates R ranging from R=¼ up to R= 9/10 are specified with a codeword length up to 64800 bits. This huge maximum codeword length is the reason for outstanding communication performance. The codeword length of 64800 bits will now be described.
For the DVB-S2 code, 64800 variable nodes (VN) and 64800×(1−R) check nodes (CN) exist. The connectivity of these two types of nodes is specified in the standard. The variable nodes comprise information nodes and parity nodes. For decoding the LDPC code, messages are exchanged iteratively between these two types of nodes, while the node processing is of low complexity. Generally, within one iteration, the variable nodes (VN) are first processed, then the check nodes (CN).
The decoding of LDPC codes is an iterative process, for example, for the DVB-S2 standard up to 40 iterations are required to gain the desired communication performance. Standard LDPC code decoder implementations assume a fixed number of iterations. In “A 690-mW 1-Gb/s, Rate-½ Low-Density Parity-Check Code decoder” by A. J. Blanksby and C. J. Howland, published in the IEEE Journal of Solid-State Circuits, vol. 37, no. 3, pp. 404-412 and March 2002, 64 decoding iterations are performed.
For decodable blocks or codewords, the stopping criteria taking into account the check node sum of the log-likelihood ratios of the incident edges is a very good stopping criteria, but for undecodable blocks or codewords, the full number of iterations is processed so a lot of energy and processing time is wasted.
In view of the foregoing background, an object of the present invention is to stop the decoding in an early stage of the decoding process for undecodable codewords.
This and other objects, advantages and features in accordance with the present invention are provided by a method for controlling the decoding of an LDPC encoded codeword composed of digital data. Each data may be also called a “soft bit” which is a real value coded on several bits and corresponding to the value of the corresponding bit of the transmitted codeword actually received from the channel. The LDPC code may be represented by a bipartite graph between check nodes and variable nodes.
The method may comprise updating messages exchanged iteratively between variable nodes and check nodes. The method may comprise, at each iteration, calculating for each variable node a first sum of all the incident messages received by the variable node and the corresponding digital data, and calculating a second sum of all the absolute values of the first sums. The decoding process is stopped if the second sum is unchanged or decreases within two successive iterations, and if a predetermined threshold condition is satisfied.
However, if the threshold condition is not satisfied, the decoding process is not stopped even if the second sum is unchanged or decreases within two successive iterations. Such a controlled decoding permits the decoding of an undecodable codeword to be stopped early in the decoding process. A lot of energy and processing time wasted during attempts of undecodable codewords decoding is avoided.
The predetermined threshold condition may be satisfied if a current second sum is smaller than a predetermined threshold. The unchanging or decreasing of the second sum indicates that the codeword is undecodable preferably at the beginning of the decoding process.
When the second sum passes the threshold, a decreasing of the second sum may occur even if the codeword is actually decodable. Accordingly, the stopping criteria has to be switched off when the current second sum passes the threshold. The threshold is advantageously dependent on the code rate of the LDPC code. It may be determined only once for each code rate. Moreover, the encoded codeword is received from a channel, and the threshold is advantageously independent on the signal to noise ratio of the channel. Furthermore, the threshold may be dependent on the number of bits of the exchanged messages. For example, the encoded codeword is received from a channel, and the threshold VNRoff is defined by:
wherein:
N is the number of bits of the exchanged messages,
Eb is the mean energy for transmitting a bit information on the channel,
N0 is the noise energy of the channel,
R is the code rate of the LDPC code, and
is the value of the ratio
at a waterfall region of a curve representing the frame error rate (FER) as a function of the ratio.
The threshold VNRoff can be also defined for example with the relation: VNRoff=2(q−1)×N
wherein:
n is the number of bits of the exchanged messages, and
q is the number of bits used for representing the absolute value of the message.
According to another embodiment, the predetermined threshold condition may be satisfied as long as the number of iterations is smaller than or equal to a predetermined number of iterations. Even for decodable codewords, a drop of the second sum can occur between the 20th and the 30th iteration. Accordingly, the stopping criteria can be switched off after, for example, a number of iterations comprised between 5 and 15.
In a preferred embodiment, the digital data of the codeword and the messages may be log-likelihood ratios (LLRs). The LDPC code is, for example, a DVB-S2 LDPC code.
According to another aspect of the invention, a decoder for decoding an LDPC encoded codeword composed of digital data is provided. The LDPC code may be represented by a bipartite graph between check nodes and variable nodes. The decoder may comprise processing means or a processor to update messages exchanged iteratively between variable nodes and check nodes. The processing means may comprise calculating means or a calculator for calculating, at each iteration for each variable node, a first sum of all the incident messages received by the variable node and the corresponding digital data, and calculating a second sum of all the absolute values of the first sums. The processing means also comprise control means or a controller for stopping the decoding process if the second sum is unchanged or decreases within two successive iterations and if a predetermined threshold condition is satisfied.
The predetermined threshold condition may be satisfied if a current second sum is smaller than a predetermined threshold. The threshold is advantageously dependent on the code rate of the LDPC code.
Advantageously, the decoder may comprise memory means or a memory. The memory may comprise a look-up table storing values of the threshold according to the code rate of the LDPC code and the number of bits of the exchanged messages.
According to another aspect of the invention, an element of a wireless communication system including a decoder as above described is provided. This element can be a terminal or a base station, or an access point device.
According to another aspect of the invention, a wireline communication system, for example an XDSL system, a fiber optic system, or a power line system comprising a decoder as above described is provided.
Other advantages and features of the invention will appear on examining the detailed description of different embodiments, these being in no way limiting, and of the appended drawings in which:
In the following description, the LDPC code is a DVB-S2 LDPC code as defined in “ETSI EN 302 307 v1.1.1 (2004-06)” defining the DVB-S2 standard, although the invention is not limited to such a code. The parity check matrix H of LDPC code is a sparse binary matrix. The set of valid codewords x have to satisfy: H.tx=0
A column in H is associated to a bit of the codeword and a row corresponds to a parity check. A nonzero element in a row of H means that the corresponding bit contributes to this parity check. The code can best be described by a bipartite graph called a Tanner graph (
The Tanner graph of a DVB-S2 code is illustrated in
The exchanged soft-information are generally log-likelihood ratios (LLR). The update of the messages at the variable nodes VNi can be effected in two steps.
In a first step, each variable node calculates a current estimate Λn of the decoded bit corresponding to the variable node according to the relation:
Λn=λch+Σλk (1)
wherein Λn is the current estimate of the decoded bit corresponding to the variable node, λch is the corresponding channel LLR of the variable node (corresponding to a digital data of the encoded codeword to be decoded), and λk is the LLRs of the incident edges of the variable node.
In other words, Λn is a first sum of all the incident messages λk received by the variable node and the corresponding digital data λch. The sign of Λn represents the hard decision of the decoded bit (one or zero), and the magnitude of Λn represents the confidence of the decoding of the bit.
In a second step, an update of the outgoing message i is calculated, with the update being the LLR sum Λn of the corresponding variable node minus the input message LLR, according to the relation:
λinew=Λn−λiold (2)
wherein λinew is the updated LLR of the outgoing message i, and λiold is the value of the LLR of the outgoing message i before the updating.
The check node message updates are generally calculated according to the relation, for a message k comprising a LLR λk:
wherein λk is the LLR updated from the check node, and λ1 is the LLRs of the incident edges of the check node.
In the following description, the early detection of undecodable codewords will be detailed. Usually, digital data of encoded codewords represent log-likelihood ratios (LLRs). The detection permits the decoding process to be stopped in an early stage for an undecodable codeword.
A second sum VNR, also called a “variable node reliability”, is calculated at each iteration of the decoding process. The second sum VNR is the sum of all the absolute values of the first sums Λn of the variable nodes:
VNR=Σ|Λn| (4)
This value VNR is easily obtained.
For an infinite block size a monotonic increasing of VNR versus the number of iterations is expected for a decodable codeword, as represented by curve VNR1 on
Thus, the decoding process is stopped if the VNR does not change or decreases within two successive decoding iterations, as illustrated by curve VNR3 of
In
Thus, a test (step ST3) is effected. If the current value VNRnew of the second sum is inferior to a predetermined threshold VNRoff, then the stopping criteria is stopped and the decoding process is continued (step ST4). Otherwise, if the current value VNRnew of the second sum is greater or equal to the predetermined threshold VNRoff another test is effected (step ST5) in comparing the current value VNRnew with the old value VNRold of the second sum corresponding to the preceding iteration.
If the current value VNRnew of the second sum is inferior or equal to the old value VNRold of the second sum corresponding to the preceding iteration, then the decoding process is stopped (step ST6). Otherwise, the current value VNRnew is affected to the old value VNRold (step ST7) for the next iteration of the decoding process. For the first iteration, a weak value, for example zero, can be affected to the old value VNRold.
In other words, if the number of iterations is greater than IToff, the stopping criteria is switched off and the decoding process is continuing. For a codeword received from a channel, the threshold VNRoff is independent on the signal to noise ratio of the channel. Nevertheless, the threshold VNRoff is dependent on the code rate R of the LDPC code and on the number of bits N of the exchanged messages.
More precisely, the threshold VNRoff can be calculated only once for each code rate with the relation:
wherein:
N is the number of bits of the exchanged messages,
Eb is the mean energy for transmitting a bit information on the channel,
N0 is the noise energy of the channel,
R is the code rate of the LDPC code, and
is the value of the ratio
of a waterfall region of a curve representing the frame error rate (FER) as a function of the ratio. The waterfall region WR corresponds to the region of great decreasing of the curves, examples of which are illustrated in
for different values of a mean bound MB which can roughly set t a SNR (signal to noise ratio) point around the waterfall region WR. Further these curves have been obtained for a code rate R=0.8, a codeword of 2000 bits and a 6 bit message quantization. The most significant represents the sign and the 5 other bits represent the absolute value of the message.
Similar curves obtained for a code rate R=0.5, a codeword of 3200 bits and a 6 bit message quantization (the fractional part is equal here to 4) are illustrated in
is set to 3.5, whereas it is set to 1.5 for a code rate R=0.5.
These curves
are obtained by simulation, as for example described in the standard communication book “Digital Communications” by J. G. Proakis (McGraw-Hill), 2001, 4th edition.
The threshold VNRoff can also be calculated, in various ways, only once for each code rate with the relation:
VNRoff=2(q−1)×N
wherein
N is the number of bits of the exchanged messages, and
q is the number of bits used for representing the absolute value of the message. An embodiment of a decoder DEC is illustrated in
The processing module PROC comprises a calculating module CALC for calculating, at each iteration for each variable node, the first sum Λn of all the incident messages λi received by the variable node and the corresponding digital data λch, and for calculating the second sum or variable node reliability VNR of all the absolute values of the first sums Λn.
The processing module PROC also comprises a control module CTRL for stopping the decoding process if the second sum VNR is unchanged or decreases within two successive iterations, and if a predetermined threshold condition is satisfied.
The control module CTRL can be adapted to detect a satisfied threshold condition if a current second sum VNRnew is smaller than a predetermined threshold VNRoff (
Moreover, the decoder DEC comprises a memory module MEM which comprises a look-up table LUT for storing values of the threshold VNRoff according to the code rate R of the LDPC code and the number of bits N of the exchanged messages. The decoder DEC may be incorporated in a receiver TP (
Number | Date | Country | Kind |
---|---|---|---|
05009477 | Apr 2005 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2006/003942 | 4/27/2006 | WO | 00 | 10/10/2007 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2006/117135 | 11/9/2006 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7249307 | Varshney et al. | Jul 2007 | B2 |
7653858 | Nefedov | Jan 2010 | B2 |
20030229843 | Yu et al. | Dec 2003 | A1 |
20040109507 | Kanter et al. | Jun 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
20080172592 A1 | Jul 2008 | US |