This invention relates to construction of an optimal trellis diagram, based on a parity check matrix for BCH encoding for error detection.
A product code is a multi-dimensional array of (n,k) linear block code that exploits a simple and relatively efficient method to construct more powerful codes using linear block code structures.
In the encoding, each row of k2 data values is augmented to include n2−k2 parity check bits for the data in that row; and each column of k1 data values is augmented to include n1−k1 parity check bits for the data in that column. The (n1−k1)×(n2−k2) region at the lower right of this block contains parity check bits for each of the n2−k2 columns above and for each of the n1−k1 rows to the left. Where, for example, a 64QAM configuration is adopted, k1=k2=57 and n1=n2=63. Because 57=26−6−1, the 7 conventional parity check bits can be replaced by 7 error check bits (Hamming, BCH, etc.), as discussed in S. B. Wicker, Error Control Systems, Prentice Hall, Englewood Cliffs NJ, 1995, pp. 8-11, 90-94 and elsewhere. Use of a QAM constellation is discussed by W. Tomasi, Electronic Communication Systems, Prentice Hall, Englewood Cliffs, NJ, 1988, pp. 503-527.
Use of a trellis construction for block and convolution codes allows an improvement in effective bit transfer rate, through a procedure discussed in some detail in S.B. Wicker, ibid., pp. 356-392. The procedure includes (1) insertion of a redundant bit for every m bits, (2) expansion of the signal constellation (e.g., QAM) from 2m to 2m+1 symbols, and (3) use of an (m+1)-bit encoded source block to specify a signal from the expanded constellation. However, construction of a trellis diagram for optimal BCH decoding has not been disclosed.
What is needed is an approach for constructing a simplified trellis diagram that is optimal for BCH decoding.
These needs are met by the invention, which provides a method and system for constructing a trellis diagram that, in one embodiment, relies on the following sequence of processes: (1) receiving BCH-encoded information having a corresponding (n−k)×(n) parity check matrix H, constructed according to a BCH error code, where n and k are selected positive integers with k<n; (2) expressing the parity check matrix H as an ordered sequence of columns of matrices {h1, h2, . . . , hn}; (3) providing a sequence of sub-code words ai={c1, . . . , ci} (i=1, . . . , n), corresponding to at least one code word c={c1, . . . , cn} that satisfies c·Htr=0n−k; (4) providing a matrix Hcp, having columns {hcp1, hcp2, . . . , hcpn} that are a selected permutation of the columns of the matrix H, forming a sequence of sub-matrices Hcpi={hcp1, . . . , hcpi}, forming a corresponding permuted code word ccp={ccp1, . . . , ccpn}, and forming a sequence of corresponding permuted sub-code words acpi={ccp1, . . . , ccpi}; and (5) providing a trellis diagram, symmetric about a central location and representing an ordered sequence of code word transitions, in the received information, for the at least one code word c, connecting n+1 stages, numbered i=0, 1, . . . , n, in an ordered sequence, where each of stage i=0 and stage i=n in the trellis has one state, each stage has at least one state, and (i) where the number of states in stage i+1 is no greater than the number of states in stage i, the number of input branches for each state in stage i+1 is 2, (ii) where the number of states in stage i+1 is greater than the number of states in stage i, the number of input branches for each state in stage i+1 is 1, and (iii) a state in stage i+1 is determined by a sum of a corresponding state in stage i and a product of the matrix Hcpi and the sub-code word bit value acpi. Preferably, the trellis diagram is constructed so that no state has more than two input branches or more than two output branches.
Optionally, the trellis diagram is constructed so that the number of states in a stage i is equal to the number of states in a stage n−i, for 0<i<n/2.
Among 64 bits generated in an encoder, the first 57 MSB bits are message bits that have been received by the encoder, which may have the structure illustrated in
A Bose-Chaudury-Hocquenheim (BCH) error detection and correction code, such as BCH(64,57) with 7 error check bits, is generated by a particular generator polynomial, such as p(x)=x6+x+1, with an encoder structure illustrated in
where the row matrices g1, g2, . . . , gk are linearly independent over the field GF(2). The 2K linear combinations of the K row matrices gk of G provide a code word space.
If A=(a1, a2, . . . , ak) is a message to be encoded, a natural encoding procedure maps the message A into a code word u=(u1, u2, . . . , un), where
u=a·G=a1·g1+a2·g2+ . . . +ak·gk, (2)
and the ith component of the code word becomes
ui=a1·g1i+a2·g2i+ . . . +ak·gki; (3)
k information bits are encoded into n bits and shifted serially onto the channel.
The generator matrix for a BCH(n,n−k) code is expressible as
where Ik is a k×k identity matrix and Pn−k is an (n−k)×(k) matrix of rank at most n−k.
A binary (n,k) linear block code C is uniquely specified by an (n−k)×(n) matrix H over GF(2), sometimes referred to as a parity check matrix for G. In systematic form, H is an (n−k)×(n) matrix, expressible as
and the n-k rows are linearly independent. A binary n-tuple v=(v1, . . . , vn) is a code word in C if and only if
u·Htr=0n−k. (6)
A binary (n,k) linear block code in C can be represented by an n-section trellis diagram, referred to as “T,” over a sequence of stages {0, 1, 2, . . . , n}. A trellis T is a directed graph consisting of n+1 levels of nodes (states) and edges (branches) that displays or represents the stage-varying behavior of the corresponding encoder. A trellis includes the following features:
1. The state space of the trellis at a node corresponding to stage m (0≦m≦n), denoted ΣmC, is the set of states at that stage. At stage 0, only one (initial) node, σ0, is available. At stage n, only one (final) node σn exists. For intermediate stages, more than one state may be available.
2. For t0≦tm≦tn, a branch in section m of the trellis T connects a state σm−1εΣm−1Cm′ to a state σmεΣmCm′, and has a label vm−1 that represents the encoder output in a stage interval tm−1≦t≦tm.(or (m−1,m)).
3. Except for the initial and final states, every (intermediate) state has at least one, but no more than two, incoming branches and at least one, but no more than two, outgoing branches. An initial (final) state has no incoming (no outgoing) branches. Two branches diverging from the same state have labels that differ from each other.
4. A directed path from an initial state so to a final state sn exists with a label sequence {v0, v1, . . . , vn} if and only if {v0, v1, vn} is in C.
A trellis diagram for C is referred to as “minimal” if the number of states at each of the stages is a minimum. A minimal trellis is unique, except for graph isomorphisms. A minimal trellis is constructed here, using a parity check matrix, and will be used to decode a BCH (64,57) code. Consider a binary (n,k) linear block code C having a parity-check matrix
H={h1, h2, . . . , hn}. (7)
where the column matrices hj denotes matrices for column j (1≦j≦n), which is a binary (n−k)-tuple. A binary n-tuple u is a code word in C if and only if u satisfies Eq. (6).
A (column-permuted) matrix Hcp={hcp1, hcp2, . . . , hcpn} is formed, having columns that are a selected permutation of the columns of the matrix H, referred to as a “column-permutation-for binary-matching” and described in the following. For 1≦i≦n, let Hi denote the (n−k)×(i) sub-matrix
Hcpi={hcp1, . . . , hcpi}, (8)
let
ccp={ccp1, . . . , ccpn} (9)
be a permuted code word, constructed according to the same permutation, and let
acpi={ccp1, . . . , ccpi} (10)
be a permuted sub-code word of the permuted code word ccp (stages 0 to stage i).
State and branch labeling of the trellis are defined as follows. The label of a state σiεΣiC, denoted S(σi) is a binary (n−k)-tuple
S(σi)=acpi·Hcpitr=(s1, s2, . . . , sn−k). (11)
For i=0, the initial state σ0 is labeled with an all-zero-entry (n−k)-tuple, 0n−k. For i=n, where acpi =ccp, the final state is also labeled with 0n−k. For intermediate states (1≦i≦n−1), let σiεΣiC and σi+1εΣi+1C be adjacent states, and let ui+1 by the branch in the code trellis that connects the states σi and σi+1. The label ui+1 is the permuted encoder output bit in the stage interval (i,i+1), from stage i to stage i+1, and is set forth in Eq. (3). For each path (u1, u2 . . . , ui) connecting σ0 and σi, the path (u0, . . . , ui+1), obtained by concatenating the first path with ui+1, is a path connecting σ0 and σi+1 through the state σi. The state label S(σi+1) is verified to be
S(σi+1)=(u1, . . . , ui, ui+1)·Hcpi+1tr=S(σi)+ui+1·hcpi+1tr. (12)
This last relation indicates that, for a “starting” state, labeled S(σi), and an output code bit ui+1 for the stage interval (i,i+1), the designation state label S(σi+1) at stage i+1 is uniquely determined.
The complexity of the trellis diagram depends upon the structure of the parity check matrix H. By permuting the order of the columns of H and of the code words c, and thus changing the order of the encoded symbols, the trellis can be simplified or made more complex.
Appendix A sets forth the original matrix H for the BCH(64,57) code. Appendices B and C illustrate operations that map H onto a column-permuted matrix Hcp, which is set forth in Appendix D. Implementation of a “column-permutation-for-binary-matching” process, as illustrated in the Appendices A-D, involves the following: (1) rearrange the columns H(m) (m=0, . . . . , n−1) of the matrix H in order of increasing (or decreasing) order of binary value of the column entries; (2) form contiguous pairs of columns H(m′) and H(m″) for which a modulo-two sum, without carry, of corresponding entries for entries in these two columns produce a selected ordered sequence of binary values (here selected to be the binary value sequence 0111100); (3) provide a sequence of the n/2 contiguous pairs for which (i) the first n/8 pairs have LSB=1 and have MSB=1, (ii) the next n/8 pairs have LSB=0 and MSB=1, (iii) the next n/8 pairs have LSB=0 and MSB=0, and (iv) the remaining n/8 pairs have LSB=1 and MSB=0. This assumes that the integer n is divisible by 8.
The matrix Hcp has a corresponding modified trellis diagram, illustrated in
For the particular example shown in
Because an (n,k) linear block code can be represented as a trellis, one can always decode the code using MAP (Maximum a posteriori probability) and an iterative decoding algorithm that were originally used in decoding convolutional code. A preferred embodiment uses a Maximum-Log-MAP algorithm. The MAP and Maximum-Log-MAP algorithms are well known to workers in this field.
The particular trellis in
In step 59, the system provides a trellis diagram, symmetric about a central location and representing an ordered sequence of code word transitions, in the received information, for the at least one code word c, connecting n+1 stages, numbered i=0, 1, . . . , n, in an ordered sequence, where each of stage i=0 and stage i=n in the trellis has one state, each stage has at least one state, and (i) where the number of states in stage i+1 is no greater than the number of states in stage i, the number of input branches for each state in stage i+1 is 2, (ii) where the number of states in stage i+1 is greater than the number of states in stage i, the number of input branches for each state in stage i+1 is 1, and (iii) a state in stage i+1 is determined by a sum of a corresponding state in stage i and a product of the matrix Hcpi and the sub-code word bit value acpi.
The generator polynomial g(x)=x6+x+1 is one of a group of polynomials in GF(2m), for the particular choice m=6, that can be used here, as set forth in S. B. Wicker, ibid., pp. 444-445. This group of generator polynomials includes the following:
g(x)=x6+x+1,
g(x)=x6+x5+1,
g(x)=x6+x5+x3+x2+1,
g(x)=x6+x5+x4+x+1,
g(x)=x6+x5+x2+x+1,
g(x)=x6+x4+x3+x+1.
Appendix B. Mapping of Parity Check Matrix H To Matrix Hcp.
The original parity check matrix H is mapped onto a column-permuted matrix Hcp, having the same dimensions, in the following manner. One first permutes the columns of the matrix H to form a matrix H2 in which the binary values corresponding to each column (e.g., H(08), which has a binary value of 1 +4+8=13) are arranged in a strictly monotonically increasing array, as indicated in the following. One then associates with each other two separate columns that have a modulo-two sum (without carry) equal to a selected binary array, here chosen to be the array {0 1 1 1 1 0 0}; other seven-entry arrays can also be used for the binary matching. In the following, each column entry for the matrix H2 has a corresponding (unique) second column entry (“addend”) for which the modulo-two sum is the array {0 1 1 1 1 0 0 0}, as indicated. The column entries of the matrix H2 are transposed or permuted so that a column entry and its corresponding addend column entry are contiguous. The result of this operation is the column-permuted matrix Hcp (or H3) shown in Appendix C. This total process (H→H2→Hcp) is referred to herein as the column-permutation-for-binary-matching process.
Appendix C. Rearrangement of H2 Matrix Order
The order of the individual entry pairs (H2 matrix column entry plus corresponding addend column entry) is rearranged into (1) eight pairs having LSB=1 and MSB=1, with the highest H2 binary values and having MSB=1, (2) eight pairs having LSB=0 and MSB=1, with the (next) highest H2 binary values; (3) eight pairs having LSB=0 and MSB=0, with the (next) highest H2 binary values; and (4) eight pairs having LSB=1 and MSB=0, having the remaining H2 binary values, in that order. The result of this rearrangement of order of the entry pairs is set forth below as a matrix H3, having a column order as shown, in terms of the original H matrix columns
Appendix D. Column-Permuted H Matrix Elements (Hcp).
The result of the “column-permutation-for-binary-matching” process is the matrix Hcp (referred to as “H4” herein), shown in the first column and used to generate the trellis shown in
H4 Matrix Column Corresponding H Matrix Column
Appendix E. Example of Use of H4 Matrix
Generation of the desired trellis begins with stage 0, which has only one state, the 0-state. The first column of H4 is hcp0 ={0000001}. In each stage, the BCH encoder output bit can have only one of two values, “0” or “1.” The labels for the first stage are
S1(0)=S0(0)+acp0·hcp0={000000}+0·{0000001}={0000000}, (E-1)
S1(1)=S0(0)+acp1·hcp0={0000000}+1 {0000001}={0000001}. (E-2)
The two labels S1 (0) and S (0) are seven-bit formats with binary values BV =0 and BV=1.
For stage 1, two states are available, namely “0” and “1.” Two branches are output from state “0” at stage 0. The number of input branches of states in stage 1 is 1. For state “0” in stage 1, the input branch corresponds to the encoder output “0”; for state “1” in stage 1, the input branch corresponds to the encoder output 1.
For stage 2, the second column of H4 is h1={0111101}. The labels for the second stage are
S2(0)=S1(0)+acp0·hcp1={0000000}+0·{0111101}={0000000}, (E-3)
S2(1)=S1(0)+acp1·hcp1={0000000}+1·{0111101}={0111101}, (E-4)
S2(2)=S1(1)+acp0·hcp1={0000001}+0·{01111011}={0000001}, (E-5)
S2(3)=S1(1)+acp1·hcp1={0000001}+1·{0111101}={0111100}. (E-6)
The four labels for stage 2, S2(0), S2(1), S2(2) and S2(3), have the respective binary values BV of 0, 61, 1 and 60. The number of input branches of the states in stage 2 is 1. This bifurcation process continues until stage 32.
Because only one state (“0”) occurs in the last stage (stage 63), one can also generate a trellis by moving backward from stage 63, also ending at stage 32.
The corresponding labels for stage 62 and 61 become
S62(0)=S63(0)+acp0·hcp63={000000}+0·{1011101}={0000000}, (E-7)
S62(1)=S63(0)+acp0·hcp63={0000000}+1·{1011101}={1011101}, (E-8)
S61(0)=S62(0)+acp0·hcp62={0000000}+0·{1100001}={0000000}, (E-9)
S61(1)=S62(0)+acp1·hcp62={0000000}+1·{1100001}={1100001}, (E-10)
S61(2)=S62(1)+acp0·hcp62={1011101}+0·{1100001}={1011101}, (E-11)
S61(3)=S62(1)+acp1·hcp62={1011101}+1·{1100001}={0111101}, (E-12)
with corresponding binary values BV of 0, 93, 0, 97, 93 and 61, respectively.
The trellis generated in a forward direction (beginning at stage 1) will merge with the trellis moving in a backward direction (beginning at stage 64). The forward-moving and backward-moving trellises merge at stage 32. Beyond stage 32, one can remove from the forward-moving trellis states that were included in only one of the forward-moving and the backward-moving trellises; this includes removal of the corresponding input and output branches. This processing results in the (symmetric) trellis shown in
Where the number of states in stage i+1 is no greater than the number of states in stage i, the number of input branches for each state in stage i+1 is 2. Where the number of states in stage i+1 is greater than the number of states in stage i, the number of input branches for each state in stage i+1 is 1.
Number | Name | Date | Kind |
---|---|---|---|
4933956 | Forney, Jr. | Jun 1990 | A |
5440570 | Wei et al. | Aug 1995 | A |
6065147 | Pyndiah et al. | May 2000 | A |
6802037 | Kim et al. | Oct 2004 | B2 |