The present invention relates to digital communications. More particularly, the present invention relates to error correction circuits and methods in digital communication systems.
A convolutional code has been widely used in many communication systems as a forward error correction (FEC) method. The Viterbi decoding algorithm is optimum for decoding of the received data, which is transmitted after convolutional encoding.
The decoding speed of the Viterbi decoding algorithm is limited by the iteration bound because the add-compare-select (ACS) recursion in the Viterbi decoding algorithm contains feedback loops. A look-ahead technique, which combines several trellis steps into one trellis step in time sequence, has been used for breaking the iteration bound of the Viterbi decoding algorithm. In the look-ahead technique, the combined branch metrics can be computed outside of the ACS recursion (referred as ACS precomputation). This allows the ACS loop to be pipelined or computed in parallel. Thereby, the decoding throughput rate can be increased. This is an advantage of the look-ahead technique. The look-ahead step (M) for a given throughput rate is obtained as the desired throughput rate divided by the ACS recursion clock rate since the overall decoding speed is limited by the allowed maximum frequency of the ACS recursion clock. Therefore, large number of look-ahead steps or high parallelism factor is needed to implement high-throughput rate Viterbi decoding.
In this invention, the ACS computation without the addition of the previous state metrics (or path metrics or accumulated branch metrics) is referred as the ACS precomputation to distinguish it from the ACS recursion, which adds the previous state metrics to the look-ahead branch metrics used for state update operation inside the feedback loop.
The main drawback of the traditional M-step look-ahead technique is that it leads to long latency for look-ahead ACS precomputation, especially when very large number of look-ahead steps is required. When the ACS precomputation unit is implemented as a pipeline structure, the ACS precomputation latency of the traditional M-step look-ahead method increases linearly with respect to the look-ahead step.
In this invention, an alternate approach is considered where the method of combining trellis steps is changed such that the inherent decoding latency can be. It combines K-trellis (where K is the encoder constraint length) steps into one trellis-step and then combines resulting sub-trellises in a layered manner (refereed as K-nested layered look-ahead, LLA). In this approach, the ACS precomputation latency can be significantly decased for high order look-ahead cases as long as the level of parallelism, M, is a multiple of the encoder constraint length, K.
The practical use of this invention is extremely important for implementation of high speed, i.e., 5 or 10 Gb/s, serializer-deserializer (SERDES), where the latency constraint is critical. The SERDES can be used in 10 Gb/s fiber channel synchronous optical network (SONET) or 10 Gb/s Ethernet local area network (LAN), etc. The low-latency Viterbi detector based on this invention may also be used in high density optical or magnetic storage y such as digital video disk (DVD) and hard disk drive (HDD) systems.
For a binary convolutional code, parallel paths exist when the number of incoming paths into a trellis state (2M) is larger than the number of trellis states (2K−1): 2M>2K−1M≧K. Each trellis transition in an M-step look-ahead trellis has 2M−K+1 parallel path. As a result, combining K-trellis steps guarantees two parallel paths between any two-trellis states. Parallel paths are the paths that have the same starting trellis state and same ending trellis state. The existence of parallel paths guarantees that it is possible to use look-ahead ACS precomputation. However, if there are no parallel paths in the look-ahead trellis, only the look-ahead additions of the branch metrics (λ), which are distances between the received data and codewords, are allowed.
The main idea of this invention involves combining K-trellis steps as a pipeline structure and then combining the resulting look-ahead branch metrics as a tree structure in a layered manner to decrease the ACS precomputation latency. This leads to a regular and simple high throughput rate Viterbi decoder architecture with logarithmic increase in latency, as opposed to linear increase in traditional look-ahead, with respect to the look-ahead factor. A restriction of this method is that the look-ahead step M should be a multiple of the encoder constraint length K.
In this invention, each layer-1 processor combines K-trellis steps into one trellis step (K-nesting). The higher layer processors combine two sub-layer trellises, and each layer processor executes the ACS computations in a distributed manner referred as layered look-ahead. The ACS recursion is executed at the top layer. For each trellis state, the layer-1 processor selects one path from two parallel paths and leads to a fully connected trellis with no parallel paths. When two fully connected trellises with no parallel paths are combined into one, 2K−1 parallel paths are generated between any two-trellis states. Therefore, the layer-2 and higher layer processors select one path from 2K−1 parallel paths instead of 2M−K+1 parallel paths.
The present invention is described with reference to the accompanying figures in the figures, like reference numbers indicate identical or functionally similar elements. Additionally, the left-most digit or digits of a reference number identify the figure in which the reference number first appears. The accompanying figures, which are incorporated herein and form part of the specification, illustrate the present invention and, together with the description, further serve to explain the principles of the invention and to enable a person skilled in the relevant art to make and use the invention.
In the look-ahead technique, the combined branch metrics can be computed outside of the ACS recursion. This allows the ACS loop to be pipelined or computed in parallel. Thereby, the decoding throughput rate can be increased. This is an advantage of the look-ahead technique, which has been explored for Viterbi decoding algorithm and the dynamic programming problems.
The ACS precomputation part (circuit 110) consists of 2-input adders (circuit 112), radix-2 ACS circuits (114), and pipelining latches (circuit 116). Each radix-2 ACS circuit consists of two 2-input adders and a radix-2 compare-select (CS) circuit. Circuit 110 uses M-parallel incoming branch metrics (signal 101) for its ACS precomputation. For the first (K-1)-steps branch metrics inputs, compare-select operations are not necessary. Therefore, 2-input adders (circuit 112) can be used for those inputs. From the K-th branch metrics inputs, radix-2 ACS circuits (114) are used for add-compare-select operations. From the ACS precomputation part (circuit 110), M-step look-ahead branch metrics (signal 103) are obtained. The M-step look-ahead branch metrics (signal 103) are used as inputs of ACS recursion part (circuit 120).
The ACS recursion part (circuit 120) consists of radix-2K−1 ACS circuits (122) and pipelining latches (circuit 124). Each radix-2K−1 ACS circuit (122) consists of 2-input adders and a radix-2k−1 ACS circuit. It adds M-step look-ahead branch metrics (signal 103) and state metrics (signal 107) of the previous step and performs compare-select operation to select a maximum likelihood path. The state metrics (signal 105) of the selected path is used for computation of the next ACS recursion.
ACS computation units (circuits 210, 220, and 230) contain P1 (circuit 210) and P2 (circuits 220 and 230) for ACS precomputation and P3 (circuit 240) for ACS recursion with pipelining latches (circuits 216, 224, 234, and 250). The required numbers of processors for ACS computation are as follows: m for P1 (circuit 210), (m−1) for P2 (circuits 220 and 230), and 1 for P3 (circuit 240).
The ACS computations are executed in a layered manner by circuits (210, 220, 230, 240, and 250) as follows.
Layer-1 processor, P1 (circuit 210): Layer-1 ACS precomputation needs m-P1 processors. Each P1 (circuit 210) executes K-step look-ahead ACS precomputation with K-parallel incoming branch metrics (signal 211) as follows:
ph,j1(n+K(i+1)−1)=min{ph,j(n+K(i+1)−1), qh,j(n+K(i+1)−1)}. EQ. 1
Here subscripts h and j stand for trellis states: 0≦h,j≦2K−1−1. The parameter i is a sequence index starting from 0. Signals ph,j(n+K(i+1)−1) and qh,j(n+K(i+1)−1) in EQ. 1 are the K-step look-ahead branch metrics of the two parallel paths between starting trellis state and ending trellis state-j, which are the sums of the K-parallel incoming branch metrics (signal 211): λh,0(n+Ki)+ . . . +λc,l(n+K(i+1)−2)+λl,j(n+K(i+1)−1). The signal 215, ph,j1(n+K (i+1)−1), is the selected K-step look-ahead branch metrics from the two parallel paths (signals 213a and 213b).
The parallel-path-select (PPS) signals for the trellis state-j in layer-1, which contain survivor path information of each selected parallel path between starting trellis state-h and ending trellis state-j, are obtained as follows:
The superscript of PPS represents the ACS precomputation layer. In layer-1, each trellis state has 2K−1 one-bit PPS signals. These are referred as PPSh,j,i1[0].
Layer-k Processor, P2 (circuits 220 and 230) for 2≦k≦log2 m+1: For layer-k ACS precomputation, m/2k−1-P2 processors are needed. Each P2 executes 2k−1·K-step look-ahead ACS precomputation using two 2k−2·K-step look-ahead branch metrics as follows:
where the subscript, N, repesents the number of trellis states: N=2K−1.
In layer-k each trellis state has 2K−1-PPS signals, which consist of (K−1)-bits because there are 2K−1 parallel paths between starting trellis state-h and ending trellis state-j with 2K−1 leading trellis states. These are referred as PPSh,j,ik[K−2:0].
ACS recursion processor (circuits 240 and 250): The ACS recursion processor consists of a P3 (circuit 240) and pipelining latches (circuit 250). The P3 and the pipelining latch execute the ACS recursion using 2m−1·K-step look-ahead branch metrics and the previous state metrics, γj(n+mKi), as follows:
where signal ph,jl(n+mK(i+1)−1) is the mK-step look-ahead branch metric that starts from trellis state and ends a trellis state-j and l=log2 m+1. The parameter γj(n+mK(i+1)) is the new state metrics of the trellis state-j.
In P3 (circuit 240), each trellis state needs 2K−1 path-select (PS) signals, which consist of (K−1)-bits to distinguish 2K−1 incoming paths to a trellis state-j from 2K−1 leading trellis states: PSj,i[K−2:0].
In
The diagram 320 is the resulting trellis diagram of the layer-1 processor. Each layer-2 processor combines resulting signals (signal 321+signal 323 and signal 325+signal 327) of layer-1 processors and selects a trellis path (signal 331) from two parallel trellis paths (signal 321+signal 323 and signal 325+signal 327).
The diagram 330 is the resulting trellis diagram of the layer-2 processor. Each layer-3 processor combines resulting signals (signal 331+signal 333 and signal 335+signal 337) of layer-2 processors and selects a trellis path (signal 341) from two parallel trellis paths (signal 331+signal 333 and signal 335+signal 337).
The diagram 340 is the resulting trellis diagram of the layer-3 processor. Each ACS recursion processor adds signals (signal 341a+signal 343a, signal 341b+signal 343b, signal 341c+signal 343c, and signal 341d+signal 343d) and selects a trellis path from four trellis paths (signal 341a+signal 343a, signal 341b+signal 343b, signal 341c+signal 343c, and signal 341d+signal 343d).
In
The mK-step K-nested LLA Viterbi decoder consists of serial-to-parallel converter (SPC), branch metrics calculator (BMC), ACS computation units, and survivor path management (M#) units. The serially received data sequence is converted into parallel data sequences by the SPC. The BMC computes Euclidean (soft decision) or Hamming (hard decision) distances of the received data with respect to the codeword. Architectures of SPC and BMC are for the traditional M-step look-ahead method and the proposed method are same and not considered in this invention.
In the layer-1 ACS precomputation, four P1 processors (circuits 402, 404, 406, and 408), which have 3-parallel incoming branch metrics each, are needed. Each P1 executes the ACS precomputation as follows: add 3-parallel incoming branch metrics and compare select two resulting parallel paths.
Each P1 processor executes the ACS precomputation for {λ(n), λ(n+1), and λ(n+2)}, {λ(n+3), λ(n+4), and λ(n+5)}, {λ(n+6), λ(n+7), and λ(n+8)}, and {λ(n+9), λ(n+10), and λ(n+11)} as follows:
p0,0(n+3i+2)=λ0,0(n+3i)+λ0,0(n+3i+1)+λ0,0(n+3i+2),
q0,0(n+3i+2)=λ0,2(n+3i)+λ2,1(n+3i+1)+λ1,0(n+3i+2),
p1,0(n+3i+2)=λ1,0(n+3i)+λ0,0(n+3i+1)+λ0,0(n+3i+2),
q1,0(n+3i+2)=λ1,2(n+3i)+λ2,1(n+3i+1)+λ1,0(n+3i+2),
p2,0(n+3i+2)=λ2,1(n+3i)+λ1,0(n+3i+1)+λ0,0(n+3i+2),
q2,0(n+3i+2)=λ2,3(n+3i)+λ3,1(n+3i+1)+λ1,0(n+3i+2),
p3,0(n+3i+2)=λ3,1(n+3i)+λ1,0(n+3i+1)+λ0,0(n+3i+2),
q3,0(n+3i+2)=λ3,3(n+3i)+λ3,1(n+3i+1)+λ1,0(n+3i+2). EQ. 5
where index i=0, 1, 2, and 3. ph,j(n+3i+2) and qh,j (n+3i+2) are 3-step look-ahead branch metrics of two parallel paths, which start from trellis state-h and end at trellis state-j. EQ. 5 only shows that the ACS precomputations for trellis state-0. The ACS precomputations for other trellis states are similar with that of the trellis state-0.
The common teems in the K-nested look-ahead branch metrics computation equations (EQ. 5) for trellis state-j can be grouped as
A=λ0,0(n+3i+1)+λ0,0(n+3i+2),
B=λ1,0(n+3i+1)+λ0,0(n+3i+2),
C=λ2,1(n+3i+1)+λ1,0(n+3i+2),
D=λ3,1(n+3i+1)+λ1,0(n+3i+2). EQ. 6
For each trellis state-j, P1 selects the minimum paths as follows
ph,j1(n+3i+2)=min{ph,j(n+3i+2),qh,j(n+3i+2)} EQ. 7
where subscripts h and j stand for trellis states: 0≦h,j≦3.
Four PPS signals are needed for each trellis state: PPS0,j,i1[0], PPS1,j,i1[0], PPS2,j,i1[0], and PPS3,j,i1[0], which consist of one-bit each, since each trellis state has four selected 3-step look-ahead branch metrics, such as p0,j1, p1,j1, p2,j1, and p3,j1.
In layer-k, where 2≦k≦3, P2 processors select the minimum paths for trellis state-j as follows:
Each trellis state has four PPS signals: PPS0,j,ik[1:0], PPS2,j,ik[1:0], PPS1,j,ik[1:0], and PPS3,j,ik[1:0], which consist of two-bits each.
For each trellis state-j, the P3's execute the ACS recursions as
where the subscript-j=0, 1, 2, and 3 when K=3. For each trellis state, P3 produces one-survivor path information: PSj,i[1:0], which consists of two bits.
In
LCS
CCS
In EQ. 11, the complexity represents the number of two input adders (or subtractors) for compare operations.
The survivor path information is easily controlled in a step by step manner, sonar in Table I, since the proposed 12-step K-nested LLA method has the layered structure. The layer-1 survivor path signals (PPSh,j,i1[0] and PPS1,j,i+11[0]) are selected by the layer-2 survivor path signal (PPSh,j,i2[1:0]). The layer-2 survivor path signals (PPSh,j,i2[1:0] and PPSh,j,i+12[1:0]) are selected by the layer-3 survivor path signal (PPSh,j,i3[1:0]).
The survivor path management (SPM: M2, M3, and MA) circuits (900, 1000, and 1100) are modified multiplexers for survivor path selection in each ACS computation layer. They select and rearrange the PPS's of the sub-layers. The required number of SPM units is the same as the number of P2 and P3 units, since layer-1 does not need SPM.
In M2, signal PPSh,j,i2[1:0] selects one PPS signal pair from four PPS signal pairs which start at trellis state-h and end at trellis state-j according to its value and rearrange them as an output Yh,j,i2[0:3]. In
In M3, PPSh,j,i3[1:0] selects one PPS signal pair from four PPS signal pairs which start at trellis state-h and end at trellis state-j according to its value and rearrange them as an output Yh,j,i3[0:9]. In
In MA, PSj,i[1:0] selects one PPS signal from four PPS signals and concatenates it with the selected PPS signal. In
The
signals become the decoded data sequence when the trellis state-j has the smallest state metrics. When the look-ahead step is large (e.g., mK≧4K), all states have the same YACSr, i.e.,
Therefore, any one of the YACSr sequences can be used as the decoded data sequence without minimum state finding as shown in
becomes the first decoded data bit. This survivor path management method can be systematically expanded for higher order look-ahead architectures.
MA processors (circuits 1110, 1120, 1130, and 1140) have 4-to-1 multiplexers (circuits 1112, 1122, 1132, and 1142) and pipelining latches (circuits 1114a, 1114b, 1124a, 1124b, 1134a, 1134b, 1144a, and 1144b).
The latency of ACS precomputation for the proposed (Lproposed) and the traditional (Lconv) M-step look-ahead architecture can be calculated as follows:
In EQ. 12, the first term K comes from computing the parallel branch metrics and CS of the sub-trellis, and the second term K·log2 (M/K) corresponds to the ACS unit in each layered stage. As shown in
The complexity of the ACS precomputation can be represented as the number of two-input adders required for the ACS precomputation. For the proposed M-step K-nested LLA architecture, the number of two-input adders (Cproposed) is
Cproposed=Cproposed
where the number of two input adders (Cproposed
For the traditional M-step look-ahead architectures with pipeline structure, the number of two-input adders (Cconv) required for the ACS precomputation is
where the number of two input adders (Cconv
C
conv
CS
r2=(2K−i)2(M−K+1) EQ. 15.b
The decoding latency and the complexity of the ACS precomputation for M-step look-ahead architecture are summarized in Table II. As can be seen in Table II, even if the look-ahead step (M) is not a power-of-two multiple of the encoder constraint length (K), low-latency Viterbi decoders can be implemented efficiently. For example, if K=7, a 49-parallel design has equivalent latency but fewer functional units than a 56-parallel (23-multiple of K) design.
Various embodiments of the present invention have been described above. These various embodiments can be implemented, for example, in optical fiber, twisted-pair, coaxial cable, and wireless communication receivers. These various embodiments can also be implemented in systems other than communications systems. It should be understood that these embodiments have been presented by way of example only, and not limitation. It will be understood by those skilled in the relevant art that various changes in form and details of the embodiments described above may be made without departing from the spirit and scope of the present invention as defined in the claims. Thus, the breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
This application is a continuation-in-part of U.S. Provisional Patent Application No. 60/496,307, filed on Aug. 19, 2003, which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5042036 | Fettweis | Aug 1991 | A |
5530707 | Lin | Jun 1996 | A |
5935270 | Lin | Aug 1999 | A |
6343105 | Saegusa | Jan 2002 | B1 |
6539367 | Blanksby et al. | Mar 2003 | B1 |
20040243908 | Box et al. | Dec 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
20050060633 A1 | Mar 2005 | US |
Number | Date | Country | |
---|---|---|---|
60496307 | Aug 2003 | US |