The present invention relates generally to coding techniques for communications and, more particularly, to code designing for repeat-zigzag Hadamard codes.
For communication systems operating in the low signal-to-noise ratio (SNR) regime (e.g., code-spread communication systems and power-limited sensor networks), low-rate coding schemes play a critical role. Traditional low-rate channel coding schemes include Hadamard codes and super-orthogonal convolutional codes. These codes offer low coding gain and hence their performance is far away from the ultimate Shannon limit. The ultimate Shannon capacity of an Additive White Gaussian Noise (AWGN) channel in terms of SNR per information bit is about −1.6 dB for codes with rates approaching zero. Turbo-code-based, low-rate concatenated coding schemes have been proposed which offer higher performance but they also incur higher complexities due to the complex trellis structures that specify the codes. The low-density parity-check (LDPC) codes and the repeat-accumulate (RA) codes offer capacity-approaching capability for various code rates when the ensemble profiles are optimized. However, in the low-rate region, they both suffer from significant performance loss and extremely slow convergence with iterative decoding. On the other hand, Hadamard codes have been shown to be a useful tool for improving the code performance in the low-rate region. Constructed from Hadamard code arrays, low-rate turbo-Hadamard codes offer a bit-error-rate (BER) of 10−5 at a signal to noise ratio Eb/N0=−1.2 dB, which is only around 0.4 dB away from the Shannon limit. More recently, built on zigzag codes, parallel-concatenated zigzag-Hadamard (PCZH) codes and repeat-zigzag-Hadamard (RZH) codes have been proposed, both of which exhibit much simpler encoder and decoder structures while still offering a similar performance as that of the turbo-Hadamard codes.
Similar to LDPC codes and RA codes, an RZH code can be represented by its Tanner graph, based on which iterative decoding algorithms can be derived. In two decoding schemes, namely the turbo-like serial decoding and the LDPC-like parallel decoding, it is clear that the parameters of an RZH code need to be chosen carefully for capacity-approaching performance, which leads to the irregular RZH (IRZH) code with optimized degree profile. The exact density evolution method for LDPC code design can be employed for the IRZH code optimization. However, the complexity is extremely high, even for the moderate rate LDPC codes. Density evolution with Gaussian approximation does not work for the design of low-rate RZH codes. Accordingly, there is a need for a design method for low-rate RZH codes.
In accordance with the invention, there is provided a method to, with a given rate, design the irregular RZH code with minimum signal-to-noise ratio threshold or given a signal-to-noise ratio threshold, design a code ensemble to a maximizing rate. The signal-to-noise ratio threshold means that for any signal-to-noise ratio greater than this threshold, the BER of the code will go to zero or a very small value when the code length is enough long.
In accordance with an aspect of the invention, a method for selecting a signal to noise ratio for a communications code includes obtaining extrinsic information transfer (EXIT) information for a repeat-zigzag Hadamard (RZH) code responsive to a Hadamard order and a signal to noise ratio, determining code parameters for an irregular repeat zigzag Hadamard (IRZH) code for a corresponding code rate in response to the obtained EXIT values, and repeating the step of obtaining the EXIT information for a different signal to noise ratio if the corresponding code rate is other than a selected rate. In a preferred embodiment, the step of obtaining EXIT information includes one of obtaining an EXIT curve for repeat-zigzag Hadamard code by Monte Carlo simulation using serial decoding or obtaining an EXIT function for parallel decoding of the repeat-zigzag Hadamard code by using equations.
In yet another aspect of the invention, a method for selecting a signal to noise ratio for a communications code includes choosing a signal to noise ratio, selecting a Hadamard code order, obtaining extrinsic information transfer (EXIT) information for one of a serial decoding and a parallel decoding of a irregular repeat-zigzag Hadamard (IRZH) code responsive to the Hadamard order and the signal to noise ratio, determining a code ensemble for the irregular repeat zigzag Hadamard (IRZH) code for a related bit error rate in response to the obtained EXIT information, and changing the signal to noise ratio for repeated steps of obtaining the EXIT information and determining a code ensemble for a different signal to noise ratio if the related bit error rate is other than a target rate. Preferably, the EXIT information is a curve for the irregular repeat-zigzag Hadamard (IRZH) code obtained by Monte Carlo simulation using the serial decoding and the EXIT information is a function for parallel decoding the irregular repeat-zigzag Hadamard (IRZH) code using equations.
These and other advantages of the invention will be apparent to those of ordinary skill in the art by reference to the following detailed description and the accompanying drawings.
The inventive code design considers two decoding schemes, namely the turbo-like serial decoding and the LDPC-like parallel decoding. Parameters of an RZH code need to be chosen carefully for capacity-approaching performance, which leads to the irregular RZH (IRZH) code with optimized degree profile. The invention considers the design methods for IRZH codes. For turbo-like decoding, the extrinsic information transfer function (EXIT) chart technique can be employed to optimize the code profiles. EXIT functions characterize mutual information between the input and output of constituent decoders significantly facilitates performance analysis of iterative coding schemes. The design method for both decoding schemes is based on EXIT function/EXIT chart. One may always get the EXIT by Monte Carlo simulation for both decoding schemes. For parallel decoding, one obtains the EXIT function analytically, i.e., a mathematical formulation. With that one can calculate the EXIT value without using the simulation, which simplifies or reduces the complexity of the code design procedure significantly. Since in this case the inner decoder is a trellis-based zigzag-Hadamard (ZH) decoder, an analytical expression of its EXIT function is not available, and the inventive code design resorts to Monte Carlo simulations to obtain the EXIT functions of the inner code. For LDPC-like parallel decoding, the connection bits of the ZH code are treated as degree-2 variable nodes, and the inner constituent decoder becomes a Hadamard decoder, having the channel observations of the parity bits and the a priori probabilities about the information or connection bits as the input, and the extrinsic information for the information/connection bits as the output. EXIT functions with multiple inputs and outputs are difficult to obtain using Monte Carlo simulations. EXIT functions of Hadamard with multiple inputs and outputs in the context of low-rate RZH codes over BIAWGN channels are derived and applied to the analysis and design of RZH codes. With the EXIT functions, bit error rates (BERs) for a given communication code profile can be estimated and the differential evolution (DE) method can be employed to optimize the degree profile.
The structure of a systematic, repeat-zigzag-Hadamard RZH code is shown by the diagram 10 in
where r is the order of the Hadamard code for the inner encoder.
In case that the inner code has no puncturing, one can have the un-punctured RZH codes output on a single channel 22 whose structure 20 is shown in
With k→∞, then
When the coding rate is very low, e.g., Rc≦0.01, the performance difference between the punctured one and the un-punctured code is relatively small; whereas in the range around Rc=0.05, the punctured code offers a significant coding gain over the un-punctured one due to the elimination of the repetition bits embedded in the inner ZH codes.
A RZH code can be represented by its Tanner graph 30, as shown in
Based on the Tanner graph, iterative decoding algorithms can be derived. Two belief-propagation (BP) based decoding schemes for RZH codes can be employed. The turbo-like serial decoding 40 depicted in
Design Methods for Turbo-Like Decoding
The code design of IRZH codes with serial decoding where the outer code is a mixture of repetition codes with different rates is considered. The design approach closely follows those described for RA codes and LDPC codes where the EXIT chart technique is utilized as a design tool. EXIT functions of the component codes and code ensemble optimization are examined.
EXIT Functions of the Component Codes
Considering EXIT functions of the component codes, for an (n,k) IRZH codes, the outer code consists of k repetition codes with variable rates. As shown in
where Lch is the LLR value about the information bit from the channel. For AWGN channel with noise variance
then
where xu is the channel observation of the binary phase shift keying (BPSK) modulated information bit u. Lrepin(j) is modeled as the output LLR of an AWGN channel whose input is the jth interleaver bit transmitted using BPSK. The EXIT function of a degree-dv variable node is then
IE,VND(IA,VND,dv)=J(√{square root over ((dv−1))}J−1(IA,VND)) (4)
where
Since J(σ) is a monotonically increasing function of σ, it is invertible.
Given the Hadamard code order r, the IRZH design involves specifying the variable node degrees dv(i), i=1, 2, . . . , k. Let D be the number of different variable node degrees, and denote these degrees by dv,i, i=1, 2, . . . , D. Then the degree profile of a code can be specified by a polynomial
where ai≧0 is the fraction of nodes having degree dv,i. Note that {ai} must satisfy
The average variable node degree is then given by
Since for
then
Let bi be the fraction of edges incident to variable nodes of degree dv,i. There are (kai)dv,i edges involved with such nodes, so then
Note that {bi} must satisfy
It has been shown that the EXIT function of a mixture of codes is an average of the component EXIT functions. With (4), (6) and (7), the effective transfer function of the outer mixture codes is thus given by
Since g(·) is a monotonically increasing function of IA,VND, it is invertible and then IA,VND=g−1(IE,VND,Rc,r).
For systematic RZH codes, an information bit variable node of degree dv has dv+1 incoming messages: dv from the edge interleaver and one from the channel. The decoder outputs are given by (3). Then the EXIT function of a degree-dv variable node is given by
where
being the symbol SNR. For systematic RZH codes, then
hence
Then with (7), (11) and (12), one can have the effective transfer function of the outer mixture codes as follows
Again, g(·) is invertible, and one can have
In order to perform code ensemble optimization, the EXIT transfer function of the inner ZH decoder is needed. In general, there is no closed-form formula, hence the EXIT function is computed by simulation and denoted it by
Code Ensemble Optimization
In the case of code ensemble optimization, for given r and
the optimal IRZH ensemble parameters {ai} that maximize Rc subject to vanishing BER
are solution of the following optimization problem
EXIT charts can be used to analyze the convergence properties of RA codes and LDPC codes. The same principle can be applied to RZH codes. Specifically, if there is an open tunnel between the EXIT functions of the inner code and outer code for given r and
the iterative decoding algorithm can asymptotically converge and then
with a sufficient large number of iteration. Mathematically, the convergence condition is given by
for un-punctured RZH codes, and
for systematic codes. With the help of the EXIT chart analysis, one can simplify the above optimization problem by replacing the constraint
in (17) with condition (18) or (19). To design an IRZH code for a particular rate Rc, we simply choose proper Hadamard degree and change
in (17) until the resulting optimization result Rc*=Rc.
Design Method for LDPC-Like Decoding
The design approach for IRZH codes with parallel decoding closely follows that for irregular LDPC codes using the deferential evolution (DE) technique. During the optimization, the BER for a given code profile has to be estimated, which can be done through mutual information evolution. The mutual information transfer function for the outer repetition code is similar to the case for serial decoding. Hence, obtaining the EXIT functions for Hadamard codes is needed.
EXIT Functions Hadamard Components
The EXIT functions for Hadamard codes with multiple inputs on BIAWGN channels are considered. Since it is difficult to directly compute the EXIT functions of the output from the MAP decoder, use is made of a pMAP decoder to derive an approximation for the extrinsic mutual information over binary-input additive white Gaussian noise BIAWGN channels. Basic properties of BIAWGN channel are introduced and the pMAP decoder, with which an approximate expression for the EXIT function over BIAWGN for general linear block codes and Hadamard codes is derived.
Properties of BIAWGN Channels
First the BIAWGN channel, its LLR and “soft bit” outputs are characterized. A BIAWGN channel is characterized by its variance σ2. Let Y denote the BIAWGN channel observation for a transmitted BPSK modulated bit X, and let
denote the LLR and “soft bit” estimation of X based on the channel observation Y respectively. For a BIAWGN channel one can have
Suppose that +1 is transmitted, then (L|X=+1)N(m, 2m), where
Hence (T|X=+1) has the following pdf
where fL denotes the pdf of (L|X=+1). With (20), the (2i)-th moment of (T|X=+1) as a function of m is given by
The mutual information between X and L as a function of m is given by [?]
which is invertible and hence has m=W−1(I).
MAP and pMAP Decoders
Now, turning to the output of the MAP decoder and the pMAP decoder. Given an (n,k) linear block code C over GF(2), the dual code C⊥ is an (n,n−k) linear block code. Let cj⊥=[cj,1⊥, cj,2⊥, . . . , cj,n⊥]T denote the j-th codeword of the (n,n−k) dual code. Denote by Ii,1⊥={j|cj,i⊥=1} the set of indices of all codewords in the dual code with the i-th bit being 1 (or the set of indices of all parity-checks that the i-th bit participates in), and Ii,0⊥={j|cj,i=0} the set of indices of all codewords in the dual code with the i-th bit being 0.
The extrinsic MAP decoding can be implemented by using the dual code as follows
Let DEMAP,i be the extrinsic output of MAP decoder (23) after the following modification
The extrinsic output of a suboptimal decoder which one can call pMAP decoder [?] is defined as
where P(Ii,1⊥) denotes the set of all subsets of Ii,1⊥ and “” denotes logical “or” operation. In what follows, the pMAP decoder is employed to obtain an approximate expression for the EXIT functions of linear block codes over a BIAWGN channel. Since the basic idea is to decompose the EXIT function in the form of a series EXIT functions of multiple single parity-check codes, we will start from the EXIT function of single parity-check codes.
EXIT Functions for General Linear Block Codes
Note that the goal is to find the extrinsic functions for different bits given that the a priori mutual information from the extrinsic and the communication channels for different bits is different. Keeping this in mind, we first compute the extrinsic information at the output of a single parity-check code.
Theorem 4.1.
The extrinsic information of the i-th bit at the output of MAP decoder of an (n,n−1) single parity-check code is given by:
Proof:
The dual code of the (n,n−1) single parity-check code is the repetition code of length n. Hence from (23) it follows that
then using a known proposition 2.6, the extrinsic mutual information of the i-th bit at the output of MAP decoder is given by
where the last equality holds since the channel is assumed to be memoryless.
For the single parity-check codes, pMAP and MAP decoders are identical in any memoryless channel, and the Conjecture 4.1 also states that for other high rate codes, DEMAP≅DEpMAP when the all-zero codeword is transmitted over the BIAWGN channel. We have the following result.
Theorem 4.2.
Let C be an (n,k) linear block code such that in BIAWGN channel DEMAP=DEpMAP. Then the mutual information between Xi and TEMAP,i is given by
where V(S)={lε{1, . . . , n}|jεScj,l⊥−1}, and ml=W−1(IA,l) where IA,l is the a priori mutual information about Xl from the channel given Xl=+1 is transmitted.
Proof:
According to a known Theorem and (24), we have
Since DEMAP=DEpMAP, we further have
Define V(S)={lε{1, . . . , n}|jεScj,l⊥=1}, then the E{·} term in (29) is the extrinsic information of a (|V(S)|,|V(S)|−1) single parity-check code. Since all-zero codeword is transmitted, according to Theorem 4.5, we have
with which (29) becomes
where ml is the mean of the “soft bit” estimation passed from the channel to the MAP decoder for Xl given that X=+1 is transmitted. Note that such a BIAWGN channel can either be a communication channel or an extrinsic channel. It is also noted that the EXIT functions in the form of multiple EXIT functions of the same code in BEC channel, cannot be expanded.
For high rate codes, we have DEMP≅DEpMAP when the all-zero codeword is transmitted over the BIAWGN channel, and Theorem 4.2 can be used to approximately compute the extrinsic information at the output of the MAP decoder for a linear block code. Note that Hadamard codes are low rate codes. For a low rate code, the extrinsic information can be approximated by
IE,iBIAWGN(IA,1, . . . , IA,n)≅1−IE,i⊥,BIAWGN(1−IA,1, . . . , 1−IA,n), (30)
where IE,i⊥,BIAWGN(1−IA,1, . . . , 1−IA,n) is the extrinsic information of its high-rate dual code and can be computed by Theorem 4.2 with ml=W−1(1−IA,l).
EXIT Functions for Hadamard Codes over BIAWGN Channel
Next we consider the EXIT functions of Hadamard codes in the context of RZH codes with parallel decoding. We first consider the average mutual information about the information bits d which is given by
Where IE,d
Let cj=[cj,1, cj,2, . . . , cj,n]T denote the j-th codeword of the Hadamard code over GF(2). For cj, we have cj,2
where “” is the logical “or” operation. It is clear that V(S,q) is either {1} or φ. Further define
Then we have the following results for Hadamard codes that will be subsequently used:
Lemma 4.1.
For Hadamard codes C with order r, we have
Proof:
Since Ag,h,j,kd
for all possible {dl}l≠i. Since GH,r is in systematic form, gi can be written as [ui,pi] where ui=[u0, u1, . . . , ur] with ul=0 for l≠i and ui=1. By switching the rows gi and gl, we obtain GH,r(1) with g(1)=gl and gl(1)=gi. It is clear that the subcode Ci(1) generated by GH,r(1) is identical to Ci. We further construct GH,r(2) from GH,r(1) by letting (gi(2)=gi(1)+(gl(1)+gi(1))=gl(1)=gi, and gl(2)=gl(1)+(gl(1)+gi(1))=gi(1)=gl, by which we have GH,r(2)=GH,r(1) and hence Ci(2)=Ci. The effect of transforming GH,r(1) to GH,r(2) is only to change the order of the coded bits. Since both codes are systematic codes, there is one order change between systematic bit position i and l (note that there are only two l's in ui+ul), and all the other changes are happened between parity bit positions. It is clear that Ci(2)=Ci is the ·Cl* we are looking for and this concludes the proof.
In case that the size of the code book is not huge, it is easy to compute Ag,h,j,kd,even and Ag,h,j,kd,odd directly from their definitions given the codewords are known. With the above results, the average mutual information about the information bits d can be computed by the following result.
Theorem 4.3.
If the extrinsic and communication channels are AWGN channels with respective mutual information IA,d, IA,p, IA,q and IA,p
where mq=W−1(1−IA,q), md=W−1(1−IA,d), mp=W−1(1−IA,p) and Mp
Proof:
Using Theorem 4.2, (30) and Theorem 4.1, we obtain the above result. Now consider the connection bit q. Similarly, we denote by I1H,q={j|cj,1=1} the set of indices of all Hadamard codewords with the connection bit equal 1, and P(I1H,q) the set of all subsets of I1H,q. Let SεP(I1H,q), then we can obtain V(S,d), V(S,p[m]), and V(S, pm) as in (31), (32) and (34). Define
Then similar to Theorem 4.3, the mutual information of q can be computed by the following result.
Theorem 4.4.
If the extrinsic and communication channels are AWGN channels with respective mutual information IA,d, IA,p and IA,p
where md=W−1(1−IA,d), mp=W−1(1−IA,p) and mp
Now consider the last parity bit pm. Since pm has a channel observation ym, the EXIT function of the last parity bit pm is different from that of q. Again, let C* be a new code formed by all pairs (d, p, q, pm), then we can define I1H,p
by which we can compute the EXIT function for pm as follows.
Theorem 4.5.
If the extrinsic and communication channels are AWGN channels with respective mutual information IA,q, IA,d and IA,p, then we have
where mq=W−1(1−IA,q), md=W−1(1−IA,d) and mp=W−1(1−IA,p).
The following example demonstrates the computing of EXIT functions for Hadamard codes.
Consider a Hadamard code with r=4. The code book of C can be easily obtained, from which we are able to obtain Ag,h,j,kd,even and Ag,h,j,kd,odd. Let IA,p=0.01, and IA,q=IA,p
BER Estimation of RZH Codes with Parallel Decoding
For an (n,k) IRZH codes, the outer code consists of k repetition codes with variable rates and the EXIT functions of repetition decoders are identical to the case where the serial decoding is employed. Also, since the connection bit nodes are viewed as variable nodes with degree 2, the corresponding EXIT functions for q and pm are simply the EXIT functions for rate ½ repetition code without message from the channel. Now we have both the EXIT functions of the outer repetition decoder and the inner Hadamard decoder, we can then trace the mutual information exchanged between the two constituent components for a given degree profile and calculate the corresponding BER after a given number of iterations as in [?], with which we are able to perform degree profile optimization by using differential evolution (DE).
Specifically, let Ich be the mutual information about the LLRs of the coded bits transmitted from the communication channel. For a BIAWGN channel with
Also let IA,aH, IA,qH, IA,p
where
Code Ensemble Optimization
For given r and Rc, the optimal IRZH ensemble parameters {ai} are the one that minimize Eb/N0, subject to a vanishing BER Pb. In practice, the vanishing BER condition is often replaced by a BER threshold ε for a given iteration number Nit, i.e., Pb(Nit)<ε, which leads to the following optimization problem
To solve (17) for irregular RZH codes with parallel decoding, we resort to the differential evolution (DE) algorithm, which is a powerful population-based genetic algorithm and was introduced for finding the optimal degree profile of the irregular LDPC codes. The essential idea behind DE is a self-organizing scheme to generate a trial parameter vector (which is {ai} in our case) by adding the weighted difference between two population vectors of the current generation to a third vector which is the target vector. If the trial vector has a smaller cost value (which is Pb in our case and can be estimated by using the EXIT functions of the component codes as discussed in Section 1) than the target vector, it survives into the next generation of the evolution. After a given number of evolutions, the vector with the smallest cost value among the population of current generation is the optimized parameter vector. Note that although there is no mathematical convergence proof of DE, it is believed to be a simple and reliable global optimization method. To find the solution to (17) for given Rc and r, we first choose an Eb/N0 and find a degree profile {ai} using DE that satisfies the BER constraint ε. If at least one {ai} exists, the Eb/N0 is reduced and the procedure is repeated until no such a vector {ai} exists. The smallest value of Eb/N0 for which a power profile {ai} satisfies the BER constraint is the desired minimum SNR and the corresponding {ai} is the optimized degree profile.
Numerical Results
The following are several examples for RZH code optimization with the previously proposed design methods.
An un-punctured regular RZH code with r=4 and dv=14 which results in a coding rate of around 0.018.
where the degree profile polynomial is given by f(x)=0.323x3+0.175x8+0.026x22+0.476x23. The corresponding EXIT chart for
−0.98 dB is also plotted 700 in
The graph 800 of
with f(x)=0.363x3+0.338x6+0.299x7, and the simulated threshold (measured at Pb=10−4) is −1.13 dB, which is only 0.41 dB away from the capacity.
Next is the ensemble optimization of the systematic IRZH codes. Since the repetition bits are punctured, much better performance can be expected. Indeed, for r=4 and Rc=0.05, we are able to obtain an irregular code at
with f(x)=0.467x3+0.375x10+0.158x11, which is only 0.1 dB away from the capacity. The EXIT chart of the curve-fitting result 900 is shown in
with f(x)=0.364x3+0.014x11+0.192x12+0.074x13+0.095x36+0.136x37+0.1087x38+0.004x39+0.013x200, and the simulated SNR threshold is around −1.2 dB, which is 0.34 dB away from the capacity and around 0.8 dB better than the same rate un-punctured code with r=6. With r=6, a code is optimized at
with f(x)=0.401x3+0.573x7+0.026x20, and the simulated SNR threshold is −1.24 dB, which is slightly better than that of r=4.
Next some design examples of IRZH codes with parallel decoding are provided. First the performance of the regular code with parallel decoding is considered. Consider a regular systematic RZH code with r=4 and
By setting r=4 and
The method for code design for IRZH codes is detailed by flow chart 40A in
Design for Serial Decoding
The decoding of RZH code is based on its tanner graph 30 which is depicted in
Chart 40A details the steps for IRZH code design for serial decoding. Step 1: a small signal to noise ratio Es/N0 is initially chosen 42A. Step 2: for a given Hadamard order r and Es/N0, the EXIT curve for ZH code is obtained by Monte Carlo simulation using serial decoding 43A. Step 3: with the obtained EXIT curve there is an attempt to find the optimal IRZH ensemble parameters {ai} that maximize coding rate subject to vanishing BER by solving the following optimization problem
This problem can be solved by any linear optimization program 44A. The vanishing BER condition can be implemented by checking the existence of a decoding tunnel between the EXIT curve of the ZH code obtained in step 2 and that of outer repetition codes. Namely, the curve defined by a particular degree profile lies below the EXIT curve of ZH code in the EXIT chart. Step 4: if the maximum rate obtained by step 3 is smaller than the target rate, the signal to noise ratio Es/N0 is increased by a small amount and step 2 and 3 are repeated, until the obtained achievable rate equals to the target rate 45A.
Design for Parallel Decoding
As in
Chart 50A details the steps for IRZH code design for parallel decoding. Step 1: a relatively large signal to noise ratio SNR Eb/N0 is initially chosen 52A. Step 2: for a given Hadamard order r coding rate Rc and SNR, a degree profile that has minimum BER by using deferential evolution (DE) is found 53A. During the DE optimization, BER is computed, which can be done by a mutual information tracking scheme. EXIT functions of the Hadamard codes in AWGN channel are derived, with which the BER can be easily estimated 54A. Specifically, the EXIT functions for the information bits are given by:
similarly, the EXIT function for the connection bits can be computed by
and the EXIT function for the last parity bit is given by
where the details of the variables in the above equations are explained elsewhere herein. Step 4: if the minimum BER obtained by step 2 is smaller than the target BER requirement, the signal to noise ratio SNR Eb/N0 is reduced and step 2 is repeated, until the target BER requirement cannot be achieved 55A. The least SNR that can still achieve the BER requirement is the minimum SNR and the corresponding degree profile is the optimized degree profile.
In summary, the present code design method is optimized for IRZH codes with serial and parallel decoding schemes. For serial decoding, the EXIT functions are obtained via simulation; on the other hand, for parallel decoding, the EXIT functions of Hadamard codes in the context of RZH codes are derived. With these EXIT functions, BERs for a given code profile can be easily estimated and either curve fitting (for serial decoding) or differential evolution (DE) technique (for parallel decoding) can be employed to optimize the degree profile for the given design parameters, e.g., the coding rate and the Hadamard order. The techniques introduced in this report can also be easily extended to the design of general low-density parity-check codes where the check nodes are replaced by other linear block codes, e.g., Hadamard codes or Hamming codes.
The present code design method for irregular repeat-zigzag-Hadamard (IRZH) codes to approach capacity with turbo-like serial decoding or LDPC-like parallel decoding is quite different from current techniques and provides significant advantages. With respect to current design methods for LDPC codes, a check node of a LDPC code is a single parity-check constraint. The design procedure for LDPC codes is similar to that of IRZH codes with parallel decoding. The difference is that with the present method it is a common practice to use the analytical EXIT function of the inner check node over BEC to approximate that over BIAWGN channel. Results show that such an approximation works very well for irregular LDPC code design. However, such a BEC approximation design method provides less satisfactory results for RZH code design with parallel decoding. For instance, for r=4 and dv=7, with BEC approximation, one is able to design an IRZH code with a simulated SNR threshold of −0.79 dB, whereas with the present method EXIT functions derived for AWGN channel, one can obtain a code with a simulated SNR threshold of −1.15 dB, which is only 0.29 dB away from the capacity. With respect to current design methods for LDPC-Hadamard codes, the EXIT functions of the Hadamard check nodes are obtained by Monte Carlo simulation, consequently, the optimization procedure is time-consuming. With the present design method based on the analytical EXIT functions, the optimization complexity can be significantly reduced.
The present EXIT-function-based design method offers high quality design results whereas the optimization complexity is low. Note that although density-evolution can be used for the design of IRZH code, the complexity is very high.
Although with the present turbo-like decoding, in which the inner decoder is a trellis-based zigzag-Hadamard (ZH) decoder, an analytical expression of its EXIT function is not available and there is use of Monte Carlo simulations to obtain the EXIT functions of the inner code, since the EXIT function of the inner code is a one dimension function for a given SNR the optimization complexity is still low.
For LDPC-like parallel decoding, the connection bits of the ZH code are treated as degree-2 variable nodes, and the inner constituent decoder becomes a Hadamard decoder. Although simulation can still be utilized to obtain the EXIT function, the present method derives analytical EXIT functions of Hadamard codes with multiple inputs and outputs in the context of low-rate RZH codes over BIAWGN channels, and applies these results to the analysis and design of RZH codes. With analytical functions, the optimization procedure is further simplified.
Test results show that the present design method works well and serves as practical tool for the low-rate IRZH code optimization. The present design method can also be extended to general LDPC codes where the single parity-check nodes are replaced by other linear codes, e.g., Hadamard codes or Hamming codes.
The present invention has been shown and described in what are considered to be the most practical and preferred embodiments. That departures may be made there from and that obvious modifications will be implemented by those skilled in the art. It will be appreciated that those skilled in the art will be able to devise numerous arrangements and variations which, although not explicitly shown or described herein, embody the principles of the invention and are within their spirit and scope.
This application claims the benefit of U.S. Provisional Application No. 60/806,152, entitled “Code Design Methods for Repeat-Zigzag Hadamard Codes”, filed on Jun. 29, 2006, and U.S. Provisional Application No. 60/806,149, entitled “Low-Complexity High-performance Low-Rate-Code”, filed on Jun. 29, 2006, the contents of both which are incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
6222946 | Abe | Apr 2001 | B1 |
6925107 | Hagenauer et al. | Aug 2005 | B2 |
Number | Date | Country | |
---|---|---|---|
20080008270 A1 | Jan 2008 | US |
Number | Date | Country | |
---|---|---|---|
60806152 | Jun 2006 | US | |
60806149 | Jun 2006 | US |