The drawings accompanying and forming part of this specification are included to depict certain aspects of the invention. The invention may be better understood by reference to one or more of these drawings in combination with the description presented herein. It should be noted that the features illustrated in the drawings are not necessarily drawn to scale.
The following detailed description of the invention refers to the accompanying drawings. The description includes exemplary embodiments, not excluding other embodiments, and changes may be made to the embodiments described without departing from the spirit and scope of the invention. The following detailed description does not limit the invention. Instead, the scope of the invention is defined by the appended claims.
One embodiment of the present invention determines localized burst errors in a message based on the cumulative metrics of a maximum likelihood (ML) path and all alternative paths, generated by the ML trellis code decoder employing the Viterbi algorithm. If a decoded message contains a cyclic redundancy check (CRC) error, the codewords that have burst errors are identified and re-transmitted. Since the retransmission only involves the codewords with burst errors, the efficiency of the network is not jeopardized.
Assume that an original message is padded with J parity bits based on the error detection code (EDC). The EDC coded message is then divided into N segments. After a trellis code encoder encodes each of the segments, a codeword of a length L is formed.
A trellis code decoder applies the Viterbi algorithm, which is based on the maximum likelihood (ML) algorithm, to a codeword after it is received. It can also apply the Viterbi algorithm to all N codewords after they are received. The Viterbi algorithm finds an ML path, i.e. the one with the smallest metric or Euclidian distance, in order to recover the original message. Subsequently the EDC decoder decodes the receiving message decoded by the trellis code decoder. The EDC decoder determines the accuracy of the receiving message by checking if a CRC error exists in the receiving message. In other words, the decoded message is deemed inaccurate if a CRC error is present.
An alternative path is a path that follows the ML path of the decoded message for a period of time, diverges from it at time instance i, and merges with it at time instance j, where i<j. In
A symbol Δk represents the absolute difference between cumulative metrics of the ML path and an alternative path at time instance k. All the Δk, each of which corresponds one alternative path, are stored in a list L. The elements in the list L are sorted in an ascending order, and a predetermined number of elements, namely Δi, are selected from the beginning of the list to form an ordered list {tilde over (L)}, where Δ{tilde over (1)}<Δ{tilde over (2)}< . . . <Δ{tilde over (M)}.
After the receiving message is decoded by the trellis code decoder, it is decoded by the EDC decoder. If there is a CRC error in the decoded receiving message, the localized burst error detector identifies one or more codewords with the localized burst errors based on the ordered list {tilde over (L)}.
The concentration of errors in a receiving message is determined by the detection function of a localized burst error detector. The detection function identifies the localized burst errors based on the absolute differences between cumulative metrics of the ML path and alternative paths.
A symbol Δj denotes the absolute difference between cumulative metrics of the ML path of the message and an alternative path of the message at time instance j. The cumulative metric of an alternative path of the message is denoted as MML+Δj, where MML is the cumulative metric of the ML path of the message.
Let min( . . . ) be a function that identifies the smallest Δj from the list L and Δmin=mink(Δk). The alternative path with the smallest cumulative metric, denoted as MML+Δmin, is identified as the alternative path that has localized burst errors at one or more time instances adjacent to time instance k.
If the EDC decoder 230 detects a CRC error, a signal 208 is sent to a localized burst error detector 240, which has a detection function that finds the localized burst errors and identifies codewords with the highest concentration of localized burst errors. The localized burst error detector 240 performs a series of operations. First, it retrieves the metrics of an ML path and alternative paths of the receiving message from the memory module and generates an ordered list {tilde over (L)}. Second, it uses the information in the ordered list {tilde over (L)} to identify one or more codewords with localized burst errors. Last, it sends the information about the one or more codewords with localized burst errors to the Automatic Repeat and Request module to request the retransmission of the one or more codewords that are corrupted in the previous transmission.
One embodiment of the localized burst error detector 240 in
The localized burst error detector 240 employing the majority vote algorithm computes a total number of elements in the list {tilde over (L)} corresponding to a codeword for all codewords. The codeword that has the most elements in the ordered list {tilde over (L)} is identified as one with localized burst errors. If multiple codewords have the same number of elements in the ordered list {tilde over (L)}, they all are considered as codewords with localized burst errors.
One embodiment of the localized burst error detector 240 employs an algorithm using soft information to assign a weight to each element in the ordered list {tilde over (L)} and summing the weighted values of the elements in the ordered list {tilde over (L)} corresponding to all the codewords. The codeword with the largest value is identified as one with localized burst errors.
A weight assigned to each element in the ordered list {tilde over (L)} can be obtained by the following exemplary probability algorithm. The localized burst error detector 240 calculates a value Q (Q=SNR−Δ
The localized burst error detector 240 employing a probability algorithm described above estimates the probability of errors for each codeword by taking into consideration all the information pertaining to the codeword. For instance, the Qs of all the codewords are summed and the codeword with the highest Q is regarded as the one with localized burst errors.
The method disclosed in the present invention is applicable to trellis code termination using a zero-padding method or a tail-biting method. If a trellis code decoder decodes a codeword with tail-biting termination, the ML path is not identified in its original order. Instead, the front portion of the ML path is identified only after the rest of the ML path is constructed. All the paths, including the ML path and alternative paths, converge at the same state, which is the termination point. This observation does not affect the method disclosed in the present invention because the construction of an ordered list {tilde over (L)} does not depend on how the ML path is constructed.
The method disclosed in the present invention is also applicable to decoders that perform sliding-window decoding or non-sliding window decoding. An ordered list {tilde over (L)} can be constructed as long as the ML path of a message is identified. The ML path is determined either by a single trace-back method or a multiple partial trace-back method.
The above illustration provides many different embodiments or embodiments for implementing different features of the invention. Specific embodiments of components and processes are described to help clarify the invention. These are, of course, merely embodiments and are not intended to limit the invention from that described in the claims.
Although the invention is illustrated and described herein as embodied in one or more specific examples, it is nevertheless not intended to be limited to the details shown, since various modifications and structural changes may be made therein without departing from the spirit of the invention and within the scope and range of equivalents of the claims. Accordingly, it is appropriate that the appended claims be construed broadly and in a manner consistent with the scope of the invention, as set forth in the following claims.
The present application claims the benefit of U.S. Provisional Application Ser. 60/850,991, which was filed on Oct. 11, 2006.
Number | Date | Country | |
---|---|---|---|
60850991 | Oct 2006 | US |