 Review
 Open Access
 Published:
GLDPCStaircase ALFEC codes: a fundamental study and new results
EURASIP Journal on Wireless Communications and Networking volume 2016, Article number: 206 (2016)
Abstract
This paper provides fundamentals in the design and analysis of Generalized LowDensity Parity Check (GLDPC)Staircase codes over the erasure channel. These codes are constructed by extending an LDPCStaircase code (base code) using ReedSolomon (RS) codes (outer codes) in order to benefit from more powerful decoders. The GLDPCStaircase coding scheme adds, in addition to the LDPCStaircase repair symbols, extrarepair symbols that can be produced on demand and in large quantities, which provides small rate capabilities. Therefore, these codes are extremely flexible as they can be tuned to behave either like predefined rate LDPCStaircase codes at one extreme, or like a single RS code at another extreme, or like small rate codes. Concerning the code design, we show that RS codes with “quasi” Hankel matrixbased construction fulfill the desired structure properties, and that a hybrid (IT/RS/ML) decoding is feasible that achieves maximum likelihood (ML) correction capabilities at a lower complexity. Concerning performance analysis, we detail an asymptotic analysis method based on density evolution (DE), extrinsic information transfer (EXIT), and the area theorem. Based on several asymptotic and finite length results, after selecting the optimal internal parameters, we demonstrate that GLDPCStaircase codes feature excellent erasure recovery capabilities, close to that of ideal codes, both with large and very small objects. From this point of view, they outperform LDPCStaircase and Raptor codes and achieve correction capabilities close to those of RaptorQ codes. Therefore, all these results make GLDPCStaircase codes a universal ApplicationLayer FEC (ALFEC) solution for many situations that require erasure protection such as media streaming or file multicast transmission.
Review
LowDensity Parity Check (LDPC) codes have been intensively studied during the last decade due to their nearShannon limit performance under iterative beliefpropagation (BP) decoding [1–3]. A (N,K) LDPC code, where N is the code length and K is its dimension, can be graphically represented as a bipartite graph with N “variable nodes” (VNs) and M=N−K “check nodes” (CNs). Equivalently, LDPC codes can be represented through their H _{ L } parity check matrix translating the connection between VNs and CNs. The degree of a VN or a CN is defined as the number of edges connected to it. A VN of degree n can be interpreted as a “length repetition code” (n,1), i.e., as a linear block code repeating n times its single information bit towards the CN set. Similarly, a CN of degree n can be interpreted as a Single Parity Check (SPC) code (n,n−1), i.e., as a linear block code associated with one parity equation. To improve error floor, minimal distance, and decoding complexity performances, a generalization of these codes was suggested by Tanner in [3], for which subsets of the variable nodes obey a more complex constraint than an SPC constraint. The SPC check nodes in a GLDPC structure are replaced with a generic linear block codes (n,k) referred to as subcodes or component codes while the sparse graph representation is kept unchanged. More powerful decoders at the check nodes have been investigated by several researchers in recent years after the work of Boutros et al. [4] and Lentmaier and Zigangirov [5] where BCH codes and Hamming codes were proposed as component codes, respectively. Later several works, on several channels, have been carried out in order to afford very large minimum distance and exhibit performance approaching Shannon’s limit. Each construction differs from others by modifying the linear block codes (component codes) on the check nodes [6, 7, 7–11] or/and the distribution of the structure of GLDPC codes [6] to offer a good compromise between waterfall performance and error floor under iterative decoding.
A GLDPCStaircase code is an LDPCStaircase code [12] in which the constraint nodes of the code graph are ReedSolomon (RS) codes (rather than SPCs) in order to benefit from more powerful decoders. The construction of these RS codes, with the desired properties, is omitted from the initial work [13]. Therefore in [14], we introduce RS codebased Hankel matrices to that purpose. GLDPCStaircase codes differ from the GLDPC codes proposed by Tanner and their successive variants. In particular, the GLDPCStaircase coding scheme allows each check node to produce a potentially large number of repair symbols in terms of RS codes, called extrarepair symbols, on demand. These extrarepair symbols extend the base LDPCStaircase code and very small rates are easily achievable. This feature is well suited to situations where channel conditions can be worse than expected and to fountainlike content distribution applications. More generally, these codes can easily be tuned to behave either like predefined rate LDPCStaircase codes at one extreme, or like a single RS code at another extreme, or like a small rate code.
From a decoding perspective, we propose a new hybrid (IT/RS/ML) decoding approach that achieves the optimal correction capabilities of ML decoding at a lower complexity [14]. Finally, in order to analyze their performance, we detail in [15] an asymptotic analysis method based on the density evolution (DE) and extrinsic information transfer (EXIT) tools and the area theorem. Then, using this theoretical analysis combined with a finite length analysis, we discuss the impacts of the code structure and its internal parameters on performance.
Asymptotic and finite length analyses show that these codes achieve excellent decoding performance (i.e., good average decoding overhead, good waterfall region, small error floor, and channel capacity approaching performance), close to that of ideal codes, both with very large and very small objects. This independence with respect to the code dimension is a key practical benefit (e.g., LDPC codes are known to be asymptotically good only). We show in this work that our codes outperform the Raptor codes as well as some GLDPC codes, while being close to RaptorQ codes. Their extreme flexibility makes it possible to tune them to perfectly match each usecase (like low bitrate streaming applications or at the opposite large file multicast transmission). The purpose of this paper is to give the reader a detailed overview of GLDPCStaircase codes and to provide new results.
This paper is organized as follows. Section 2 focuses on the design of GLDPCStaircase codes based on RS codes. Then in Section 3, we explain the proposed asymptotic analysis method. Section 4 presents several analyses and optimizations of GLDPCStaircase codes. Then, we analyze the achieved performance, compare these codes with other erasure codes, and provide preliminary decoding complexity results in Section 5. Finally, we conclude.
GLDPCStaircase code design
Code description
As mentioned in introduction, GLDPCStaircase codes are constructed from:

LDPCStaircase code: this is the base code with length N _{ L } and dimension K. Let M _{ L }=N _{ L }−K and let H _{ L }=(H _{1}H _{2}) be the associated parity check matrix^{1}. From the LDPCStaircase viewpoint, each row of H _{ L } defines the connections between the source and LDPC repair symbols. From the GLDPCStaircase viewpoint, each row of H _{ L } defines the connections between the RS repair symbols and the source and LDPC repair symbols. Consequently, each LDPCStaircase CN is represented as a powerful CN, called generalized check node, with GLDPCStaircase codes.

RS codes: they are the outer codes (or components codes). A generalized check node of index m can generate e(m) extrarepair symbols from the RS point of view (plus one LDPC repair symbol if we use scheme A as we will see below). This is done with an RS (n _{ m },k _{ m }) encoding over G F(2^{b}) with 0≤e(m)≤E and m=1,...,M _{ L }. Here, E, k _{ m }, and n _{ m } are respectively the maximum number of extrarepair symbols per generalized check node, the RS code dimension and length for the generalized check node m.
Figure 1 illustrates the bipartite graph of a GLDPCStaircase \(\left (N_{G}, K \right)\) code of length N _{ G } and dimension K. It is composed of two sets of nodes:

the generalized check node that corresponds to RS codes;

the variable nodes (VN) further divided into three categories:

source symbols;

LDPC repair symbols;

extrarepair symbols.

Schemes A and B
Let us now define two variants, schemes A and B, depending on the definition of n _{ m } and k _{ m }:

