1. Field of the Invention
The present invention relates in general to an analog decoding method and decoder.
2. Description of Related Art
Channel coding is used in many communication systems. As a general trend, encoding techniques become more complex to facilitate a variety of desirable applications, such as high speed downlink packet access (for example). It is therefore necessary to provide appropriate decoding hardware.
A channel decoder is commonly implemented in the digital domain. There are two types of digital decoders. The first digital decoder implements an optimal decoding technique (or “APP” decoding) in which symbol error probability is minimized. The APP decoder for a trellis code performs a forward (or “alpha”) recursion starting at the beginning of the code block (code trellis) and a backward (or “beta”) recursion starting at the end of the code block (code trellis). The decoder output is calculated based on the results of the two recursions.
The second digital decoder implements a suboptimal decoding technique (or “sliding window” decoding). The sliding window decoder performs the same basic operations as the APP decoder, however, the sliding window decoder works on sub-blocks (or windows) of the overall code block. Since the backward recursion starts at the end of a window (rather than the end of the overall code block), a stabilization length is necessary (so that the backward recursion closely approximates the true values) before the decoder output can be calculated. As compared to an APP decoder, the sliding window decoder reduces both decoding delay and storage requirements.
Decoding solutions have also been implemented in the analog domain. Known analog decoders have a tailbiting structure in which the beginning and the end of the code trellis are connected together. These existing decoder implementations build the complete code trellis with analog circuitry. That is, the ring size of the analog decoder is equal to the overall block length of the code to be decoded. The applied signals travel around the tailbiting trellis freely until a stable state is reached.
Although conventional decoders are generally thought to be acceptable, they are not without shortcomings. For example, the analog decoder outperforms the digital decoders, and would therefore seem to be an ideal candidate for high speed applications. However, the complexity of the analog circuit grows linearly with the block length of the code since the whole code trellis is mapped onto the analog circuit. Thus, the analog decoder has been limited to applications involving relatively short and simple codes. Another problem is that a particular analog decoder can only be used for a fixed coding scheme (i.e., block length, rate, memory, and interleaver).
The present invention provides an analog decoder that implements a fraction of the overall block length of the code trellis and thus significantly reduces circuit complexity. Furthermore, a single decoder core may be used for various block lengths.
In one exemplary embodiment, the analog decoder includes a controller and an analog decoder core. The analog decoder core has an input with an input length that is shorter than a code length of the code data. The controller performs an apply operation prior to a plurality of read operations. In so doing, the controller applies a portion of the code data to the analog decoder core, then reads decoded data from the analog decoder core, then applies another portion of the code data (updated code data) to the analog decoder core. The updated code data overwrites code data previously applied.
In another exemplary embodiment, the analog decoder includes a controller and a plurality of analog decoder cores. Here, each of the analog decoder cores has an input with an input length that is shorter than a code length of the code data. The controller applies a portion of the code data to each of the analog decoder cores. The controller then reads decoded data from each of the analog decoder cores. The decoded data read from each of the analog decoder cores is based on different portions of the applied code data. In this way, the decoding process may be carried out in parallel.
The present invention will become more fully understood from the detailed description below and the accompanying drawings, wherein like elements are represented by like reference numerals, which are given by way of illustration only and thus are not limiting of the present invention and wherein:
To facilitate understanding of the present invention, the following description is presented in three sections. Section I discusses two conventional decoding techniques inclusive of (A) a posteriori probability (“APP”) decoding and (B) sliding window decoding. Section II presents a generalized sliding window decoding technique as applied to (A) terminated convolutional codes and (B) tailbiting convolution codes, and in subpart (C) introduces a tailbiting trellis structure. Section IH presents two exemplary, non-limiting embodiments of the invention inclusive of (A) a single core—iterative decoding embodiment and (B) a multiple core—parallel decoding embodiment.
Unless otherwise stated, sections I, II, and III are discussed in view of the following considerations: a rate ½ convolutional encoder with memory m and constraint length m+1, where N info bits are encoded into a code word of length 2N; and the trellis of the code is terminated using 2 m additional bits. Typically (but certainly not in all cases), the termination of the code is implemented by starting the encoder in the all zero state and ending the encoder in the all zero state.
I. Conventional Decoding of Convolutional Codes:
The APP and sliding window decoding techniques are well known in this art, and therefore only a brief description of each technique is provided.
A. APP Decoding:
APP decoding, which is also known as the BCJR algorithm, may be considered as an “optimal” technique for decoding convolutional codes since it minimizes the symbol error probability.
The decoder output for an info bit at an instant in time is given in terms of a log-likelihood ratio. And, for a memoryless transmission channel (for example), independent variables inclusive of a values and β values can be defined and used to determine the log-likelihood ratios. The α values are calculated in a forward recursion starting from the beginning of the trellis, while the β values are calculated in a backward recursion starting from the end of the trellis.
If it is assumed that the encoder starts in the all zero state and also ends in the all zero state due to the termination of the code, then the α and the β recursions may be initialized with α0(0)=1 and βN+m(0)=1. That is, both recursions may be initialized with 100% certainty since (due to the code trellis being terminated) information is known about the distribution of the initial α and β values at the beginning and end, respectively, of the code trellis.
The α and β recursions are schematically illustrated in
On the one hand, the APP decoding technique algorithm generally provides superior performance in terms of output accuracy. On the other hand, it introduces a considerable amount of decoding delay when the block size of the code is large. Furthermore, the sequence of all channel values and α values needs to be stored along the trellis, which consumes a significant amount of memory.
B. Sliding Window Decoding:
The sliding window technique, which has conventionally been implemented using a digital decoder core, reduces decoding delay and storage requirements. With reference to
As shown in
The a recursion may be initialized with 100% certainty due the code being terminated, as discussed above with respect to the APP decoding technique. However, the α recursion can not be initialized with 100% certainty due to a lack of information about the distribution of the α values at the end of the first window. Conventionally, therefore, the β recursion is initialized (albeit with some uncertainty) using a uniform distribution (i.e., βw=(½m, ½m, . . . ½m)) or setting βw=αw. Notwithstanding the uncertainty of the β recursion initialization, it is well known in this art that the backward recursion closely approximates the exact β distribution after a stabilization length L of five to six times the constraint length of the code.
Once the first window has been decoded, the decoder window is shifted by D trellis sections to decode the next widow. In so doing, the last α value from the previous window is propagated into the new window to continue the forward recursion in the new window. The β recursion is performed using uncertain initialization values and a stabilization length L, as described with respect to the first window.
The advantages of the sliding window technique are that the decoder output can be calculated for D=W−L trellis sections (info bits) within each window, thereby reducing decoding delay significantly for large overall code block lengths. Further, the channel values need to be stored for only a single window, and the α values need to be stored for only D trellis sections, thereby decreasing memory usage significantly. However, these advantages are achieved at the expense of computational overhead introduced by the additional stabilization length L required for the β recursion within each window.
It will be appreciated that the conventional sliding window algorithm requires a stabilization length only for the β recursion, while the α recursion is calculated exactly as in the APP decoder. That is, the α recursion does not require a stabilization length L due to the known distribution of the α values at the beginning of the trellis.
H. Generalized Sliding Window Decoding Technique:
A. Applied to Terminated Codes:
The sliding window idea may be generalized and applied to a situation that presents an arbitrary window of W trellis sections. The window is characterized as “arbitrary” because no information is available about the distribution of the α values at the beginning of the window (or the β values at the end of the window). Due to the lack of such information, a stabilization length of L trellis sections is necessary for both the forward and the backward recursions.
With reference to
B. Applied to Tailbiting Codes:
It is well known in this art that the generalized sliding window decoding technique can be used to perform suboptimal APP decoding of tailbiting convolutional codes. APP decoding of tailbiting convolutional codes is roughly 2m times more complex than APP decoding of terminated codes.
In a tailbiting code, the state at the beginning and the end of the trellis is not necessarily the first (all zero) state. Instead, any state is possible with the only constraint being that the first and the last state in the trellis is the same for all code words in the set. An advantage of tailbiting codes is that no termination bits are required (and therefore no rate loss occurs) and all code bits are protected equally, which is not the case in a truncated code trellis.
Typically, the block length of a tailbiting code is rather small compared to the window size of a sliding window decoder. So for the moment, consider a scenario in which one window is required to decode the overall code block. That is, assume that the length of the tailbiting trellis is WT=D=W−2L.
With reference to
C. The Tailbiting Trellis Structure:
Instead of using a window of size W (as shown in
For very short tailbiting codes in combination with a high encoder memory, the required stabilization length L (five to six times the constraint length) can be similar in size (or even bigger) as the block length of the tailbiting code, which could result in the α and the β recursions wrapping several times around the tailbiting trellis. This algorithm is therefore also referred to as the wrap-around decoding algorithm.
In this art, it is conventional to use analog decoders to implement a circular (or ring shaped) trellis structure for both the forward and backward recursions. However, according to convention, the stabilization length is not limited to L trellis sections, and the recursions do not start with a uniform distribution of the α and the β values. Instead, the signals travel around the tailbiting trellis freely until a stable state is reached. Thus far, existing decoder implementations build the complete code trellis with analog circuitry. This prohibits the building of decoders for larger and therefore more interesting codes since complexity, and similarly the chip size, grow linearly with the block length.
III. The Analog Sliding Window Decoder:
From a structural standpoint, the analog sliding window decoder of the present invention employs the ring structure of a conventional, analog tailbiting convolutional decoder. However, in contrast to conventional wisdom, only a fraction (i.e., a window of size W trellis sections) of the overall N trellis sections is implemented. This is advantageous in terms of circuit complexity and/or decoding speed, especially for those codes (either terminated or tailbiting) with large block lengths.
As discussed above, unless otherwise stated, the description is based on the following considerations: a rate ½ convolutional encoder with memory m and constraint length m+1, where N info bits are encoded into a code word of length 2N; and the trellis of the code is terminated using 2 m additional bits.
A. Single Core Embodiment:
The physical connections between the controller and the analog decoder core may be provided via pins, wirings, and/or conductive line. However, many alternative connections will be readily apparent from this description, and therefore a detailed description of the same is omitted.
It will be appreciated that the controller 10 and the analog decoder core 12 may be physically implemented as a single component (e.g., a single chip) or a plurality of separate and distinct components.
The functioning of the decoder core will be appreciated with reference to FIGS. 2(a)-2(c), which provide a graphical representation of the analog decoder core 12 using a conventional diagramming technique. According to this convention, the circle itself represents the circuit implementation of a tailbiting trellis structure, and points on the circle (i.e., the portions of the circle at the heads of the radial inwardly directed arrows or the portions of the circle at the tails of the radial outwardly directed arrows) represent the inputs and outputs of the circuit. Thus, in discussing the application of data to or reading data from the analog decoder core 12, a direction (e.g., clockwise) may be given to provide an indication of the inputs and outputs being accessed by the controller 10.
Assume that D=L=W/3, where D is a decoding length, L is a stabilization length, and W is the total input length (window size) of the analog decoder core 12. It is to be appreciated that L is set equal to D for ease of exposition, but the invention is not so limited. For example, L may be set less than (or greater than) D.
Initially, as shown in the upper part of
Since the code is terminated, the controller 10 now controls the forward recursion in a way that it starts in a known state (e.g., the all-zero state). This initialization may be implemented, for example, via the controller applying appropriate values to the internal nodes of the decoder core. Alternatively, the initialization may be achieved via the controller 10 applying a set of values to the inputs “code in” before applying the channel values 1 to W.
After a settling time of the analog decoder core 12, and with reference to the lower part of
After the settling time of the analog decoder core 12, and with reference to the lower part of
As shown in the upper part of
As a result of the initialization, after the settling time of the decoder core, and with reference to the lower part of
It will be appreciated that analog sliding window decoding of a tailbiting convolution code works similarly. However, no initialization is required and a stabilization length will be necessary at the beginning and the end of trellis.
B. Multiple Core Embodiment—Parallel Decoding:
As in the previous embodiment, the physical connections between the controller 10 and the analog decoder cores may be provided via pins, wirings, and/or conductive lines. However, many alternative connections are well known in this art, and therefore a detailed description of the same is omitted. Further, the controller 10 and the analog decoder cores may be physically implemented as a single component (e.g., single chip) or a plurality of separate and distinct components.
The functioning of the analog decoder cores will be appreciated with reference to
As shown in the upper most part of
The controller 10 loads a portion of the code data onto each of the analog decoder cores as shown in the middle part of
Since the code is terminated, the controller 10 controls the forward recursion of the analog decoder core ADC1 in a way that it starts in a known first state (e.g., the all-zero state). This initialization may be implemented, for example, via the controller 10 applying appropriate values to the internal nodes IN1 of the analog decoder core ADC1. Alternatively, the initialization may be achieved via the controller 10 applying a set of values to the inputs CI1 before applying the channel values 1 to Δ3. Also, the controller 10 initializes the backward recursion of the analog decoder core ADC3 so that it starts in the last encoder state (i.e., the all-zero state). This initialization may be implemented by the controller 10 in a fashion similar to that noted above with respect to the forward recursion initialization.
After a settling time of the decoder cores, the controller 10 reads out (via the outputs CO1 . . . N) decoded information O1−O5 from the analog decoder cores as shown in the lower part of
The controller 10 also reads out D=W−2L decoded information bits from the decoder core ADC2. Here, both the forward and the backward recursions require a stabilization length L. Thus, the analog decoder core output O3 is based on the input of the Δ2 through Δ4 trellis sections of the code.
The controller 10 also reads out the last D+L decoded information bits from the decoder core ADC3. The last L (Δ5) information bits may be read out since no stabilization length is required for the backward recursion at the end of the code block due the termination of the code and due to the initialization of the analog decoder core ADC3. Thus, the analog decoder core output O4−O5 is based on the input of the Δ3 through the Δ5 trellis sections of the code.
It will be appreciated that analog sliding window decoding of a tailbiting convolution code works similarly. However, no initialization is required and a stabilization length will be necessary at the beginning and the end of trellis.
Numerous features of the invention including various and novel details of construction and combination of parts have been particularly described with reference to the accompanying drawings and pointed out in the claims. It will be understood that the particular analog sliding window decoding core and decoding method embodying the invention is shown by way of illustration only and not as a limitations of the invention. The principles and features of this invention may be employed in varied and numerous embodiments without departing from the scope of the invention.