The present disclosure generally relates to error correction coding. More specifically, the present invention relates to an analog system and method for iterative decoding of turbo, low-density parity check (LDPC) or turbo-like encoded data.
The statements in this section merely provide background information related to the present disclosure and may not constitute prior art.
Underlying the success of low-density parity-check (LDPC) codes and its acceptance into emerging digital video broadcasting (DVB-S2) and wireless standards (802.11, 802.12, 802.20) has been its fast and hardware realizable decoding process. Conventional LDPC decoders are either based on sum-product processes or use suboptimal min-sum (MS) processes. Both decoding processes are soft-decision processes that operate in either probability or log-likelihood ratio (LLR) domains and are amenable to parallel analog and digital hardware implementations. In particular, analog decoders are attractive over their digital counterparts because of their potential to achieve superior energy efficiency at fixed decoding speeds. Popular topology for analog LDPC decoders has been based on trans-linear circuits using either bipolar transistors or MOS transistors biased in weak inversion. Alternate analog topology based on min-sum approximation of sum-product process has been reported and has been mapped onto optical networks for high-speed decoding.
The LDPC decoding process can be expressed by equations in terms of a log-MAP formulation. LDPC codes are a class of binary linear block codes whose parity check matrix contains only a few 1's in comparison to the amount of 0s. An example of a parity check matrix H and its tanner or factor graph are shown in
For detailed treatment and analysis of LDPC decoding based on sum-product process, reference may be had to J. Hagenauer, E. Offer, and L. Papke, “Iterative decoding of block and convolutional codes,” IEEE Trans. Inf. Theory, vol. IT-42, no. 3, pp. 429445, March 1996, which is incorporated herein by reference in its entirety for any purpose. More briefly, let Vi denote a set of check nodes connected to the variable node vi and Vi˜j represent the set of check nodes other than cj that are connected to variable node vi. Similarly let Cj denote a set of variable nodes connected to the check node cj and Cj˜i represent the set of variable nodes other than the node vi connected to cj.
In a message passing process, each check node cj receives messages from its set of neighbors Cj (denoted by L(vi→cj)) and computes messages to be sent to the variable nodes viεCj (denoted by L(cj→vi)) according to
where tan h(χ)=(exp(χ)−exp(−χ))/(exp(χ)+exp(−χ)). In subsequent iterations, the variable nodes vi receive messages from its check nodes cjεVi and re-computes messages (denoted by L(vi→cj)) that will be sent to the check node cj according to
Messages are propagated back and forth between the variable and check nodes for a pre-determined number of iterations before a decision on the received bits is performed.
In LDPC decoding, the computationally intensive core is equation (1) which requires evaluations of hyperbolic function. Several approximations have been proposed in literature that approximate floating point computation of hyperbolic functions, some of which include the use of finite resolution look tables for digital implementations or a min-sum approximation for analog implementations. Equation (1) can be computed recursively according to the following process:
The update equation (3) is the fundamental operation for implementing LLR based LDPC decoders. For the sake of brevity, the operation (3) can be compactly represented as x←log(1+eχ+y)−log(ex+ey) where the arbitrary variables x, y represent the likelihoods. Before we introduce the log-MAP formulation and subsequently margin propagation, we will first decompose variables x and y into differential representations as x=x+−x− and y=y+−y− with x+,x−,y+,y−≧0. Such a decomposition is desirable for analog circuit implementation because a fully differential architecture is robust to common-mode interference. Equation (3) can be represented as the following differential updates:
x+←log└ex
x−←log└ex
Each of the updates (4), (5) are in the form of a “log-MAP” normalization which are popular in Bayesian network literature.
In accordance with the present invention, a margin decoding communications system includes a circuit receiving a message encoded by an iterative code and processing the message into scores. A normalization module receives the scores and iteratively approximates log-map normalization factors of the scores to generate approximation normalization factors. An element receives the message and the approximation normalization factors and decodes the received message based on the approximation normalization factors.
The margin propagation process is advantageous over previous decoding processes for implementing analog decoders. For example, unlike conventional analog decoders which rely on trans-linear operation of transistors, margin propagation (MP) based decoders use only additions, subtractions and threshold operations and can be mapped onto several analog networks (current-mode, charge-mode, or non-electronic circuits). Additionally, compared to trans-linear and min-sum approaches, the computational core of margin propagation can be implemented using universal conservation laws (charge, current, energy, mass etc.) and therefore can be mapped onto several analog architectures. Also, the properties and performance of margin propagation analog LDPC decoders are superior compared with those of alternative decoders based on sum-product and min-sum (MS) process. In particular, margin based LDPC decoders achieve near identical bit error rate performance as their floating point sumproduct counterparts and superior performance as compared to MS decoders. Moreover, when messages in LDPC decoding process are corrupted by additive noise, margin decoders demonstrate superior performance, compared to sum-product and MS based decoders.
Further areas of applicability will become apparent from the description provided herein. It should be understood that the description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the present disclosure.
The present invention will become more fully understood from the detailed description and the accompanying drawings, wherein:
The following description is merely exemplary in nature and is not intended to limit the present disclosure, application, or uses.
A margin propagation based iterative analog decoding process accomplishes decoding for low density parity check (LDPC) codes. At the core of margin propagation is reverse water-filling process that performs a normalization operation. Given a set of scores ƒiεR,i=1, . . . ,N, reverse water-filling computes a normalization factor zεR according to the equation
where [.]+=max(.,0) denotes a threshold operation and γ≧0 represents a parameter of the process. The solution to constraint (6) is shown in
The margin normalization factor computed according to equation (6) can be used to approximate factors computed according to a log-MAP normalization. For a set of scores ƒi,i=1, . . . ,N, log-MAP normalization factor is computed according to
Margin normalization can be applied to recursions (4) and (5) by approximating the differential log-MAP normalization factors as
L(vi→cj)←(z1−z2) (8)
where the normalization factors z1 and z2 are computed according to the following reverse water-filling constraints
[x++y+−z1]++[x−+y−−z1]+=γ (9)
and
[x−+y+−z2]++[x++y−−z2]+=γ (10)
x+,x−,y+ and y− are differential representations of likelihoods as x+=L+(vi→cj),x−=L−(vi→cj),y+=L+(cj→vi), and y−=L−(cj→vi). The normalization parameter γ is dependent only on size and degree of the nodes in the parity check matrix.
Margin propagation and its underlying reverse water-filling process can be naturally mapped onto several analog computational structures.
Even though the above description uses charge as the parameters for analog computation, other physical parameters can also be used. For instance, the potential wells in illustration 4 can be replaced by micro-fluidic chambers in a MEMS device, where the computation can be performed using a noncompressive fluidic medium. Reverse water-filling functionality can also be emulated on CMOS devices using charge mode or current mode circuits. A current mode implementation for margin propagation is illustrated in S. Chakrabartty, “CMOS analog iterative decoders using margin propagation circuits,” Proceedings of International Symposium on Circuits and Systems, Kos, Greece, 2006, which in incorporated by reference herein in its entirety for any purpose.
A CMOS charge mode implementation based on emulation of steps shown in
A CMOS current mode implementation is shown in
The performance of margin based LDPC decoding algorithm was compared to sum-product and min-sum based LDPC decoding algorithm using computer simulations. In the experiments, a rate ½ H(4, 8) LDPC code with a codeword length of Nc=256 and Nc=1024 was chosen. An additive white Gaussian noise (AWGN) channel with noise variance N0/2 was used for simulations. An all reference zero codeword was transmitted using binary phase shift keying (BPSK) modulation. Subsequent to LDPC decoding bit error rate (BER) was plotted against signal-to-noise ratio (SNR), computed according to SNR=10 log10(Eb/N0) with Eb representing energy per bit. The simulation results for codeword length of 256 were obtained after 10 message passing iterations where as 20 iterations of computations were used for codeword of length 1024.
The first set of experiments were used to determine the optimal value of γ for parity check matrix with different node degree that produced the lowest BER. A code length of Nc=256 was chosen for the experiments.
The next set of experiments compared the performance of margin based decoders with alternate decoding algorithms.
The advantage of margin based decoding over log-MAP decoding can be demonstrated for the scenario where the communication channel used for propagating the messages between variable and check nodes is non-ideal. Such a scenario arises in an analog iterative decoding hardware where the messages could be corrupted by substrate coupling noise or digital switching noise. For this experiment, two sources of additive noise were considered. A primary noise corrupts the BPSK signal at the receiver and a secondary noise corrupts the messages propagated on communication channel between nodes of the code graph. For the experiment, a rate ½ LDPC code of length Nc=256 was chosen. The SNR due to primary noise contribution was fixed to 2 dB and the SNR due to secondary noise contribution was varied.
More discussion of the teachings presented above can be found in: (a) S. Chakrabartty, “CMOS analog iterative decoders using margin propagation circuits,” Proceedings of International Symposium on Circuits and Systems, Kos, Greece, 2006; and (2) C. Kong and S. Chakrabartty, “Analog iterative LDPC decoders based on margin propagation,” Proc. Analog Decoding Workshop, Torino, Italy, Jun. 5-6, 2006. The contents of these disclosures are incorporated by reference herein in their entirety for any purpose.
One skilled in the art will recognize that the preferred embodiment of the present invention detailed above may be modified without departing from the spirit and scope of the present invention. Moreover, the description of the invention is merely exemplary in nature and, thus, variations that do not depart from the gist of the invention are intended to be within the scope of the invention.
This application claims the benefit of U.S. Provisional Application No. 60/790,176, filed on Apr. 7, 2006. The disclosure of the above application is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60790176 | Apr 2006 | US |