Scheme A
For row m>1, the source symbols (from the user viewpoint) involved in this row plus the LDPC repair symbol of row m−1 are considered as source symbols from the RS viewpoint. The new LDPC repair symbol plus the e(m) extrarepair symbols are considered as repair symbols from the RS viewpoint. Therefore, the LDPC repair symbol is also an RS repair symbol. For m=1, the only difference is that there is no previous repair symbol (beginning of the staircase).
No matter the row, we have
$$ n_{m} = k_{m} + 1 + e(m) ~ \text{and} ~ k_{m} = d_{r}(m)  1, $$(1)where d _{ r }(m) is the degree of row m of H _{ L }. Due to the staircase structure of H _{2}, it follows
$$ { d_{r}(m) = \left\lbrace \begin{array}{ccc} d_{r_{H_{1}}}+ 1 & \text{if} & m=1 \text{;} \left(d_{r_{H_{1}}} = \frac{N_{1}}{\frac{1}{r_{L}}1}\right)\\ d_{r_{H_{1}}} + 2 & \text{if} & m>1 \text{;} \left(d_{r_{H_{1}}} = \frac{N_{1}}{\frac{1}{r_{L}}1}\right). \end{array}\right. } $$(2)In order to fulfill the duality property of the LDPC repair symbols, we propose in [16] a specific construction of RS codes based on “quasi” Hankel matrix. The generator matrix G of these codes has the following form:
$$ G =\left[ \begin{array}{cccccccccc} 1&0&\ldots&\ldots&0&\boldsymbol{1}&1&\ldots&\ldots&1 \\ 0&1&\ddots&\ddots&\vdots&\boldsymbol{1}&b_{1}&b_{2}&\ldots&b_{n_{m}k_{m}} \\ 0&0&\ddots&\ddots&\vdots&\boldsymbol{1}&b_{2} &{{\cdot}{\raisebox{3pt}{$\cdot$}}{\raisebox{6pt}{$\cdot$}}}& {{\cdot}{\raisebox{3pt}{$\cdot$}}{\raisebox{6pt}{$\cdot$}}} &b_{n_{m}k_{m}+1}\\ \vdots&\vdots&\ddots&\ddots&0&\vdots&\vdots&{{\cdot}{\raisebox{3pt}{$\cdot$}}{\raisebox{6pt}{$\cdot$}}}&{{\cdot}{\raisebox{3pt}{$\cdot$}}{\raisebox{6pt}{$\cdot$}}}&\vdots \\ 0&0&\ldots&0&1&\boldsymbol{1}&b_{k_{m}}&{{\cdot}{\raisebox{3pt}{$\cdot$}}{\raisebox{6pt}{$\cdot$}}}&{{\cdot}{\raisebox{3pt}{$\cdot$}}{\raisebox{6pt}{$\cdot$}}}&b_{n_{m}1} \\ \end{array} \right] $$(3)where \(b_{i} = \frac {1} {1 {y}^{i}}\), for 1≤i≤q−1, y is an arbitrary primitive element of G F(q) and y ^{i} is computed over G F(q).
Thanks to the column full of “1” in G for the first RS repair symbol, this latter can also be considered as an LDPCStaircase symbol (it is the XOR sum of source symbols from the RS viewpoint).

Scheme B
For each row m, the various source symbols (from the user viewpoint) involved in this row plus the LDPC repair symbol(s) are considered as source symbols from the RS viewpoint. The e(m) extrarepair symbols are the only repair symbols from the RS viewpoint. No matter the row, we have
$$ n_{m} = k_{m} + e(m)~\text{and}~k_{m} = d_{r}(m). $$(4)Here, any RS code (e.g., based on Hankel, Cauchy, or Vandermonde matrices) can be used.
Extrarepair symbol regular/irregular distributions
For a fixed code rate r _{ L } of LDPCStaircase code (N _{ L },K), the code rate of the GLDPCStaircase code is given by
where \(\bar {f}\) is the average number of extrarepair symbols per generalized check node:
and f _{ e } denotes the fraction of generalized check nodes with e extrarepair symbols:
We can consider the following two distributions of extrarepair symbols on the various generalized check nodes:

Regular distribution: f _{ e }=0 for \(e \in \{0,1,\dots,E1\}\) and f _{ E }=1. Thus, each generalized check node m has the same number e(m)=E of extrarepair symbols and the rate of the extended code (GLDPCStaircase code) is
$$ r_{G} =\frac{r_{L}}{1+ (1  r_{L})*E} $$(8)Figure 1 shows such a regular variant.

Irregular distribution: the generalized check nodes can have a different number of extrarepair symbols.
Figure 2 shows such an irregular variant.
Cunche et al. [13] shows that there exists an irregular uniform distribution of extrarepair symbols which achieves performance close to the optimal irregular distribution. This irregular uniform distribution allows to allocate the extrarepair symbols with \(\bar {f} =\frac {E}{2}\) and \(f_{e}=\frac {1}{E+1}\) for \(e \in \{0,1,\dots,E\}\).
Throughout this paper, we only consider the regular distribution and the irregular uniform distribution, and we assess in Section 4.4.1 their impacts on performance.
Encoding method
Encoding generates two types of repair symbols:

M _{ L } LDPCStaircase repair symbols, (p _{1}, …\(p_{M_{L}}\)), and

\(M_{L}\bar {f}\) extrarepair symbols, ((e _{1,1}, … e _{1,e(1)}), …(\(e_{M_{L},1}\), …\(e_{M_{L},e(M_{L})}\))).
Let S=(S _{1},S _{2},…S _{ K }) be the K source symbols. The \((p_{1}, \ldots p_{M_{L}})\phantom {\dot {i}\!}\) repair symbols are computed following the “stairs” of H _{ L }: p _{ m } is the XOR sum of the subset x of S of source symbols that have a “1” coefficient in row m, plus p _{ m−1} if m>1.
Then, the e(m) extrarepair symbols for row m are computed by multiplying the k _{ m } LDPC symbols by the systematic generator matrix G _{ m } of RS \(\left (n_{m}, k_{m} \right)\) associated to this row^{2}.
Example 2.1.
Consider the GLDPCStaircase code, scheme A, defined by the bipartite graph of Fig. 1. We have N _{ G }=13, K=4 and exactly e(m)=2 extrarepair symbols per generalized check node (regular distribution). H _{ L } and the various RS codes are as follows:
We note that here (regular distribution and scheme A), the same RS code can be used for all the rows. Its generator matrix G _{ rs } has the form
To summarize, encoding is as follows:

First row, using x=(S _{1},S _{2},S _{4}), produces
$$ P_{1} = G^{4}_{rs}\times (S_{1}, S_{2}, S_{4}) $$$$ e_{1,1} = G^{5}_{rs} \times (S_{1}, S_{2}, S_{4}) $$$$ e_{1,2} = G^{6}_{rs} \times (S_{1}, S_{2}, S_{4}) $$ 
Second row, using x=(S _{2},S _{3}), produces
$$ P_{2} = G^{4}_{rs}\times (S_{2}, S_{3}, P_{1}) $$$$ e_{2,1} = G^{5}_{rs} \times (S_{2}, S_{3}, P_{1}) $$$$ e_{2,2} = G^{6}_{rs} \times (S_{2}, S_{3}, S_{1}) $$ 
Third row, using x=(S _{1},S _{4}), produces
$$ P_{3} = G^{4}_{rs}\times (S_{1}, S_{4}, P_{2}) $$$$ e_{3,1} = G^{5}_{rs} \times (S_{1}, S_{4}, P_{2}) $$$$ e_{3,2} = G^{6}_{rs} \times (S_{1}, S_{4}, P_{2}) $$
A key advantage is the fact that extrarepair symbols can be produced incrementally, on demand, rather than all at once (unlike LDPCStaircase repair symbols for instance). Their number can also be rather high since it is only limited by the finite field size, usually GF(2^{8}). Said differently, GLDPCStaircase codes can easily and dynamically be turned into small rate codes.
Decoding method
To recover erased source symbols, in addition to the (IT + RS) decoding method, we proposed a new decoding approach called hybrid (IT/RS/ML) decoding.
Let us consider a GLDPCStaircase (N _{ G },K) code, built from an LDPCStaircase (N _{ L },K) base code.
(IT + RS) decoding
The (IT + RS) decoding, for both schemes A and B, consists of a joint use of

the IT decoder over the LDPCStaircase graph. Extrarepair symbols are ignored at this step. This decoder features a linear complexity but also suboptimal erasure recovery capabilities;

the RS decoder over a given generalized check node. This is a classic RS decoding that takes into account the three types of symbols. This decoder features a higher complexity but is MDS;
Example 2.2.
Figure 3 shows a simple example for GLDPCStaircase code, scheme A, with N _{ G }=12, K=4, N1=3, and \(r_{L}=\frac {1}{2}\). Here we assume that only symbols {S _{1},P _{1},P _{2},P _{3},e _{1},e _{2}} have been received. The receiving order for these symbols is {S _{1},P _{1},P _{2},e _{2},e _{1},P _{3}} (i.e., symbol transmission order is random). After receiving the first four symbols, the RS decoder triggers on the second generalized check node. This node is associated with RS(6, 4) code which recovers the (S _{2}, S _{3}) erased symbols in step 2. Then these recovered symbols trigger the SPC decoding on the first generalized check node which recovers S _{4} in step 3. Decoding is successful.
Finally, Algorithm 1 details the (IT + RS) decoding that works symbol per symbol, in a recursive manner. This algorithm does not necessarily use all the received symbols: IT decoding is always preferred to RS decoding if both are possible, in order to reduce decoding complexity.
Hybrid (IT/RS/ML) decoding
We propose an hybrid (IT/RS/ML) decoding, generalization of the decoding approach proposed for LDPC codes in [17, 18]. Hybrid (IT/RS/ML) decoding consists of a joint use of IT, RS, and (binary/Non binary) ML decoding to achieve the performance of ML decoding at a lower complexity. It works as follows. It starts with (IT + RS) decoding. If (IT + RS) decoding succeeds, the hybrid decoding succeeds. Otherwise, the receiver switches to ML decoding, using the simplified linear system that results from the (IT + RS) decoding.
During ML decoding, we use the following decoders:

