Abstract-We propose two variants of staircase codes that resolve the issue of parity-propagation in their encoding process. The proposed codes provide a systematic way of terminating a staircase code after an arbitrary number of blocks. The class of feed-forward staircase codes are introduced, which uses a self-protection technique to avoid parity-propagation. We also introduce the class of partial feed-forward staircase codes, which allows parity-propagation to occur over a given number of blocks. By amortizing the complexity of self-protection over several standard staircase blocks, the encoding complexity of these codes is made comparable to staircase codes. Partial feedforward staircase codes have the same error-floor as staircase codes. Simulations confirm that the performance of the proposed codes in both the waterfall and error-floor regions is similar to the original staircase codes. The proposed codes help extend the domain of application of staircase codes to systems in which parity-propagation is undesirable or termination is necessary.
I. INTRODUCTION
H IGH-SPEED fiber optical communication system are a challenging environment for forward error correction (FEC) schemes. Modern high-speed optical communication systems require high-performing FEC engines that support throughputs of 100 Gbit/s and multiples thereof, that have low power consumption, that realize net coding gains (NCGs) close to the theoretical capacity limits at a target BER of 10 −15 , and that are preferably adapted to the peculiarities of the optical channel [1] .
Although coding schemes that allow for soft-decision decoding are now well established in optical communications [1] , especially in long-haul and submarine transmission systems which need to operate at the lowest possible signal-to-noise ratio (SNR), hard-decision decoding is still predominant in the widely deployed metro networks, due to its low complexity leading to power-friendly receiver implementations [2] . Such low-complexity receivers are also attractive for data center interconnect applications.
In the recent years, several new capacity-approaching coding schemes suitable for high-speed optical communications have been presented. Staircase codes [3] , [4] , are hard-decision decoded, spatially-coupled codes with practical application in forward error-correction for long-haul optical-fiber transmission systems. An ITU-T G.709-compatible staircase code with rate R = 239/255 was shown to operate within 0.56 dB of the The associate editor coordinating the review of this letter and approving it for publication was Dr. xxx. Manuscript received XXX. yy, 2016.
L. M. Zhang is with the University of Toronto, ECE department. His work has been carried out while he was visiting Nokia Bell Labs funded by a scholarship from the German DAAD-RisePro program.
L. Schmalen is with Nokia Bell Labs, Stuttgart, Germany (e-mail: first.last@nokia.com).
L. Schmalen was supported by the German BMBF in the scope of the CELTIC+ project SENDATE-TANDEM.
Digital Object Identifier xx.xxxx/xxx.2016.xxxxxx capacity of the binary-input AWGN channel with hard decision at the output (which is equivalent to a binary symmetric channel (BSC)) at a bit-error rate (BER) of 10 −15 [3] . Its gap to capacity is smaller than all of the enhanced coding schemes proposed in ITU-T recommendation G.975.1 [5] . In [4] , staircase codes with rates R ≥ 6/7 were shown to be within 0.80 dB of capacity in terms of NCG at a BER of 10 −15 . Such coding gains are obtained by using an iterative, hard-decision decoding algorithm with decoder data-flow orders of magnitude lower than that of messagepassing decoders for sparse-graph codes such as Turbo or Low-Density Parity-Check (LDPC) codes [3] . For long-haul optical-fiber transmissions systems where bit-rates exceed 100 Gb/s, staircase codes are often the best practical solution.
Besides staircase code and variants thereof [6] , several other code constructions based on spatial coupling of algebraic component codes have been proposed, e.g., braided BCH codes [7] . Recently, multiple works show that these codes can approach capacity of the BSC under simple iterative decoding when the rate is large enough [8] - [11] . However, all the proposed structures of spatially coupled algebraic product codes are recursive codes which lead to several practical drawbacks in their implementation: First, a recursive structure requires extra circuitry [12] for terminating the code, which may be undesired in some applications where a low-complexity decoder implementation is crucial. Previous publications have not explicitly dealt with code termination but have only considered free-running, non-terminated codes. Terminating a feed-forward code on the other hand is straightforward.
A second drawback of recursive codes is the effect of parity-propagation; a single non-zero information bit leads to an infinitely extending parity sequence. This effect may be undesired in some optical transmission applications, where the transceivers are usually free-running due to the setup times of links [13] and only some of the transmitted bits carry useful information. Parity propagation limits in this case the possibility of switching off the forward error correction circuitry during times when no useful data is transmitted, nonnegligibly increasing the transceiver power consumption [2] .
In this paper, we discuss several options for constructing feed-forward staircase codes. It becomes quickly obvious that a straightforward modification of the staircase encoding structure to avoid parity propagation will lead to unacceptably high error floors for most applications. In order to mitigate the error floor, we use the technique of self-protecting paritybits [5, App. I.9] together with a clever interleaving to construct a class of feed-forward staircase codes. We also give an approximation of the expected error floor based on the minimum size stall pattern. In some applications with very stringent requirements, the error floor may still be too large. For this reason, in the second part of the paper, we slightly arXiv:1604.06574v2 [cs.IT] 11 Aug 2016 relax the parity-propagation constraint and present partial feed-forward staircase codes, which have the same error floor as the original staircase codes but completely avoid paritypropagation and allow for easy termination. This paper is structured as follows: In Sec. II, we introduce the basic notation and recapitulate the structure and main properties of staircase codes. In Sec. III, we introduce a first construction of feed-forward staircase codes based on self-protected parity-bits. In Sec. IV, we slightly generalize this construction and introduce partial feed-forward staircase codes, which have a slightly lower rate but improved error floor properties. Error floor approximations based on minimal stall patterns are derived in Sec. V. Finally, we compare in Sec. VI the performance of both schemes using a coding setup typically used in optical communications.
II. BACKGROUND: STAIRCASE CODES
In this section, we briefly overview the encoding and decoding of staircase codes since the proposed codes share many common features with the original staircase code. We also motivate our work by examining the parity-propagation property of staircase codes. A block diagonal matrix consisting of m copies of a matrix Q along its diagonal is given by I m ⊗ Q. We denote a block diagonal matrix consisting of m arbitrary matrices {Q 1 , Q 2 , . . . , Q m } of the same size along its diagonal by
A. Notation
. . . 
B. Encoding of staircase codes
An illustration of a staircase code is shown in Fig. 1 . The fundamental building block is a binary, linear, systematic block code C(n, k), referred to as a component code, with blocklength n (required to be even) and number of information bits k. Let R c k/n be the component code rate. For M n/2, the dimension of each staircase block B i is M × M . For a staircase code to have non-trivial rate (i.e., R > 0) the component code rate must satisfy R c > 1/2.
The first staircase block B 0 is fixed to all-zero bit-values. Let r n − k be the number of parity bits in a component codeword. Let G be a k×n systematic generator matrix for C. We denote by G p the k × r sub-matrix of G containing the r columns which correspond to the parity bits in each codeword. For i ∈ {1, 2, . . . }, given block i − 1, to encode the ith block, first fill an M × (M − r) matrix M i with information bits. Next, calculate the M × r matrix P i of parity bits according to
where () T denotes matrix transpose. The ith block is then given by
The rate of a staircase code is given by
where we assumed that the smallest transmission granularity is a complete block B i .
C. Decoding of staircase codes
Staircase codes are decoded using a sliding-window decoder. Consider the blocks in Fig. 1 now to be received blocks buffered in a decoding window of length 6, with all except B 0 corrupted by a BSC.
Decoding proceeds in iterations. Let l ∈ {1, 2 . . . , l max } denote decoding iterations, with the maximum number of iterations denoted by l max . During iteration l, for each i ∈ {1, 2, . . . , 5}, form the matrix B T i−1 B i and decode each row of the matrix by a component code decoder, e.g., a syndrome decoder. Once l = l max is reached, the window "slides" by shifting out decoded block B 0 and shifting in a newly received block B 6 . The decoding process continues indefinitely in this manner.
In practice, the component code decoder can be implemented using efficient table-lookup methods for syndrome decoding to achieve very high decoding throughputs [3, Appendix] [14] . (1), we obtain
D. Motivation
which is a linear recursion of the parity-bit matrix P i . We refer to this as the parity-propagation property of staircase codes. The presence of feedback in the encoding process leads to a number of issues, the most significant of which is the lack of a termination mechanism.
Although staircase codes were designed for continuous transmission applications where termination is not necessary, allowing the encoding process to terminate after a certain number of blocks would extend their domain of application significantly. Furthermore, a terminated staircase code can be decoded by two sliding window decoders working in parallel from both ends of the code. The decoding throughput is doubled at a cost of extra hardware, a favorable trade-off in high-throughput optical-fiber systems.
III. FEED-FORWARD STAIRCASE CODE
The most pragmatic approach to mitigate the effect of parity propagation would be to not re-encode the parity bit block P i . Such an approach is shown in Fig. 2 . However, it becomes quickly obvious that this approach suffers from some important problems. Most importantly, if high-rate component codes with error correcting capability t are used, the occurrence of t + 1 errors in the parity-part of a component code will not be corrected. Hence, if there are t+1 errors in the parity part of a vertical codeword, t+1 errors in the parity part of a horizontal codeword and an additional error in the intersection of both vertical and horizontal codewords, this additional error will not be corrected and will contribute to the error floor of the code, which will become unacceptably high for most applications. Especially in optical communications, where usually residual bit error rates in the range of 10 −13 to 10 −15 are required, a different approach is necessary.
In order to design a code with acceptable error floors, we adopt the parity self-protection technique proposed in [5, App. I.9] to ensure that errors in the parity part of the code do not cause large residual error floors. The structure of the proposed Feed-Forward Staircase Code (FF-SC) with parity self-protection is shown in Fig. 3 . The dark shaded blocks at the bottom of even-indexed information blocks are referred to as column redundancy blocks. Each column redundancy block consists of a parity blockP c and a self-protection block Y . The lightly shaded blocks to the right of odd-indexed information blocks are referred to as row redundancy blocks, each consisting of a parity blockP r and a self-protection block X, which are both punctured (indicated by the light shading in Fig. 3 ). As in a staircase code, an FF-SC parity block contains parity bits calculated during component code encoding. The key difference in an FF-SC is that the bits in a self-protection block, which are a sub-set of the information bits of component codes, are additionally constrained.
Let π 1 and π 2 be permutations defined by
where b ∈ {1, 2}, A is an M × r matrix, and Π b is an M r × M r permutation matrix. By definition, π b are bijective maps, with the property
We define the self-protection constraints
Since π b are bijective, as long as the self-protection constraints are satisfied, we can puncture either the column or row redundancy blocks. For consistency with Fig 3, we puncture the row redundancy blocks in the following. Due to the constraints imposed on self-protection blocks, M must satisfy 2M + r = k, hence M = (k − r)/2 (assuming k and r have the same parity, which can be achieved with shortening). For computing the rate, we first assume that always an even number of blocks B i are transmitted as smallest granularity. The rate of an FF-SC is then
which is identical to the rate of a staircase code. If we want to achieve the finer granularity of conventional staircase codes with single blocks, we define that the parity and self-protection blocks Y andP c are attached to each block with odd index.
In that case, with a total of Λ blocks transmitted we have 
A. Encoding
We slightly generalize the component code definition to allow different binary linear block codes to be used as row and column component codes. Given block-length n and number of information bits k, let C r (n, k) be a row component code with k × n systematic generator matrix G. Let C c (n, k) be a column component code with k × n systematic generator matrix F . Let G p and F p denote the sub-matrices containing the r columns of G and F corresponding to parity-bits.
Due to the self-protection block, the last r bits out of k information bits in a component codeword are constrained. We highlight this fact by partitioning G p and F p according to
where G i and F i are (k − r) × r matrices and G r and F r are r × r matrices. Consider the encoding operation over information blocks B 0 , B 1 , and B 2 in Fig. 3 . Subsequent blocks are encoded in the same manner. By horizontally concatenating B 0 and B 1 , we obtain P r = B 0 B 1 G i .
By vertically concatenating B 1 and B 2 , we obtain
Note that P r and P c are not the same asP r andP c . Consider the entries of the M × r matrix X and the r × M matrix Y to be variables. According to the structure shown in Fig. 3 , we can writeP r andP c as
Imposing self-protection conditions (3) and (4), we obtain
Each of the above terms is an r×M matrix. Let vec(·) be the column-wise vectorization and let y = vec(Y ), p c = vec(P c ), and p r = vec((π 2 (P r )) T ). Let Π T be the permutation matrix satisfying
. Using the fact that for some matrix Q vec(QY ) = (I M ⊗ Q)vec(Y ), the above expression can be written as
The invertibility of A depends on the choices of C r (n, k), C c (n, k), F , G, Π 1 , and Π 2 . Using the same row and column component codes, we have found that searching over the space of all Π 1 and Π 2 can quickly produce an invertible A. The search and calculation of A −1 can be performed offline at design time, since information bits are only involved in the calculation of c.
The main complexity of FF-SC encoding is the multiplication in (6) between an M r × M r matrix and an M r × 1 vector. The complexity of this operation highly depends on the choice of permutation matrices Π 1 and Π 2 . For instance, the permutation matrices may be chosen such that the hardware implementation is simplified or such that A −1 has a special structure easing the multiplication.
B. Decoding
Decoding of FF-SC is very similar to conventional staircase codes. A sliding window decoder is used starting from block B 0 . When corrections are made in a column redundancy block the corresponding row redundancy block is also modified, and vice versa. Additional logic is required to implement the permutations π 1 , π 2 , and their inverses.
C. Low error-floor permutations
We describe a choice of permutations π 1 and π 2 suitable for applications requiring very low error-floors. The permutations π 1 , π 2 are defined by the permutation matrices
together with column-wise vectorization vec(·) and its inverse vec −1 (·). These permutations cyclically shift each column of X and P r by a number of bits related to their column index, an example of which is shown in Fig. 3 . They can be implemented efficiently in hardware using barrel shifters. Discussions of the estimated and simulated error-floor performance under these permutations are given in Sec. V. 
IV. PARTIAL FEED-FORWARD STAIRCASE CODE
Although self-protection allows us to considerably reduce the error floor of feed-forward staircase codes, the error floor (see Sec. VI) may still be unacceptably high for some applications requiring very low residual BERs, e.g., optical core networks. We therefore slightly relax the parity-propagation constraint by allowing the parity bits to propagate over some blocks and introduce Partial Feed-Forward Staircase Codes (PFF-SCs).
Let L ∈ {1, 2, . . . } be the propagation length of a PFF-SC, defined as the maximum number of consecutive blocks over which parity-propagation can occur. The PFF-SC then uses a hybrid structure, with L − 1 blocks being standard staircase code blocks followed by one block with parity bits that are not re-encoded but where self-protection is used to mitigate the detrimental effect of harmful error patterns. The self-protection scheme also results in one block containing only information bits. Figure 4 illustrates the structure of a PFF-SC with L = 3. In this example, 2 out of every 4 blocks are standard staircase code blocks and 1 out of every 4 blocks contains only information bits. Self-protection is used to stop parity-propagation after L = 3 blocks.
Another major difference in PFF-SCs is the position of the self-protection redundancy blocks, which are part of the conventional staircase structure. This modification allows the permutations π 1 , π 2 to be trivial and drastically reduces the error-floor as compared to FF-SC (see Sec. VI). Another difference is that the number of information bits per block B i is not constant. As in FF-SC, we set M = (k − r)/2 to account for the self-protection and all blocks contain M 2 code bits. The component codes are shortened respectively. In order to accommodate the position of self-protection redundancy blocks Y , the component codes involved in self-protection (e.g., codes over blocks B 2 and B 3 as well as B 6 and B 7 in Fig. 4) must be shortened by an extra 2r bits relative to the other component codes.
A. Rate of PFF-SCs
In order to compute the rate of PFF-SCs, we count the number of information bits per block. The first L − 1 blocks 1 blocks B 1 , . . . , B (L+1)i , i ∈ N are transmitted, then the rate can be computed as
which is independent of L. As R PFF − R = (2Rc−2) 2 1−2Rc , we can conclude that R PFF < R as R c > 1 2 has to hold (see Sec. II-B) . However, at high rates the differences are small. For example, R PFF is within 5% of R for R c ≥ 10/11 and within 25% for R c ≥ 5/6. Note that a PFF-SC of non-trivial rate requires R c > 3/4.
This result may seem counter-intuitive at first glance, since it appears that we should recover the original staircase code rate R for L → ∞. However, contrary to the original staircase code construction (see Sec. II), in the proposed construction the component codes of the staircase-like blocks are shortened by 2r, which leads to the observed rate difference. We could relax the granularity constraint of L + 1 blocks and find an expression for R PFF (Λ, L). As this expression is cumbersome and does not lead to any new insights, we omit it here. For practical purposes, it is customary to restrict ourselves to the granularity of L + 1 blocks, allowing for easy termination and avoiding possibly higher error rates at the code boundaries.
B. Description of the Encoder
In this subsection, we describe the encoder of PFF-SC. We focus only on the self-protection blocks, since L − 1 out of L + 1 consecutive blocks are encoded in the same way as the original staircase code. Our explanations will focus on Fig. 5 , which highlights blocks B 2 , B 3 , B 4 , Y ,P c , X, andP r of Fig. 4 for L = 3. Figure 5 further sub-divides each block into sub-blocks. The encoding process consists of two stages. Stage 1 calculates Y 1 . Stage 2 calculates Y 2 based on Y 1 . In terms of implementation complexity, stage 1 is equivalent to component code encoding while stage 2 is a general matrix multiplication. Fortunately, for high code rates where M r, the encoding complexity is dominated by stage 1.
1) Calculating Y 1 : We inherit the definitions of matrices G p , F p , G i , F i , and G r , F r from Sec. III. By horizontally concatenating M 1,1 , M 1,2 , and M 2,1 , we obtain
By vertically concatenating blocks 0 2r×M −2r , M 0,1 and M 1,1 , where 0 2r×M −2r accounts for the extra shortening of the column component codes, we obtain
We writeP c,1 andP r,1 as
Imposing self-protection constraints
c,1 under trivial permutations and solving for Y 1 gives
Since A = 0 r×r if G r = F r , a necessary condition for A to be invertible is G r = F r . Here we satisfy this condition by using different binary cyclic codes as row and column component codes. However, instead of using different component codes with different error correction capabilities and potentially requiring distinct decoder hardware implementations, we propose the following construction: Let g(x) and f (x) be generator polynomials for C r (n, k) and C c (n, k). We require g(x) and f (x) to satisfy the condition
where deg(p(x)) is the degree of the polynomial p(x). The component codes then have the property that the "mirrorimage" of a codeword (c 0 , c 1 , . . . , c n−1 ) ∈ C r (n, k), i.e., (c n−1 , c n−2 , . . . , c 0 ), is a codeword of C c (n, k), and vice versa [15, Ch. 7] . Hence, the same decoder hardware can be reused to decode both component codes, with some simple bit-reversal logic. Using different binary cyclic component codes with generator polynomials satisfying (10) gives an invertible A as G r = F r . By calculating A −1 offline at design time, the complexity of finding Y 1 andP c,1 at encoding time is equivalent to a multiplication between an r × r matrix and an r × M − 2r matrix.
2) Calculating Y 2 : In stage 2, the blocks Y 1 andP c,1 are considered known. By vertically concatenating blocks 0 2r×2r , M 0,2 and M 1,2 we obtain
We partition the matrix G i into 3 sub-matrices with
We can now writẽ
Using (11) and the self-protection constraint Y T 2 = X 2 , we havẽ
Imposing the self-protection constraintP r,2 = (P c,2 ) T and simplification yields
where A was defined implicitly in (9) and with
Note that all terms in (12) are 2r × r matrices. Let vec(·) now denote the row-wise vectorization given by the mapping v(i, j) = in + j. Let y = vec(Y 2 ) and c = vec(C). Let S(A) be the r×2r 2 matrix where for i ∈ [0, r−1] and j = 2ri, the jth column of S(A) is the ith column of A, with zeros elsewhere. We can then equivalently write (12) as
where B is the 2r 2 × 2r 2 matrix given by
3) Finding an invertible B: Since G r and F r were fixed in stage 1 in order to obtain an invertible A, if B is singular, the only way to obtain an invertible B is to manipulate G B using elementary row operations. Here we focus on row permutations of G B only, since they do not affect the error floor.
Let Π be a 2r×2r permutation matrix. Denote the permuted G B byG B ΠG B . A computer search can be used to find an appropriate Π that results in an invertible B.
Given Π, the expressions forP r,2 and B are modified by replacing G B withG B . Note that Π also affects stage 1 calculations, where (8) has to be modified to
For an invertible B, the matrix Y 2 is given by
The complexity of calculating Y 2 is dominated by the multiplication with a 2r 2 × 2r 2 matrix. Since only 1 out of every L + 1 blocks requires self-protection calculations, the average complexity of PFF-SC approaches conventional staircase codes with increasing L.
V. ERROR-FLOOR ANALYSIS
Error-floor analysis of staircase codes and its variants proposed in this paper depends on enumerating the number of stall patterns, i.e., patterns of errors that the decoder cannot remove [3] , [16] . To obtain a simple estimate of the error-floor, we only enumerate the smallest stall patterns resulting from channel errors, referred to as minimal stall patterns.
We consider an erroneously decoded bit to be a bit error only if it is an information bit. A decoded block is considered to be a block error if it contains at least one bit error. The block (BKER) and bit (BER) error-rates are defined according to these definitions.
We estimate the block and bit error-floors of FF-SC based on low-error-floor permutations of Sec. III-C assuming transmission over a BSC with error probability p. An example of a minimal stall pattern for component codes with t = 3 is shown in Fig. 6 , consisting of 4 information-bit errors and 4 redundancy-bit errors from the channel.
To construct such a stall pattern, first choose any 2 out of M rows in the information block, such as the rows marked by the horizontal dashed and dash-dotted lines in Fig. 6 . Denote the chosen rows by r 1 and r 2 . Under the transposes in (3) and (4), the chosen rows are mapped to columns marked by the thin vertical dashed and dash-dotted lines, reflected about the diagonal of the information block.
Under the proposed low-error-floor permutations, bit errors in the row redundancy block are cyclically shifted by no more than 2r − 1 columns, modulo M , in the column redundancy block. In Fig. 6 , the range of cyclic shifts is bounded by the thin and corresponding thick vertical lines. For example, bit errors in the row redundancy block of r 1 may be shifted to columns within the thin and thick dashed vertical lines. For r 2 , bit errors in the row redundancy block may be shifted to columns within the thin and thick dash-dotted vertical lines, wrapping around the right boundary of the column redundancy block. Given r i , we define its valid column set by
It is simple to verify the following spreading property of the low-error-floor permutations: if 2r < M , i.e., R > 1/2 or OH < 100% (where OH denotes the overhead of the code, defined as OH (1/R − 1) × 100%), then row redundancy block bit-errors belonging to the same row cannot belong to the same column in the column redundancy block. Consequently, columns in the stall pattern can only be chosen from the intersection of valid column sets. The number of choices of such columns is
In Fig. 6 , the intersection consists of columns bounded between the thin dashed and thick dash-dotted vertical lines Both proposed classes of codes show similar performance in the waterfall region. PFF-SCs have a slight performance loss at lower rates due to their rate loss, which requires a larger M compared to an FF-SC of the same rate.
In the error-floor region, even with low-error-floor permutations, FF-SCs have observable error-floors. On the other hand, PFF-SCs, due to their similarity to the structure of the original staircase codes, do not exhibit any bit error-floor above a BER of 10 −15 . In fact, the estimates of the bit error-floor are orders of magnitude below 10 −15 . For comparison, we also give the bit error rates of the original staircase codes ( ) constructed using the same component codes. We can see that the original staircase code slightly outperforms the FF-SC and PFF-SC, especially for low rates, however, at high rates, the difference becomes negligible. This difference is most likely due to the stronger coupling between blocks in the original staircase code construction.
Let h(x) be the binary entropy function and erfc −1 (x) be the inverse complementary error function. Given a code of rate R which achieves an output BER of 10 −15 at an input BER of p 15 , we define the NCG gap to capacity (in dB) by ∆ 20 log 10 erfc −1 (2h −1 (1 − R)) − 20 log 10 erfc −1 (2p 15 )
where h −1 (x) is the unique 0 ≤ p < 1/2 such that h(p) = x. We extrapolate the BER curves of PFF-SC down to 10 −15 in order to estimate p 15 . The values of p 15 with the corresponding ∆ are given in Table II . For comparison, we also included the ∆ ref of staircase codes of the same rates from [4] , which were found by exhaustively searching over a wide range of parameters m and t and are considered to be the best staircase codes based on the construction given in Sec. II and [3] . The referenced codes were based on BCH component codes with t ∈ {4, 5}. Nevertheless, the difference in NCG between PFFSCs with t = 3 and the reference codes are less than 0.26 dB. Error-floors of PFF-SCs and the reference codes are identical and well below 10 −15 .
VII. CONCLUSIONS
In this paper, we proposed two modifications to staircase codes which allow for convenient termination. In feed-forward staircase codes, a self-protection technique is used to completely eliminate parity-propagation. In partial feed-forward staircase codes, a propagation-length parameter is used to control the extent of parity-propagation.
Analysis and simulation results show that these codes have similar performance as the original staircase codes. FF-SC have slightly better waterfall performance than PFF-SC, while PFF-SC have much lower error-floors. Hence, FF-SC and PFF-SC are good staircase code solutions for applications where parity-propagation is undesirable or termination is necessary. Input bit error probability Output block and bit error probability 