Binary ML decoder: extrarepair symbols are ignored at this step and instead it only considers binary equations, made of simple XOR sums, in order to reduce complexity. ML decoding can consist of simple Gaussian elimination (GE) on this subsystem.

Nonbinary ML decoder: the full linear system is considered here and GE is performed on G F(2^{b}). As in binary ML decoding, this step also features a quadratic complexity but operations are now significantly more complex (performed on G F(2^{b}) instead of simple XOR). However, it allows reaching the maximum correction capabilities of the code.
The hybrid (IT/RS/ML) decoding algorithm is presented in Algorithm 2.
Asymptotic analysis method
Preliminaries
In the sequel, we denote by d _{ vmax } and d _{ cmax } respectively the maximum variable and check node degrees in the bipartite (Tanner) graph associated with LDPCStaircase. Following [19], we define the edgeperspective DD polynomials by (λ(x), ρ(x)) and the node perspective DD polynomials by (\(L(x)=\lambda (x) = \sum _{i=1}^{dvmax} \lambda _{i}.x^{i1}\), \(R(x)=\sum _{i=1}^{dcmax} \rho _{i}.x^{i1}\)).
Given a GLDPCStaircase code, DD pair (λ, ρ) are defined by the underlying LDPCStaircase code, defined by the bottom graph of Fig. 1 (that is, not containing the extrarepair nodes). Assume that transmission takes place over an erasure channel with parameter ε. We denote by \({\mathcal {E}}(\lambda, \rho, {f_{e}})\) the ensemble of GLDPCStaircase with DD pair (λ, ρ) and with f _{ e } the fraction of generalized check nodes with e extrarepair symbols as presented in Eq. (7).
Density evolution
Introduction
Over erasure channels, DE becomes onedimensional, and it allows to analyze and even to construct capacityachieving codes [20]. It works by recursively tracking the erasure probability messages passed around the edges of the graph during IT decoding. Roughly speaking, this means that it recursively computes the fraction of erased messages passed during the IT decoding. Using this technique, the decoding threshold of codes is defined as the supremum value of ε (that is, the worst channel condition) that allows transmission with an arbitrary small error probability assuming N goes to infinity [19].
Let us determine the DE equations of GLDPCStaircase codes.
DE equations of GLDPCStaircase codes
Assume that an arbitrary GLDPCStaircase code from \({\mathcal {E}}(\lambda, \rho, {f_{e}})\), with length N _{ G } goes to infinity.
We are interested in the erasure probability of messages exchanges by the (IT + RS) decoding along the messages of the LDPCStaircase code using extrarepair variable nodes. We denote by

P _{ ℓ }, the probability of an LDPC symbol (source or repair) node sending an erasure at iteration ℓ to the connected generalized check nodes. Clearly, P _{0} is equal to the channel erasure probability ε.

Q _{ ℓ }, the probability of a generalized check node sending an erasure (to an LDPC symbolnode) at iteration ℓ.
The calculus of these probabilities depends on the coding scheme used to design the GLDPCStaircase code (scheme A or B). Next, we give more details for each case. At iteration ℓ, the LDPC symbols are erased with probability P _{ ℓ }, while extrarepair symbols are always erased with probability ε (the channel erasure probability).
Scheme A: The first repair symbol generated by any RS code is one of the repair symbols of the LDPCStaircase code.
Consider a generalized check node c connected to symbolnodes \((v_{1},\dots,v_{d},e_{1,c},\dots,e_{e(c),c})\) where v _{ i } denotes an LDPC (source or repair) symbol node and e _{ i,c } denotes the ith extrarepair symbol node. Since c corresponds to an RS code, it can recover the value of an LDPC symbol node, say v _{1}, if and only if the number of erasures among the other symbolnodes \((v_{2},\dots,e_{e(c),c})\) is less than or equal to e(c).
It follows that the probability of a generalized check node c recovering the value of an LDPC symbol at iteration ℓ+1, denoted by \(\bar {Q}_{\ell +1,A}(d, e(c))\), is given by:
Hence, the probability of a generalized check node c sending an erasure to an LDPC symbol at iteration ℓ+1 is \((1 \bar {Q}_{\ell +1,A}(d, e(c)))\). Averaging over all possible values of d and e(c), we get
Scheme B: All the LDPCStaircase repair symbols are source symbols for the RS codes.
Consider a constraint node c connected to symbolnodes \((v_{1},\dots,v_{d},e_{1,c},\dots,e_{e(c),c})\) where v _{ i } denotes an LDPC (source or repair) symbol node and e _{ i,c } denotes the ith extrarepair symbol node. The node c corresponds both to a parity check constraint between LDPC symbol nodes \((v_{1},\dots,v_{d})\) and to an RS linear constraint between all the symbolnodes \((v_{1},\dots,v_{d},e_{1,c},\dots,e_{e(c),c})\).
Thus, c can recover the value of an LDPC symbol node, say v _{1}, if and only if one of the following (disjoint conditions) holds:

there are no erased symbols among \(v_{2},\dots,v_{d}\) (i.e., LDPC decoding);

there is at least one erased symbol among \(v_{2},\dots,v_{d}\), but the number of erasures among all the symbolnodes \((v_{1},\dots,v_{d},e_{1,c},\dots,e_{e(c),c})\) is less than or equal to e(c)−1.
The second condition is also equivalent to the following one:

the number of erased symbols among \(v_{2},\dots,v_{d}\) is equal to i and the number of erased symbols among \(e_{1,c},\dots,e_{e(c),c}\) is equal to j, with \(1 \leq i \leq \min (d1,e(c)1)\) and 0≤j≤e(c)−1−i.
It follows that the probability of a generalized check node c recovering the value of an LDPC symbol at iteration ℓ+1, denoted by \(\bar {Q}_{\ell +1,B}(d, e(c))\), is given by
Averaging over all possible values of d and e(c), we get
Remark 3.1.
For both schemes with regular distribution of extrarepair symbols, all the generalized check nodes have E extrarepair symbols, the Eqs. (12) and (14) are reduced to:
Conversely, for both schemes, an LDPC symbol node v of degree d, connected to generalized check nodes \(c_{1},\dots, c_{d}\), sends an erasure to c _{1} iff it was erased by the channel, and it received erased messages from all generalized check nodes \(c_{2},\dots, c_{d}\). Since this happens with probability \(\varepsilon \cdot Q_{\ell +1}^{d1}\), and averaging over all possible degrees d, we get
For both schemes, using Eqs. (11) or (13), (12) or (14), and (16), we can determine a recursive relation between P _{ ℓ } and P _{ ℓ+1}, with P _{0}=ε.
The decoder can recover from a fraction of ε erased symbols iff \({\lim }_{\ell \rightarrow +\infty }P_{l} =0\). This means that, when \(l \to +\infty \), the (IT + RS) decoding succeeds if the DE recursion converges to zero. Then, the (IT + RS) decoding threshold of an GLDPCStaircase code over an erasure channel is defined as the supremum value of ε such that the DE recursion converges to zero. Therefore, the (IT + RS) decoding threshold can be computed by
If we transmit at ε≤ε ^{(IT+RS)}, then all the erased LDPC symbols can be recovered. But if we transmit at ε>ε ^{(IT+RS)}, then some or all the erased LDPC symbols remain erased after the decoding ends.
Additionally, using the DE recursion equation, we can plot the evolution of the (IT + RS) decoding process of an GLDPCStaircase code for an erasure channel probability ε by tracing P _{ ℓ+1}=f(P _{ ℓ }) with \(l \to +\infty \) as shown in the following example.
Example 3.1.
Let us consider a GLDPCStaircase (scheme A) code with the following parameters:

Rate: \(r_{G}=\frac {1}{2}\)

Base code: r _{ L }=0.8, N1=5
$$ DD: \left\lbrace \begin{array}{l} \lambda(x) = 0.0909.x^{1}+0.9091.x^{4}, \rho(x) = x^{21}\\ L(x) = 0.2.x^{2}+0.8.x^{5}, R(x) =x^{22} \\ \end{array}\right. $$(18) 
E=3 (regular distribution of extrarepair symbols).
Figure 4 provides the evolution of erasure probability during the (IT + RS) decoding of GLDPCStaircase at ε=0.3. The initial fraction of erasure messages emitted by the LDPC variable nodes is P _{0}=1. After an iteration (at the next output of the LDPC variable nodes), this fraction has evolved to P _{1}=0.3. After second full iteration, i.e., at the output of the LDPC variable nodes, we see an erasure fraction of P _{2}=0.2555. This process continues in the same fashion for each subsequent iteration, corresponding graphically to a staircase function which is bounded above by P _{ ℓ+1}=P _{ ℓ } and below by P _{out}.
EXIT functions of GLDPCStaircase codes
Introduction
EXIT technique is a tool for predicting the convergence behavior of iterative processors for a variety of communication problems [21]. Over erasure channel, to visualize the convergence of iterative systems, rather than mutual information, the entropy information can be used (i.e., one minus mutual information). It is natural to use entropy in the setting of the erasure channel since the parameter ε itself represents the channel entropy. We focused in our work on EXIT based on entropy to evaluate the performance of GLDPCStaircase codes under (IT + RS) and ML decoding. Therefore, we extended the method presented in [22]. These EXIT functions are based on DE equations derived in Section 3.2. The EXIT technique defined in this section relates to the asymptotic performance of the ensemble \({\mathcal {E}}(\lambda, \rho, {f_{e}})\) under the decoding.
(IT + RS) EXIT function: h ^{(IT+RS)} (ε)
The (IT + RS) EXIT function of GLDPCStaircase code is denoted by h ^{(IT+RS)}(ε). It corresponds to running an (IT + RS) decoder on a very large LDPCStaircase graph that is connected to the extrarepair variable nodes at ε until the decoder reaches a fixed point. This fixed point defines the stability of erasure probability improvement during decoding iterations. The extrinsic erasure probability of the LDPCStaircase symbols at this fixed point gives the (IT + RS) EXIT function. Therefore, consider an \({\mathcal {E}}(\lambda, \rho, {f_{e}})\), the EXIT function of the GLDPCStaircase codes under (IT + RS) decoding, over erasure channel (ε), is equal to the following equation:
where, \(h^{(\text {IT+RS})}_{i}\) is the extrinsic (IT + RS) erasure probability of LDPCStaircase symbol “i” as shown in Fig. 5. h ^{(IT+RS)}(ε) is the asymptotic (average on all the LDPC variable nodes, \(N_{L}\to +\infty \)) extrinsic erasure probability at the output of an (IT + RS) decoding. This function value can be easily computed using the DE equations of GLDPCStaircase codes. After an infinite number of iterations of the DE recursion (Eq. (16)), the (IT + RS) decoder reaches a fixed point (i.e., P _{ ℓ+1}=P _{ ℓ }, \(\ell \to +\infty \)).
Hence, we can also write
where \({Q}_{+\infty }\) is Q _{ ℓ }, derived from the DE equations of GLDPCStaircase codes in Section 3.2, when the number of iterations goes to infinity.
Next, we present how can visualize the evolution of extrinsic erasure probability during (IT + RS) decoding in a graph called EXIT curve.
(IT + RS) EXIT curve
The (IT + RS) EXIT curve of the GLDPCStaircase code under (IT + RS) decoding can be derived, in terms of extrinsic erasure probability (at the output of the decoder) as a function of the a prior erasure probability (input of the decoder, ε).
Therefore, the asymptotic (IT + RS) EXIT curve, denoted by h ^{(IT+RS)}, is given in a parametric form by
Summarizing, the (IT + RS) EXIT curve is the trace of h ^{(IT+RS)}(ε) equation for ε starting from ε=ε ^{(IT+RS)} until ε=1. In other hand, it is zero up to the (IT + RS) decoding threshold ε ^{(IT+RS)}. It then jumps to a nonzero value and also continues smoothly until it reaches one at ε=1. Therefore, by using this curve, ε ^{(IT+RS)} is given by the value of ε where h ^{(IT+RS)}(ε) drops down to zero.
Example 3.2.
Given a GLDPCStaircase code with rate \(r_{G}=\frac {1}{3}\), 2 extrarepair symbols per generalized check nodes (regular distribution) and base code with the following parameters:

r _{ L }=0.6, N1=5

DD:
$$ \left\lbrace \begin{array}{l} \lambda(x) = 0.2105x^{1} + 0.7895x^{4}, \rho(x) = x^{9}, \\ L(x) = 0.4x^{2} + 0.6x^{5}, R(x) = x^{10} \\ \end{array}\right. $$(22)
The (IT + RS) EXIT function h ^{(IT+RS)}(ε) is depicted in Fig. 6. The (IT + RS) decoding threshold, ε ^{(IT+RS)}, is given by the point where h ^{(IT+RS)}(ε) drops down to zero. This gives ε ^{(IT+RS)}=0.5376. It can be seen that h ^{(IT+RS)}(ε)=0 for values ε≤ε ^{(IT+RS)}, then it jumps to a nonzero value and continues to increase until it reaches a value of 1 for ε=1.
Upper bound on the ML decoding threshold
As for the (IT + RS) decoding, the EXIT curve of the ML decoding is also defined in terms of extrinsic erasure probability based on entropy. Precisely, in the limit of infinite code length, for a given channel erasure probability ε, h ^{ML}(ε) is the probability of a symbol node being erased after ML decoding, assuming that the received value (if any) of this particular symbol has not been submitted to the decoder. The asymptotic, average on all the LDPC variable nodes, extrinsic erasure probability at the output of an ML decoding (ML EXIT function) is obtained by
where, \(h^{ML}_{i}(\varepsilon)\) is the extrinsic erasure probability of LDPC symbol “i” after ML decoding as shown in Fig. 5.
Just like LDPC codes [22], the exact computation of the EXIT function for the ML decoding is difficult. However, using the area theorem [22, 23], we have:
where r _{ G } is the designed coding rate of the given ensemble of GLDPCStaircase codes. Moreover, since the (IT + RS) decoding is suboptimal with respect to the ML decoding, we have h ^{IT+RS}(ε)≥h ^{ML}(ε). Hence, if for some \(\bar {\epsilon }^{ML}\)
we necessarily have \(\bar {\epsilon }^{ML} \geq \epsilon ^{ML}\). This gives an upper bound on the ML threshold, which is easily computed using h ^{(IT+RS)}.
The ML EXIT curve of the GLDPCStaircase codes, h ^{ML}(ε), can be constructed in the following manner:

Step 1: Plot the (IT + RS) EXIT curve as parametrized in Eq. (21).

Step 2: Determine the \(\bar {\epsilon }^{ML}\) by integrate backwards from the right end of the curve where ε=1. The integration process stops at \(\bar {\varepsilon }^{ML}\) where it assures Eq. (25). This gives the upper bound \(\bar {\varepsilon }^{ML}\) of the GLDPCStaircase codes.

Step 3: The ML EXIT curve is now the curve which is zero at the left of the upper bound on the ML decoding threshold and equals to the (IT + RS) EXIT curve to the right of this decoding threshold (i.e., the (IT + RS) EXIT and the ML EXIT curves coincide above \(\bar {\varepsilon }^{ML}\)).
Remark 3.2.
This upper bound is conjectured to be tight because the GLDPCStaircase codes are based on LDPCStaircase codes, which are binary codes and defined by quasiregular graphs.
Example 3.3.
Consider the same code of Example 3.2.
Figure 7 shows the (IT + RS) EXIT curve (h ^{(IT+RS)}(ε)) and the integral bound on ε ^{ML} for GLDPCStaircase code with the same distributions of Fig. 6.
The (IT + RS) decoding threshold value is ε ^{(IT+RS)}=0.5376.
The ML decoding threshold upperbound is the unique point \(\bar {\varepsilon }^{ML} \in \left [\varepsilon ^{(\text {IT+RS})} \ 1\right ]\) such that the red area below the (IT + RS) EXIT curve, delimited by \(\varepsilon =\bar {\varepsilon }^{ML}\) at the left and by ε=1 at the right, is equal to the GLDPC code rate, r _{ G }=1/3. In this case, we obtain \(\bar {\varepsilon }^{ML} = 0.6664\).
Optimization of GLDPCStaircase codes
Description
GLDPCStaircase codes can be viewed as an extension of LDPCStaircase code (base code) into generalized LDPCStaircase code using RS codes. Moreover, GLDPCStaircase codes can be constructed using two structures which differ in the type of the generated LDPC repair symbols that are either RS repair symbols or not, as follows:

Scheme A has the property that on each generalized check node, the repair symbol generated by the LDPC code is also an RS repair symbol.

On the opposite, with scheme B the generated LDPC repair symbol, on each generalized check node, is an RS source symbol.
In addition, the configuration of GLDPCStaircase codes depends on the important internal parameters, namely

the extrarepair symbols distribution across the H _{ L } rows: regular distribution or irregular uniform distribution,

the N1 parameter of the base code: degree of source variable nodes in H _{ L },

the base code rate r _{ L }.
Therefore, in this section, we start by showing the impacts of the property that the generated LDPC repair symbols are at the same time RS repair symbols, on the decoding behavior (i.e., compare scheme A and scheme B). Then, the best configuration of these parameters for hybrid (IT/RS/ML) decoding^{3} will be discussed. To gauge the correction capabilities of decoding, we use the asymptotic analysis based on DE and EXIT techniques presented in Section 3, as well as the finite length analysis.
Experimental conditions
For the finite length analysis, we have developed a GLDPCStaircase codec based on RS codes under (IT + RS) and ML decoding methods, in C language, using the OpenFEC.org project (http://openfec.org). All experiments are carried out by considering a memoryless erasure channel along with a transmission scheme where all the source and repair symbols are sent in a fully random order.
This has the benefit to make the performance results independent of the loss model^{4} and the target channel loss rate is the only parameter that needs to be considered.
Different LDPCStaircase matrices are used (more precisely we change the PRNG seed used to create the matrix). Then, the results, averaged over the tests obtained by varying LDPCStaircase matrix, show the average behavior of GLDPCStaircase codes.
In the sequel, we evaluate the finite length performance based on the decoding overhead^{5}, the decoding inefficiency ratio^{6} and the failure decoding probability^{7}.
For the asymptotic analysis, we use commonly the following DD of LDPCStaircase codes as presented in Tables 1 and 2.
The calculus of these degree distributions is based on the parameter N1, \(d_{r_{H_{1}}}\), and the structure of LDPCStaircase codes.
For an irregular uniform distribution of extrarepair symbols, we use the notation \(f(\%)=[f_{0}\ f_{1}\ f_{2}\ \dots f_{e}]\) to define the fractions of generalized check nodes with e extrarepair symbols. For example, f(%)=[25 50 25] means that we have 25 % of generalized check nodes have 0 extrarepair symbols, 50 % of generalized check nodes have 1 extrarepair symbols, and 25 % of generalized check nodes have 2 extrarepair symbols.
Best coding scheme for GLDPCStaircase codes
Throughout this section, we investigate the impacts of the property given by scheme A on decoding performance in different configurations of GLDPCStaircase codes. For this reason, the study allows to determine the best for the hybrid (IT/RS/ML) decoding through a comparison between scheme A and scheme B.
Asymptotic results
Let us consider a base code with distribution defined in Table 1 for r _{ L }=0.8 and N1=5. We use the DE equations proposed in Section 3.2 to plot in Fig. 8 the evolution of the erasure probability transfer on the graph of GLDPCStaircase code with \(r_{G}=\frac {1}{2}\) and E=3 (regular distribution) for scheme A (P _{ ℓ+1,A }=f(P _{ ℓ,A })) and scheme B (P _{ ℓ+1,B }=f(P _{ ℓ,B })). These curves represent the value of the erasure probability on all the LDPC symbols during the propagation of the erasure probability between generalized check nodes and variable nodes of the GLDPCStaircase tanner graph where (ε) equals to 0.32.
This figure shows that the initial fraction of erasure messages emitted by the LDPC variable nodes is P _{ l } = 1 in schemes A and B. After an iteration (at the next output of the LDPC variable nodes) this fraction has evolved to P _{ l+1}=0.32 for the two schemes.
After second full iteration, i.e., at the output of the LDPC variable nodes, we see that an erasure fraction of scheme A is equal to P=0.2889 whereas it is equal to P=0.3117 for scheme B. This difference explains that the erasure probability in scheme A decreases more quickly than scheme B (i.e., the correction of the erasure in scheme A is better than scheme B). After that the process of the transfer continues in the same fashion for each subsequent iteration.
The figure also shows that the process of DE for scheme B is stuck at value >0 (P=0.3094) while for scheme A the process finishes with P=0. This means that under (IT + RS) decoding and at ε=0.32, the GLDPCStaircase codes converge (i.e., can recover all the erased LDPC symbols) only with scheme A. We continue the comparison between the two schemes in terms of decoding threshold using the EXIT analysis presented in Section 3.3. This analysis allows us to compute the (IT + RS) decoding threshold (ε ^{(IT+RS)}) and the upper bound on the ML decoding threshold (\(\bar {\varepsilon }^{\text {\scriptsize ML}}\)). We note that DE also allows to determine the decoding threshold, but it requires several calculations.
Table 3 provides the comparison in terms of ε ^{(IT+RS)} and \(\bar {\varepsilon }^{\text {\scriptsize ML}}\) between scheme A and scheme B (with regular distribution and \(r_{L}=\frac {2}{3}\)) for two global code rates (\(\frac {1}{2}\) and \(\frac {2}{5}\)) and different values of N1. This table reveals that for different values of N1, scheme A outperforms scheme B under (IT + RS) decoding. Therefore, the property that the generated LDPC repair symbols are RS repair symbols helps to get closer to channel capacity limit. Whereas under ML decoding, below of N1=5, scheme B is preferable and beyond this value, this property has no great significant impact. This is explained as follows. In practice, the efficiency of the ML decoder over BEC is related to the densification of its linear system. Therefore, low value of N1 implies a sparse binary linear system of LDPCStaircase codes which causes degradation on the ML decoding results [24]. Whereas, as mentioned in Section 2.5.2, the linear system of GLDPCStaircase codes is composed of a binary subsystem (composed from LDPCStaircase equations) and a non binary subsystem (composed from extrarepair equations) which is somewhat more dense with scheme B than scheme A. Therefore, this difference has an impact on performance of global system when the binary subsystem is sparse; otherwise, it is vanished. We will see next, that N1=5 is the best value for the hybrid decoding type, therefore we prefer scheme A in this case.
In the previous analysis, we fixed the base code rate and the distribution type of extrarepair symbols to study only the impact of the property of scheme A when varying N1. Let us now see the impact of this property when we vary r _{ L } (i.e., vary E) and the distribution of extrarepair symbols with N1 fixed to 5.
Table 4 provides the comparison in terms of ε ^{(IT+RS)} and \(\bar {\varepsilon }^{\text {ML}}\) between scheme A and scheme B (with \(r_{G}=\frac {1}{2}\)) for different values of r _{ L } (i.e., vary E) using a regular distribution of extrarepair symbols. This table proves that, for different values of E > 0, the (IT + RS) decoding threshold of scheme A is higher than that of scheme B. On the opposite, the ML decoding thresholds of the two schemes, for different values of E, are almost equivalent.
Additionally, for an irregular uniform distribution of extrarepair symbols, Table 5 also shows that, for different values of f (distribution of extrarepair repair symbols), scheme A is better than scheme B for (IT + RS) decoding and both achieve the same ML decoding thresholds.
Let us move to see the results when varying the rate of GLDPCStaircase code. Table 6 provides the comparison in terms of ε ^{(IT+RS)} and \(\bar {\varepsilon }^{\text {\scriptsize ML}}\) between scheme A and scheme B for different values of r _{ G } with \(r_{L}=\frac {2}{3}\), N1=5 and regular distribution. This table reveals that for different rates of GLDPCStaircase code, scheme A outperforms scheme B under (IT + RS) decoding and both have the same behavior under ML decoding. For an irregular uniform distribution, in Table 7, we provide a comparison between decoding thresholds of the two schemes with \(r_{L}=\frac {2}{3}\) for different values of f (distribution of extrarepair symbols). This table also shows the same results for regular distribution.
Therefore, for all configurations of GLDPCStaircase codes, the structure of scheme A resists to the channel loss more than scheme B under (IT + RS) and both have the same behavior under ML decoding with dense system.
Finite length results
This section aims to give additional claims on the impact of the property of scheme A in terms of decoding inefficiency ratio, decoding overhead, decoding failure probability, and error floor. All results are determined using N1=5 and a regular distribution of extrarepair symbols.
Figures 9 b and 10 b provide the average (over 1000 different codes) decoding inefficiency ratio of both schemes under ML decoding for two different code rates (\(\frac {1}{2}\) and \(\frac {1}{3}\)). They show that no matter the dimension, K, both schemes perform the same, with results quite close to that of MDS codes (characterized by an decoding inefficiency ratio always equals to 1). This means that for small and large object size, the property of scheme A has no impact on the ML decoding inefficiency ratio. These results hold for the two considered code rates.
Figures 9 a and 10 a do the same in case of (IT + RS) decoding only. They show that scheme A exhibits the lowest average decoding inefficiency ratio in all cases. This is made possible by a higher number of RS repair symbols (i.e., increase of the minimum distance) for scheme A, which mechanically increases the success probability of decoding an erased symbol on each generalized check nodes. The increase of the RS repair symbols also avoids stopping sets associated to short cycles that stuck (IT + RS) decoding. This means that scheme A is more efficient on (IT + RS) decoding than scheme B.
In order to go further to see the error floor and overhead achieved by each scheme under ML decoding, we analyze the ML decoding failure probability. In Fig. 11, we plot the ML decoding failure probability versus channel loss percentage (in Fig. 11 a) and versus number of received symbols (in Fig. 11 b). To that purpose, we choose \(r_{G}=\frac {1}{2}\) (E=1), K=1000, and 10^{6} tested codes.
In Fig. 11 a, the black vertical line corresponds to ideal, MDS code, for which the decoding failure is equal to 0 as long as the experienced loss rate is strictly inferior to 50 % for \(r_{G}=\frac {1}{2}\). This figure confirms that for two schemes, the GLDPCStaircase codes have a very small decoding failure probability, with no visible error floor above 10^{−5}. The little difference between the two curves is readable at the foot where we test several codes (i.e., at 49.45 % scheme A has 4.16.10^{−6} as decoding failure probability whereas scheme B has 5.45.10^{−6}). Figure 11 b gives additional details of the behavior of the two schemes using ML decoding. This figure confirms that scheme B has almost same decoding overhead as scheme A (i.e., with 6 symbols added to K, scheme A has 6.93.10^{−6} decoding failure probability while 7.27.10^{−6} with scheme B for channel erasure probability equals to 49.6 %). Also, the two schemes achieve ≃5.10^{−2} decoding failure probability with overhead equals to 2. Therefore, both schemes have a very small decoding overhead, close to that of MDS codes.
Conclusion of the analysis
The asymptotic analysis and finite length analysis confirm that all results prove that scheme A is globally the best solution: it significantly performs better than scheme B with an (IT + RS) decoding and leads similar performance to scheme B with an ML decoding with dense system. Thus, to design GLDPCStaircase codes, with hybrid (IT/RS/ML) decoding, we must choose scheme A. Therefore, the rest of this document will only consider scheme A.
Tuning internal parameters of GLDPCStaircase codes
In this section, we analyze the impact of three configuration parameters of GLDPCStaircase codes on the erasure recovery performance in order to obtain the best configuration over hybrid (IT/RS/ML) decoding.
The extrarepair symbol distribution
As shown in Section 2.1, we can distribute the extrarepair symbols on the generalized check nodes in two ways: regular, or irregular uniform distribution. In [13], based on asymptotic results, it is shown that these codes with (IT + RS) decoding perform the best under an irregular uniform distribution rule. However, in our work, we consider also the ML decoding scheme and the situation is completely different. Therefore, we test these two distributions to determine the best on each decoding type.
Figure 12 provides the average decoding inefficiency ratio (i.e., average of 1000 GLDPC codes with \(r_{G}=\frac {1}{2}\)) of GLDPCStaircase codes, for different object sizes. It shows that the regular distribution performs significantly better under ML decoding, both with small and large objects.
Based on asymptotic results, we give the gaps to capacity of GLDPCStaircase codes with irregular uniform distribution and regular distribution of extrarepair symbols for different code rates r _{ G } with N1=5 and \(r_{L}=\frac {2}{3}\) in Table 8. In addition, we provide in Table 9 the gaps to capacity of the two distributions for different values of r _{ L } with fixed global code rate \(r_{G}=\frac {1}{2}\) and N1=5.
The gap to capacity (Δ) is computed using the following equation:
(with ε _{ th } is the decoding threshold).
These tables show that, for different values of global code rate and base code rate, under (IT + RS) decoding, the GLDPCStaircase codes produce higher gap to capacity with a regular distribution rather than with an irregular uniform distribution. While, under ML decoding, the regular distribution allows to have GLDPCStaircase codes very close to the channel capacity more than the irregular uniform distribution. This confirms the finite length analysis.
Let us see the case where N1 varies. Table 10 provides the decoding thresholds of the two decoding types for \(r_{L}=\frac {2}{3}\) for the two distributions into different values of global code rates. This table also shows that ML decoding favors the regular distribution for different values of N1 (more advantage with low value of N1). Therefore, for different values of N1, r _{ L }, and r _{ G }, the regular distribution is accorded to the ML decoding whereas irregular uniform distribution is suitable for (IT + RS) decoding.
As our objective is to focus on the hybrid decoding and ML performance, in the remaining of this work we only focus on the regular distribution where there are exactly e(c)=E extrarepair symbols per generalized check node c.
N1 parameter
Let us now adjust the second internal parameter of the GLDPCStaircase codes, N1, which represents the degree of the source variable nodes of the base code matrix H _{ L }.
The increase of N1 parameter causes the “densification” of H _{ L } and maybe the decrease of the smallest stopping set size. It is well known that the effectiveness of IT decoding over erasure channel is related to the sparseness of the LDPC graph. In addition, the correction capabilities of LDPC codes are limited by the size of smallest stopping sets.
Since, in our case we have IT and RS decoding working together, let us see if the RS decoding helps IT decoding to prevent the negative impact of the densification of the graph on the decoding (i.e., to see if the densification also causes the degradation of (IT + RS) decoding performance). Therefore, in Table 11, we provide the average decoding inefficiency ratio (i.e., average of 1000 GLDPCStaircase codes for each r _{ G }) for different r _{ G } versus N1 under (IT + RS) decoding with K=1000 and \(r_{L}=\frac {2}{3}\). This table shows that, for different r _{ G } and under (IT + RS) decoding, increasing N1 induces an increase in the average decoding inefficiency ratio. This means that the extrarepair symbols which are used to cope with the problem of small stopping sets in the base code graph do not succeed. Moreover, increasing E (i.e., reducing the GLDPC code rate) does not solve the problem. Therefore, the increase of N1 leads to the deterioration of the ability to correct with (IT + RS) decoding. This table also shows that, for different GLDPC code rates, the behavior of ML decoding is totally different than the one observed for (IT + RS) decoding.
We give the same remarks using Table 12 where we compute the threshold of (IT + RS) decoding and ML decoding for a different value of N1.
Additionally, the decoding complexity depends on the number of XOR operations on the graph of IT decoding, whereas it depends on the size and the density of the linear system to be solved of ML decoding [24]. Then, the increase of N1 has a negative impact on the IT and ML decoding complexity.
Therefore, with ML decoding, with respect to the low decoding complexity, the most significant performance gains are obtained by switching from N1=3 to 5. Above this value, the performance only improves slightly. This value N1=5 also limits the performance degradation of (IT+RS) decoding compared to values N1>5. N1 = 5 is the best value that can be used by the hybrid (IT/RS/ML) decoding.
The base code rate r _{ L }
Let us consider a GLDPCStaircase code rate r _{ G }. Several values of the base code rate r _{ L }, or equivalently of E, enable to achieve the global code rate r _{ G } (see Eq. (8)). However, choosing a value impacts the achieved performance.
In Fig. 13, we plot the average ML decoding inefficiency ratio (i.e., average of 1000 GLDPC codes with \(r_{G}=\frac {1}{3}\)) for a different object size. This figure shows that increasing r _{ L } rate (i.e., increasing the number E), the average decoding inefficiency ratio quickly approaches 1 (i.e., ideal code) as E=3 (i.e., \(r_{L}=\frac {2}{3}\)), even for very small code dimensions. We also apply the techniques developed in Section 3 to adjust E, by computing the upper bound on the ML decoding threshold for several values of E. These results are summarized in Table 13 and compared to the Shannon capacity limit (δ _{ sh }). We notice that increasing E (or equivalently increasing the LDPC code rate) quickly increases the upper bound on the ML decoding threshold, until it reaches a stable value very close to the Shannon limit δ _{ sh }. Depending on r _{ G }, this stable value is obtained with E=1, 2, or 3. Therefore, a small number of extrarepair symbols per generalized check node is sufficient to get extremely close to the channel capacity.
These results are identical to the finite length performance results.
Since r _{ G }= {\(\frac {1}{2},\frac {1}{3}\)} are commonly in our usecases, therefore we choose to set the base code rate to r _{ L }=2/3.
Performance evaluation
In Section 4, we concluded that scheme A, N1=5, and small number of extrarepair symbols distributed regularly on generalized check nodes are the most appropriate values for hybrid (IT/RS/ML) decoding. Based on this optimal configuration, we now investigate more in details the performance achieved in various situations, for different performance metrics. Then, we compare with the performance achieved with other ALFEC codes. Finally, we discuss the decoding complexity of GLDPCStaircase codes and give preliminary decoding throughput results.
Achieved performance
(IT + RS) versus hybrid (IT/RS/ML) decoding
Let us first quantify the gains made possible by the use of ML decoding. Figure 14 shows the average (over 1000 different codes) decoding inefficiency ratio for various object sizes or equivalently code dimensions K (both are equal here as the object is encoded in a single pass), when \(r_{G} =\frac {1}{2}\). It confirms the major performance gains for all object sizes (e.g., equal to 22 % for K=1000). More remarkable, the performance remains excellent for very small values of K.
Detailed hybrid (IT/RS/ML) decoding inefficiency ratio results
In Fig. 15 a, we plot the average (over 1000 different codes) hybrid (IT/RS/ML) decoding inefficiency ratio as a function of the object size for various code rates: \(r_{G}=\frac {1}{3}\) (E=3), \(r_{G}=\frac {1}{2}\) (E=1), and \(r_{G}=\frac {2}{3}\) (E=0). In Fig. 15 b, we do the opposite, as a function of the code rate (equivalent E value) for various object sizes (from K=100up to K=1000).
We see in both figures that the GLDPCStaircase codes with E=1 or E=3 exhibit exceptional erasure recovery capabilities, even for tiny objects. On the opposite, codes with E=0 (i.e., LDPCStaircase as there is no extrarepair symbol) exhibit poor performance. Therefore, the addition of extrarepair symbols, even in small number, makes the correction capabilities of GLDPCStaircase codes under hybrid decoding close to that of ideal MDS codes, both for tiny and large objects. These tests also show that GLDPCStaircase codes perform extremely well even for very small code rates.
Hybrid (IT/RS/ML) decoding failure probability results
Let us now focus on the decoding failure probability as a function of the number of received symbols or, equivalently, channel loss percentage. Figure 16 shows the average results over 10^{7} GLDPCStaircase codes with \(r_{G}=\frac {1}{2}\) when K=32, K=256, and K=1000. The black vertical line corresponds to ideal MDS code for which the decoding failure is equal to 0 as long as the experienced loss rate is strictly inferior to 50 %. This figure confirms that GLDPCStaircase codes are close to ideal MDS codes with no visible error floor above 10^{−5}. This is obvious with objects of size K=1000 and K=256 and it remains almost true with K=32 (i.e., error floor start at 8×10^{−6} with 42 % of loss for K=32, below 5.33×10^{−6} with 49.45 % of loss for K=1000).
Table 14 shows the average decoding failure probability as a function of the overhead (i.e., the number of received symbols above K), under the same conditions. We see that, for large or small object sizes, a few symbols in addition to K are sufficient for decoding to succeed with a high probability. With K=32, two symbols are sufficient to reach a decoding failure below 10^{−5}, and with K=1000, six symbols are sufficient to be below 10^{−5}. This confirms that GLDPCStaircase codes have correction capabilities close to that of MDS codes.
Comparison with other erasure correcting codes
Let us now compare with other ALFEC codes, such as LDPCStaircase codes (RFC 5170 [12]), Raptor codes (RFC 5053 [25]), and another construction of GLDPC codes [26].
Comparison with LDPCStaircase codes
Let us start by comparing the correction capabilities with those of LDPCStaircase codes, using the decoding failure probability metric. We plot ML decoding failure probability versus loss channel percentage in Fig. 17 b and versus the number of received symbols in Fig. 17 a, when the code rate is \(\frac {1}{2}\). Figure 17 b shows that the GLDPCStaircase codes are close to ideal with a very steep slope in the “waterfall” area. In addition, no error floor appears above 10^{−6} decoding failure probability, which is a very good performance, whereas LDPCStaircase codes exhibit an error floor at 2.10^{−5} decoding failure probability. Figure 17 a shows that with GLDPCStaircase codes, the reception of a few symbols in addition to K allows to quickly reach a decoding failure probability below 10^{−6}. Besides, in order to obtain ML decoding failure probability equals to 10^{−4}, 28 symbols in addition to K=1024 are needed with LDPCStaircase codes, against 4 symbols with GLDPCStaircase codes. Therefore, GLDPCStaircase codes provide major gains with low error floor and a very steep slope compared to LDPCStaircase codes.
Comparison with another GLDPC code [26]
Let us now compare the correction capabilities with the GLDPC code construction defined by Tanner [3]. This GLDPC code is characterized by an optimal distribution (capacityapproaching) based on hybrid check node structure, which is composed of SPC and (31,21) linear block codes (BCH codes with d _{min}=5) [26]. For our codes, we use a regular distribution of extrarepair symbols and a base code with N1=5, \(r_{L}=\frac {2}{3}\) and DD as shown in Table 1).
Table 15 provides a comparison in terms of decoding threshold for rate \(\frac {1}{2}\). It shows that our construction method performs the best.
Comparison with Raptor and RaptorQ codes
Finally, we compare with Raptor codes [25] when

Case 1: K=32, N=128;

Case 2: K=256, N=1024;

Case 3: K=1024, N=3072.
In Fig. 18, we plot the ML decoding failure probability versus decoding overhead for those three cases. For Raptor codes, we used the results provided by Qualcomm for 3GPP in [27]. This figure shows that GLDPCStaircase codes outperform Raptor codes, no matter the object size. In fact, in case 3, with two symbols in addition to K GLDPCStaircase achieves a decoding failure probability equal to 1.2×10^{−4} compared to 0.41562 for Raptor codes.
Finally, using the results given in [27], the correction capabilities of our codes are close to those of RaptorQ codes. For instance, in case 3, the 10^{−7} decoding failure probability is achieved with two additional symbols for RaptorQ codes and four symbols in our case.
Hybrid (IT/RS/ML) decoding complexity
Experimental conditions
In order to evaluate the complexity of GLDPCStaircase codes, we implemented a functional C language codec integrated in the http://openfec.org environment, reusing its binary LDPCStaircase and HankelRS over G F(2^{8}) software codecs. Then, we conducted throughput tests on a Linux desktop, using kernel 2.6.27.41/64 bits, and an Intel Xeon CPU E5410@2.33GHz processor (a single CPU core was used during experiments). Here, we also use N1=5, r _{ L }=2/3, and a regular distribution of extrarepair symbols.
Results
Hybrid decoding always starts with the (IT + RS) decoder and triggers the ML (binary and/or nonbinary) decoder if needed. This typically happens when the channel loss rate is too high for the (IT + RS) decoder to recover all the erased symbols. During ML decoding, recovering source and repair LDPC symbols using binary ML decoding requires only simple XOR operations. However, extrarepair symbols add finite field operations: multiplying symbols with associated coefficients over G F(2^{8}) and adding symbols. If finite field addition consists in XORing the two values, finite field multiplications are more complex, requiring in general a log table lookup, an addition operation, and an exponentiation table lookup to determine the result. With G F(2^{8}), a common optimization with software codecs consists in precalculating multiplications and storing the result in a 255×255 table. With this optimization, multiplying two elements of G F(2^{8}) consists in accessing the right element of this precalculated table, and multiplying a symbol by a coefficient over G F(2^{8}) consists in doing this for all the bytes of the symbol.
In Fig. 19, we plot the decoding throughput in megabyte per second as a function of the channel loss percentage. We set \(r_{G}=\frac {1}{2}\), E=1, and consider an object of size K=1000 symbols, each of them of size 1024 bytes.
This figure illustrates what we said above: when the channel loss percentage is low (until 35 %), the (IT + RS) decoding is usually sufficient to recover the erased source symbols with speeds around 700 Mb/s. Then, as the channel loss percentage approaches the theoretical limit (i.e., 50 %), the throughput decreases until it stabilizes around 50 Mb/s. This is due to the frequent use of ML decoding. If (IT + RS) decoding is fast, ML decoding remains costly and needs further optimizations. In [28], the structured Gaussian elimination (SGE) method has been successfuly applied to LDPCStaircase codes. An extension of this approach to GLDPCStaircase codes should reduce the hybrid decoding complexity.
Conclusions
This paper provides the fundamentals for the design and analysis of GLDPCStaircase ALFEC codes, a class of codes well suited to reliable transmissions and largescale content distribution, in particular when retransmissions are not possible. They can be viewed as an intelligent way of coupling two complementary codes: on the one hand, the structured binary LDPCStaircase codes, characterized by low encoding/decoding complexities yet good performance for medium to large objects (where RS codes behave poorly); on the other hand, the nonbinary RS codes that are ideal codes for small objects (where LDPC codes behave poorly). The coupling is as follows: each SPC check node of LDPCStaircase (base code) is replaced by an RS code (component code), nodes that are now called “generalized check nodes.” We also define and analyze two variants, schemes A and B, that differ by the nature of the first repair symbol of each generalized check node. Thanks to the generalized check nodes, a large number of RS repair symbols (called extrarepair symbols) can be produced on demand, a nice feature for situations where the channel conditions can be worse than expected or to fountainlike content distribution applications. Very small rates are therefore easily achievable.
First of all, we introduce the use of systematic “quasi” HankelRS codes, a forgotten type of RS codes, as a practical way to design GLDPCStaircase codes (both variants). We show that this class of RS codes features very low construction times, which means that GLDPCStaircase codes can be generated on the fly, with the exact code dimension and length values. In addition to the basic (IT + RS) decoder of GLDPCStaircase codes, we introduce a new hybrid (IT/RS/ML) decoder, and thanks to a joint use of IT, RS, and binary and nonbinary ML decoding, it achieves ML decoding performance at a lower complexity. This is confirmed by preliminary decoding throughput tests, even if further optimizations are needed for the ML decoder.
Then, we detail the asymptotic analysis method for GLDPCStaircase codes under both (IT + RS) and ML decoding, using the EXIT and DE tools. It allows us to investigate their decoding convergence and gap to the theoretical limit. First, we derive DE equations under (IT + RS) decoding for the two variants, schemes A and B. This technique is then combined with EXIT functions by generalizing the area theorem (initially proposed for LDPC codes) to our codes, and we determine the upper bound on the ML decoding threshold. This analysis shows that GLDPCStaircase codes under ML decoding are quite close to the theoretical limit. Moreover, using this method along with a finite length analysis, we discuss the impacts of the code structure. We show that the “dual identity” repair symbols of scheme A improve the decoding correction power of each generalized check node (the impact of stopping sets to (IT + RS) decoding vanishes) which accelerates the (IT + RS) decoding convergence. Since this is done without negatively impacting ML decoding performance, we conclude that scheme A is the most appropriate code construction approach. Our analyses also lead us to conclude that N1=5 and a small number of extrarepair symbols distributed regularly over the generalized check nodes represent the best configuration for hybrid (IT/RS/ML) decoding.
Finally, using finite length analyses and the above optimal configuration, we show that these codes exhibit exceptional erasure recovery capabilities with a memoryless channel. More precisely, they show very small decoding overheads, close to that of ideal codes, low decoding failure probabilities, low error floors, and steep waterfall regions. These results are achieved no matter the object size, which is the main problem of most ALFEC codes (e.g., LDPCStaircase, RS, and Raptor codes). From this point of view, GLDPCStaircase codes outperform the LDPCStaircase, Raptor, and another construction of GLDPC codes [8, 26]. Their correction capabilities are close to that of RaptorQ codes.
All these results make GLDPCStaircase codes a ubiquitous class of ALFEC codes for the erasure channel. They are very well suited to streaming applications where encoding is performed on small amounts of data in order to satisfy realtime constraints. But they are also appropriate for bulk data transfer applications where the encoding is performed on large amounts of data (ideally a single block encompassing the whole file) where it is only limited by the practical aspects (available memory and CPU during decoding).
Endnotes
^{1} This matrix is divided into two parts and has the form \(\left (H_{1}H_{2}\right)\). The M _{ L }×K lefthand side part, H _{1}, defines the emplacements of source symbols in equations (rows). It is created in a regular way in order to have constant column and row degrees. More precisely, each column of H _{1} is of degree N1, which is an input parameter during the LDPCStaircase code creation [12]. The M _{ L }×M _{ L } righthand side part, H _{2}, defines in which equations the repair symbols are involved and features a staircase (i.e. double diagonal) structure.
^{2} As explained previously, with scheme A, the k _{ m } symbols consist of x plus p _{ m−1} (if m>1). With scheme B, they consist of x plus p _{ m−1} (if m>1) and p _{ m }.
^{3} We note that hybrid (IT/RS/ML) decoding and ML decoding have the same correction capabilities but they are different at decoding complexity level. Thus, we mention “ML decoding” to refer the correction capabilities obtained by hybrid decoding.
^{4} It is equivalent to the order of packet loss.
^{5} It is the number of required symbols over K to succeed the decoding
^{6} It is the ratio between the number of symbols needed for decoding to succeed over the number of source symbols.
^{7} It is the probability that at least one erased source symbol is not recovered
References
 1
R Gallager, Low Density Parity Check codes. IRE Trans. Inform. Theory. 8:, 21–28 (1962).
 2
D MacKay, R Neal, Near Shannon limit performance of low density parity check codes. IET Electron. Lett.33(6), 457–458 (1997).
 3
R Tanner, A recursive approach to low complexity codes. IEEE Trans. Inform. Theory. 27(5), 533–547 (1981).
 4
J Boutros, O Pothier, G Zéor, Generalized Low Density (Tanner) Codes. IEEE Int. Conf. Commun. (ICC), 441–445 (1999).
 5
M Lentmaier, K Zigangirov, On Generalized LowDensity ParityCheck codes based on Hamming component codes. IEEE Trans. Commun.3(8), 248–250 (1999).
 6
G Yue, L Ping, X Wang, Generalized lowdensity paritycheck codes based on Hadamard constraints. IEEE Trans. Inform. Theory. 53(3), 1058–1079 (2007).
 7
J Chen, R Tanner, A hybrid coding scheme for the GilbertElliott channel. IEEE Trans. Commun.54(10), 1787–1796 (2006).
 8
N Miladinovic, M Fossorier, Generalized LDPC codes with ReedSolomon and BCH codes as component codes for binary channels. IEEE Global Telecommun. Conf. (GLOBECOM), 1239–1244 (2005).
 9
I Djordjevic, O Milenkovic, B Vasic, Generalized LowDensity ParityCheck codes for optical communication systems. Lightwave Technol.23(5), 1939–1946 (2005).
 10
Y Wang, M Fossorier, Doubly Generalized LDPC codes. IEEE Int. Symp. Inform. Theory, 669–673 (2006).
 11
E Paolini, D Wilab, M Fossorier, M Chiani, in Proceedings of Allerton Conference on Communications, Control and Computing. Analysis of doublygeneralized ldpc codes with random component codes for the binary erasure channel, (2006).
 12
V Roca, C Neumann, D Furodet, Low Density Parity Check (LDPC) staircase and triangle forward error correction (FEC) schemes (2008). IETF Request for Comments, RFC 5170.
 13
M Cunche, V Savin, V Roca, G Kraidy, A Soro, J Lacan, Lowrate coding using incremental redundancy for GLDPC codes. In: IEEE Int. Workshop on Satellite and Space Communications (2008).
 14
F Mattoussi, V Roca, B Sayadi, Design of small rate, close to ideal, GLDPCStaircase ALFEC codes for the erasure channel. IEEE Global Commun. Conf. (GLOBECOM), 2143–2149 (2012).
 15
F Mattoussi, V Roca, B Sayadi, Good coupling between LDPCstaircase and ReedSolomon for the design of GLDPC codes for the erasure channel. IEEE Wireless Commun. Netw. Conf. (WCNC), 1528–1533 (2013).
 16
F Mattoussi, V Roca, B Sayadi, Complexity comparison of the use of Vandermonde versus Hankel matrices to build systematic MDS Reed Solomon codes. IEEE Int. Workshop Signal Process. Adv. Wireless Commun. (SPAWC), 344–348 (2012).
 17
E Paolini, G Liva, B Matuz, M Chiani, Generalized IRA erasure correcting codes for hybrid iterative/maximum likelihood decoding. IEEE Commun. Lett.12(6), 450–452 (2008).
 18
M Cunche, V Roca, Optimizing the error recovery capabilities of LDPCStaircase codes featuring a Gaussian elimination decoding scheme. In 10th IEEE International Workshop on Signal Processing for Space Communications (SPSC 2008) (2008).
 19
TJ Richardson, RL Urbanke, The capacity of LowDensity ParityCheck codes under messagepassing decoding. IEEE Trans. Inform. Theory. 47(2), 599–618 (2001).
 20
M Luby, M Mitzenmacher, M Shokrollahi, D Spielman, V Stemann, Practical lossresilient codes. 29th Annual ACM Symposium on the Theory of Computing (1997).
 21
S ten Brink, Convergence of iterative decoding. IEEE Electron. Lett.35(10), 806–808 (1999).
 22
C Mésson, A Montanari, R Urbanke, in IEEE Int. Symposium on Information Theory (ISIT). Maxwell’s construction: The hidden bridge between maximumlikelihood and iterative decoding, (2004).
 23
C Messon, Conservation laws for coding. PhD thesis, Ecole Polytechnique Federale de Lausanne (EPFL) (2006).
 24
M Cunche, Codes alfec hautes performances pour les canaux défacements : variations autour des codes ldpc (2010). PhD thesis, Université Joseph Fourrier, Grenoble.
 25
M Luby, A Shokrollahi, M Watson, T Stockhammer, Raptor forward error correction scheme for object delivery. IETF Request for Comments, RFC 5053 (2007).
 26
E Paolini, Iterative decoding methods based on lowdensity graphs. PhD thesis, Universitádegli Studi di Bologna (2007).
 27
EMMEFEC, Selection of the FEC. Document S4121367, 3GPP TSGSA4 meeting 71, Bratislava, Slovakia (2012). http://www.3gpp.org/ftp/tsg_sa/WG4_CODEC/TSGS4_71/Docs/S4121367.zip.
 28
V Roca, M Cunche, C Thienot, J Detchart, J Lacan, in 9th IEEE International Conference on Wireless and Mobile Computing, Networking and Communications (WiMob). Rs + ldpcstaircase codes for the erasure channel: Standards, usage and performance, (2013).
Acknowledgements
This work was supported by the ANR09VERS01902 grant (ARSSO project) and by the INRIA—Alcatel Lucent Bell Labs joint laboratory.
Competing interests
The authors declare that they have no competing interests.
Author information
Rights and permissions
Open Access This article is distributed under the terms of the Creative Commons Attribution 4.0 International License (http://creativecommons.org/licenses/by/4.0/), which permits unrestricted use, distribution, and reproduction in any medium, provided you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons license, and indicate if changes were made.
About this article
Cite this article
Mattoussi, F., Roca, V. & Sayadi, B. GLDPCStaircase ALFEC codes: a fundamental study and new results. J Wireless Com Network 2016, 206 (2016). https://doi.org/10.1186/s136380160660y
Received:
Accepted:
Published:
Keywords
 ALFEC codes
 GLDPC codes
 LDPCStaircase codes
 ML decoding
 DE and EXIT tools
 Erasure channels