Information
-
Patent Grant
-
5790570
-
Patent Number
5,790,570
-
Date Filed
Friday, August 30, 199628 years ago
-
Date Issued
Tuesday, August 4, 199826 years ago
-
Inventors
-
Original Assignees
-
Examiners
Agents
- Jones, Tullar & Cooper, P.C.
-
CPC
-
US Classifications
Field of Search
US
- 371 374
- 371 431
- 375 261
- 375 262
- 375 265
-
International Classifications
-
Abstract
A concatenated trellis coded modulation and linear block (e.g., Reed-Solomon) encoding scheme splits data to be encoded into two data streams, one of which is both linear block encoded and trellis encoded, and the other of which either remains uncoded or is encoded with a weaker strength linear block code. The coding scheme requires the use of a special decoder which decodes the trellis encoded data first, and then uses the resulting information to decode the non-trellis encoded information. In embodiments using linear block coding for the non-trellis encoded data stream, the relative strengths of the two linear block encoders are selected to balance the resulting code, thereby maximizing coding gain and efficiency.
Description
BACKGROUND OF THE INVENTION
The present invention relates in general to a digital coding method and apparatus employing concatenated trellis coded modulation and linear block codes.
Trellis coded modulation (TCM), sometimes known as convolutional coding, is widely used in many digital communication applications, including deep-space, digital satellite transmission, high speed telephone modems and networks, broadcast networks and recording systems. Linear block codes are well known codes which allow single or multiple error correction.
It is known to employ multiple coding schemes simultaneously to provide desired levels of error rate performance, otherwise known as "coding gain". For example, U.S. Pat. No. 5,258,987 to Wei, issued Nov. 2, 1993, discloses a multilevel coding scheme which uses both TCM and a particular linear block code known as a Reed-Solomon (RS) code. In that scheme, a first portion of the input data stream is trellis encoded, and the resulting encoded stream is used to identify, for each of a succession of symbol intervals, a particular one of a predetermined number of subsets of symbols of a predetermined constellation. The remaining, non-trellis encoded input data is encoded using an RS code whose output is used to select for transmission, a particular symbol from the identified subset.
The coding scheme disclosed in the Wei patent allegedly provides a number of advantages. For example, the patent asserts that the bandwidth efficiency can be made to approach that of a system in which the non-trellis encoded bits are not coded at all; errors due to impulse noise of any magnitude can be corrected; the transmission of data at various different bit rates is easily accommodated; and the multilevel coded symbols selected for transmission can be interleaved in order to provide enhanced immunity to channel input pulse noise and/or correlated noise. However, because Wei's coding scheme only applies the RS code to the non-trellis encoded bits, it cannot significantly improve the code's performance with respect to additive white Gaussian noise.
Other multilevel coding schemes have been proposed which address the additive white Gaussian noise problem. However, these coding schemes tend to impose too high a penalty in coding efficiency and bit rate for the increased noise performance. For example, one known multilevel coding scheme encodes a data stream with an RS encoder, and then divides the stream into two substreams, one of which is trellis encoded as in the scheme disclosed in the Wei patent. These schemes tend to be inefficient, however, because the RS encoding is applied to all bits of the data stream equally, including those which are not to be trellis encoded. For the most part, the non-trellis encoded bits require relatively little encoding, or do not require additional encoding at all. As a result, the bit rate of this coding scheme is unnecessarily reduced.
SUMMARY OF THE INVENTION
The present invention addresses the foregoing problems by providing an improved multilevel digital encoding scheme which combines TCM and linear block codes, such as Reed-Solomon codes. In particular, a method is provided for concatenating TCM with linear block coding in which the reliability of the trellis encoded information (the trellis encoded bits) is improved by being linear block encoded, thereby decreasing the code's sensitivity to additive white Gaussian noise. To eliminate the inefficiency which would occur if the entire data stream were linear block encoded, the linear block encoding is only applied to the portion of the data stream to be trellis encoded. Alternatively, a second linear block encoder can be employed for encoding the non-trellis encoded bits of the data stream, however, its error correcting capability is selected to be lower than that of the first linear block encoder. This improves coding efficiency, but not at the expense of coding gain which is determined almost solely by the trellis encoded bits. Using the two linear block encoders, a balancing of the concatenated coding scheme can be achieved through optimal selection of the error control power for each of the linear block codes.
The foregoing coding scheme therefore provides a higher coding gain than typical concatenation methods, however, this is achieved at a cost of increased latency and memory requirements. In particular, the coding scheme requires use of a unique decoder arrangement for properly recovering the original data stream from the trellis and linear block encoded data stream. The decoder incorporates means whereby the reliability of the trellis encoded data is insured before it is used to decode the non-trellis encoded data, also known as the parallel edge information. This is achieved by estimating what the first linear block encoded data stream was, re-trellis encoding this estimated data stream, and using the resultant re-encoded data stream to determine the identity of the parallel edge information. To minimize the corruption of the parallel edge information obtained in this manner, the trellis encoders in both the encoder circuit and in the decoder circuit are both feedback free to limit the propagation of errors in selecting the parallel edge information due to the subsequent re-encoding of the estimated linear block encoded stream. Since this arrangement minimizes the corruption of the parallel edge information, a weaker linear block code, or no code at all, may be employed for encoding the parallel edge information, thereby substantially increasing overall efficiency of the coding scheme.
BRIEF DESCRIPTION OF THE DRAWINGS
The features and advantages of the present invention will become apparent from the following detailed description of a number of preferred embodiments thereof, taken in conjunction with the accompanying drawings in which:
FIG. 1 is a schematic block diagram of an encoder circuit constructed in accordance with the first preferred embodiment of the present invention;
FIG. 2 is a schematic block diagram of a decoder circuit for use with the encoder circuit of FIG. 1;
FIG. 3 is a schematic block diagram of an encoder circuit constructed in accordance with the second preferred embodiment of the present invention;
FIG. 4 is a schematic block diagram of a decoder circuit for use with the encoder circuit of FIG. 3;
FIG. 5 is a schematic block diagram of a trellis encoder for use with the preferred embodiments of the present invention;
FIG. 6 is a diagram illustrating a two dimensional 64QAM constellation partitioned into four sets of 16 points for use with the trellis encoder of FIG. 5;
FIGS. 7A and 7B are graphs illustrating bit error probability versus Es/No and Shannon limit, respectively, for a 16 state, 4-D code with unbalanced RS coding; and
FIGS. 8A and 8B are graphs illustrating bit error probability versus Es/No and Shannon limit, respectively, for a 16 state, 4-D code which includes balanced RS encoding in accordance with the second preferred embodiment of the present invention.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
Although the method and apparatus of the present invention are substantially different in operation and design from the multilevel coding scheme disclosed in U.S. Pat. No. 5,258,987 to Wei, many of the elements employed in the method and apparatus are similar to those used in the Wei scheme. Accordingly, the Wei patent is hereby incorporated by reference.
An encoder circuit 10 for encoding an incoming digital data stream 12 in accordance with a first preferred embodiment of the present invention which embodies the invention in its broadest sense, is illustrated in FIG. 1. The incoming data stream 12 is fed into a parser 14 which separates it into a trellis data stream m.sub.1, and a non-trellis data stream m.sub.2. The non-trellis data stream m.sub.2 is fed unaltered into a point selector input 16 of a conventional QAM constellation mapper 18, which may be of the type disclosed in the Wei patent, for example. The m.sub.2 data stream, known as the parallel edge information, is employed to designate a multiple bit label for each point of each cell in the QAM map (to be discussed in greater detail in conjunction with FIG. 6). These bits correspond to the most significant bits of the resulting code words, and are the least sensitive to errors. Thus, it is not typically necessary to encode the parallel edge information, or if encoding is employed, it can be of relatively weak strength.
The trellis data stream m.sub.1 is so named because it is the data stream which will ultimately be trellis encoded. However, to increase the additive white Gaussian noise performance of the code, m.sub.1 is first fed to a linear block encoder 20. The linear block encoder 20 can use any conventional linear block code to encode m.sub.1, but preferably is a Reed-Solomon (RS) encoder. The linear block encoder 20 generates a linear block encoded data stream C.sub.1, which is next encoded by any suitable trellis encoder 22, such as a binary convolutional encoder (BCC). The trellis encoder 22 generates a concatenated TCM/linear block encoded data stream b, which is input to a cell selector input 24 of the QAM mapper 18. The data stream b is therefore employed to designate the least significant bits of each code word generated by the QAM mapper 18, which are the most sensitive to noise induced errors, and thus benefit the most from multiple level coding. The QAM mapper 18 combines the point and cell selector information to form a QAM output signal 26 for transmission through any suitable type of communication channel.
FIG. 2 illustrates a decoder circuit 50 for decoding the QAM signals generated by the encoder 10 of FIG. 1. A channel output 52 feeds an incoming QAM signal to a receiver/pruner 54 which demodulates the signal, and performs an initial analysis to determine the content of the signal. The demodulated signal is comprised of a plurality of QAM symbols, each of which represents a point in the QAM constellation. The QAM constellation is defined by 2.sup.n cells, where n equals the number of bits in each trellis encoded code word, and M labels for each point within each cell, where typically M=2.sup.p, and p equals the number of bits in each unencoded data word or symbol in m.sub.2. The receiver/pruner 54 identifies a point for each of the 2.sup.n cells which represents the most likely point within each cell that is identified by the detected QAM symbol. This subset of all possible points is then passed through a line 55 first to a delay circuit 56, and then to a selector circuit 57 for further analysis as discussed below.
The receiver/pruner 54 also transmits the cell identification information through a line 58 to a sequence estimator 59. Using a conventional algorithm, such as Viterbi algorithm, the sequence estimator 59 determines the most likely one of the 2.sup.n cells which was transmitted, and thereby reconstructs an estimation C.sub.1 of the linear block encoded data stream C.sub.1. C.sub.1 is then fed to a linear block decoder 60 which detects and corrects errors in the detected encoded data stream C.sub.1, thereby forming a corrected encoded data stream C.sub.1. In the best case scenario, C.sub.1 is identical to C.sub.1 as generated by the linear block encoder 20 of FIG. 1.
C.sub.1 is fed both to a second trellis encoder 62, as well as to a linear block uncoder 64. The output b of the trellis encoder 62, is ideally the same as the output b of the first trellis encoder 22 in the encoder circuit 10. This is employed by the selector circuit 57 to determine which of the 2.sup.n cells that the sequence estimator 59 has decided was identified by the QAM symbol. The delay circuit 56 is necessary to allow the sequence estimator 59, linear block decoder 60 and trellis encoder 62 time to make this determination. Using this information, the selector circuit 57 then decides which of the points in the subset generated by the receiver/pruner 54 is correct, thereby generating the detected non-trellis data stream m.sub.2. The detected trellis data stream, m.sub.1, is generated by the linear block uncoder 64 which converts C.sub.1 to m.sub.1, typically by striping the parity bits. Finally, m.sub.1 and m.sub.2 are combined in a combiner 66 to generate the detected output data stream 68.
The block structure of an encoder circuit 100 constructed in accordance with a second preferred embodiment of the invention is illustrated in FIG. 3. This is a more specific embodiment of the present invention which employs (extended) Reed-Solomon (RS) encoders, interleavers and FIFOs as discussed below. As in the first embodiment, the incoming data 101 is fed through a parser 102 which separates the data into a first 8 bit parallel data stream m.sub.1 to be trellis encoded, and a second 8 bit parallel data stream m.sub.2 which is not to be trellis encoded (the parallel edge information). The first data stream m.sub.1 is fed through a first RS encoder 104 which is selected to have 8 bit error correcting capability (t=8), thus requiring 2t=16 parity bits, so that for every k=240 message bits, n=256 encoded bits are generated. A first interleaver 106 receives the RS encoded data, C.sub.1, from the first RS encoder 104, and is provided to mitigate the effects of the burst errors due to the sequence estimation decoder for the TCM. The output (C.sub.1) of the first interleaver 106 is fed through a 16:3 FIFO 107 which delivers 3 bits of data for every 16 bits of data fed from the interleaver 106 into a rate 3/4 trellis encoder 108, such as a binary convolutional encoder (BCC). The 4 bit parallel output b of the trellis encoder 108 is fed to a cell selector input 109 of a conventional QAM mapper 110.
In contrast to the first embodiment, the "uncoded" parallel edge information bits of the trellis code, labelled m.sub.2, are directed to a second RS encoder 112 to form an 8 bit parallel encoded data stream C.sub.2. In this particular embodiment, the second RS encoder 112 is selected to have only a 2 bit error correcting capability (t=2), with k=252 and n=256 since the parallel edge information is not as error sensitive as the trellis encoded information. C.sub.2 is fed through a second interleaver 114, and the interleaved data, (C.sub.2), is fed through a 2:1 FIFO 115 to a point selector input 116 of the QAM mapper 110, which combines this data with the cell selector data to generate a QAM signal that is applied to a communication channel input 117.
To control each of the elements in the encoder circuit 100, a plurality of different clock rates is required. For example, the output of the 16:3 FIFO 107, trellis encoder 108 and output of the 2:1 FIFO 115 must all be clocked at the same period T, the symbol period for the QAM mapper 110. To properly clock the input to the 16:3 FIFO 107, a clock period of 16T/3 is employed to clock the output of the first RS encoder 104, the first interleaver 106 and the input to the 16:3 FIFO 107. Similarly, a clock period of 2T is required to clock the output of the second RS encoder 112, the second interleaver 114 and the input to the 2:1 FIFO 115. Finally, the input to the first RS encoder 104 must be clocked with a period of 256T/45, while the input of the second RS encoder 112 must be clocked with a period of 128T/63, to accommodate the somewhat slower input data rates to the two encoders 104 and 112.
A decoder circuit 150 to be employed with the encoder circuit 100 of FIG. 3 is illustrated in FIG. 4. The decoder circuit 150 operates in the same manner as the decoder cicuit 50 of FIG. 2, and includes many of the same elements. In particular, the QAM signal is fed through a channel output 152 to a receiver/pruner 154. The receiver/pruner 154 generates outputs to a delay/selector 156 for generating (C.sub.2), and a sequence estimator 158 for generating (C.sub.1). First and second deinterleavers 160 and 162 are provided for converting (C.sub.1) and (C.sub.2) into C.sub.1 and C.sub.2, respectively.
C.sub.1 is converted to C.sub.1 by an RS decoder 164, and then C.sub.1 is converted to m.sub.1 by an RS uncoder 166. C.sub.1 is also employed to generate b, which is used by the delay/selector 156 to determine (C.sub.2). Another interleaver 168 converts C.sub.1 to (C.sub.1), while a second trellis encoder 170 converts (C.sub.1) into b. A second RS decoder 172 is employed to convert C.sub.2 to C.sub.2, while a second RS uncoder 174 is employed to convert C.sub.2 to m.sub.2. Finally, m.sub.1 and m.sub.2 are combined in a combiner 176 to generate a detected output data stream 178. Although not illustrated in FIG. 4, it will be understood that a clocking scheme similar to that illustrated in FIG. 3 for the encoder circuit 100 is also required for the various elements of the decoder circuit 150.
In both of the foregoing embodiments of the present invention, it is important that the trellis encoders be feedback free to limit the propagation of errors in selecting parallel edge information due to the subsequent re-encoding of the more reliable estimate of C.sub.1 which is obtained from the linear block or RS decoders. Otherwise, an error in the C.sub.1 estimate could result in a large error in the estimate of b. Thus, using feedback free trellis encoders minimizes the corruption of the parallel edge information by the first decoding process, which allows for the use of either a weaker linear block or RS code for m.sub.2 as in the second embodiment, or no code at all as in the first embodiment.
FIG. 5 illustrates an example of the feedback free trellis encoder 200 which may be employed in either embodiment of the present invention, although it is specifically designed for use with the second embodiment. The trellis encoder 200 is based on a design disclosed in the text book by Shu Lin and Daniel J. Costello, Jr., entitled "Error Control Coding: Fundamentals and Applications," Prentice-Hall, Engelwood Cliffs, N.J., 1983. The trellis encoder 200 receives bits from the 16:3 FIFO 107 on three input lines 202. These are converted to four cell selector outputs labelled b.sub.1.sup.0, b.sub.2.sup.0, b.sub.1.sup.1, and b.sub.2.sup.1. The bits on the input lines 202 are combined using a plurality of XOR function elements 204 and a plurality of shift register delay elements 206 to obtain the cell selector outputs. The transfer function embodied by the particular interconnection scheme for each of the inputs 202, XOR elements 204 and shift register delay elements 206 is represented in octal form by the transfer function matrix G illustrated in FIG. 5.
FIG. 6 illustrates a two dimensional 64QAM constellation which can be employed by the QAM mapper 110 with the trellis encoder 200 illustrated in FIG. 5. The constellation is comprised of 64 points 250 which are divided into four sets of 16 points, wherein each of these sets is a cell that is selected by one pair of b values from the trellis encoder 200. For example, the cell (1,0) is comprised of the circled plurality of points 252 in FIG. 6. A four bit label (not shown) is assigned to each point of each cell, and these labels are derived from the parallel edge information arriving from the 2:1 FIFO 115 on the point selector input 116 (see FIG. 3).
It should be noted that because the QAM constellation in FIG. 6 is two dimensional, and the trellis code generated by the trellis encoder is four dimensional, two QAM symbols are generated for each trellis symbol. Thus, the number of bits per trellis symbol is twice as many as the number of bits per QAM symbol. Returning to FIG. 3, the numbers adjacent the cell selector and point selector inputs 109 and 116, respectively, indicate the number of bits per QAM symbol and per trellis symbol, with the number of bits per trellis symbol being illustrated in parentheses.
One advantage of the second embodiment of the present invention is that the use of the two RS encoders 104 and 112 facilitates balancing or optimization of the system's overall coding gain. In particular, the relative coding strengths of each of the encoders 104 and 112 can be selected so that the best gain is achieved without unnecessary reductions in transmission rates. For example, much weaker coding of the parallel edge information m.sub.2 can be employed in this embodiment. To illustrate, consider the selection of RS codes for an embodiment employing RS encoders and a 16 state, 4-D BCC based trellis code. The graphs in FIGS. 7A, 7B, 8A and 8B illustrate how the selection of the RS codes for the first and second RS encoders should be made. In each case, feedback free, 16 state, 4 dimensional BCC based trellis code with coding rate 3/4 is used. This code uses the 16-way Ungerboeck partition in 4D. This code is similar to the Wei 16-state code used in the ITU V.34 standard, with the exception that the encoder is feedback free, is expressed as a rate 3/4 code with a "1 bit parallel edge", and uses a different code generator G as in FIG. 5. The constellation in each case is 64QAM (as in the ITU J.83 standard). Both cases use a t.sub.1 =8 (extended) RS (n=256 over GF256) code for the first RS code. In the first case, which demonstrates the effect of unbalanced coding, a t.sub.2 =1 RS code is used for the second RS code. The second, balanced case uses a t.sub.2 =2 RS code for the second RS code. For each case, there are 6 curves shown on two measures of signal to noise ratio (SNR). The first measure is the channel SNR and the second is a normalized SNR relative to the Shannon capacity (which sits at 0 dB).
In all of the graphs, the top curve is the uncoded 64QAM curve. The curve with the circles shows the code performance with TCM only. The dashed curve, marked with (*), shows the error probability of the trellis information bits (m.sub.1) with RS 1. The dotted curve, marked with "+", shows the error probability of (m.sub.2) given the trellis information is decoded perfectly (b=b) with RS 2. The unmarked solid curve shows the error probability for the entire system. The solid curve marked with "X" shows the effect of using a t=8 RS code for all of the information bits. (This is the same as using a t.sub.1 =t.sub.2 =8 RS code for each of the RS codes. It operates at a rate of R=5.5*15/16=5.156 bits per symbol.) In the unbalanced case illustrated in FIGS. 7A and 7B, with respect to the Es/No scale, the performance of encoding all of the bits using a t=8 RS code appears to be the best (@10.sup.-9) by about 0.1 dB relative to the trellis information, and by about 0.9 dB relative to the parallel edge information. This larger difference of 0.9 dB is due to the probability of error being dominated by the errors occurring in the parallel edge information, and is not due to incorrect decoding of the trellis information. As this system operates at a rate of R =1.5*15/16+4*127/128=5.375 bits per symbol, on the scale normalized by rate, it can be seen that the coding gain of the typical system (w.r.t. Shannon) is better by about 0.25 dB. This is attributed to the insufficiency of the t.sub.2 =1 RS code on the parallel edge information.
The second case illustrated in FIGS. 8A and 8B shows the improvement when balance is achieved. By increasing the error correction on the parallel edge information to t.sub.2 =2, the errors in decoding the parallel edge information are no longer dominated by the weakness of the RS code, and are primarily due to errors in decoding the trellis information. Thus, while the case using a single encoder appears to be better (@10.sup.-9) on the Es/No scale by 0.15 dB, when the systems are normalized by their respective rates, the balanced concatenated scheme, which operates at a rate of R=1.5*15/16+4*63/64=5.34 bits per symbol, is over 0.5 dB better. It is also clear, from this analysis, that for a desired error rate of 10.sup.-9, increasing the error correction capability of the second RS code beyond t.sub.2 =2 would be a waste of redundancy, since no apparent improvement in reliability would be achieved at a cost of loss in data rate.
It should be noted that although the invention has been disclosed as being implementing with discrete functional elements, including encoders, interleavers, mappers, etc., these elements need not be discrete components, and the functions of them can be carried out with an appropriately programmed digital signal processor(s) or the like.
Although the present invention has been disclosed in terms of a number of preferred embodiments and variations thereof, it will be understood that numerous additional variations and modifications could be made thereto without departing from the scope of the invention as defined by the following claims.
Claims
- 1. A method for encoding digital data comprising the steps of:
- a) providing a digital data stream to be encoded;
- b) separating said digital data stream into first and second uncoded data streams;
- c) linear block encoding said first uncoded data stream to form a first linear block encoded data stream;
- d) trellis encoding said first linear block encoded data stream to form a concatenated trellis and linear block encoded data stream; and
- e) applying said second uncoded data stream and said concatenated trellis encoded and linear block encoded data stream to a mapper means for forming an encoded output signal.
- 2. The method of claim 1, wherein said step of linear block encoding said first uncoded data stream further comprises encoding said first uncoded data stream with a Reed-Solomon code.
- 3. The method of claim 2, wherein the step of trellis encoding said linear block encoded data stream further comprises encoding said linear block encoded data stream with a binary convolutional code.
- 4. The method of claim 1, wherein the step of trellis encoding said linear block encoded data stream further comprises encoding said linear block encoded data stream with a binary convolutional code.
- 5. The method of claim 1, further comprising the step of:
- f) linear block encoding said second uncoded data stream to form a second linear block encoded data stream which is then applied to said mapper means.
- 6. The method of claim 5, wherein said first and second uncoded data streams are linear block encoded with first and second linear block codes, respectively, having different coding strengths with said first linear block code having a first coding strength which is greater than a second coding strength of said second linear block code.
- 7. The method of claim 6, wherein said first and second coding strengths are selected to balance the error rates in said concatenated trellis and linear block encoded data stream, and in said second linear block encoded data stream.
- 8. The method of claim 7, wherein said trellis encoding is performed in a feedback free manner.
- 9. The method of claim 7, wherein said steps of linear block encoding said first and second uncoded data streams further comprise encoding said first and second uncoded data streams with first and second Reed-Solomon codes, respectively.
- 10. The method of claim 9, wherein said trellis encoding is performed in a feedback free manner.
- 11. The method of claim 1, wherein said trellis encoding is performed in a feedback free manner.
- 12. The method of claim 1, wherein said step of applying said second uncoded data stream and said concatenated trellis encoded and linear block encoded data stream to a mapper means further comprises employing said second uncoded data stream as a point selector input to a QAM mapper means, and employing said concatenated trellis encoded and linear block encoded data stream as a cell selector input to said QAM mapper means.
- 13. The method of claim 1, further comprising the step of interleaving said first linear block encoded data stream before trellis encoding said first linear block encoded data stream.
- 14. The method of claim 5, further comprising the steps of interleaving said first linear block encoded data stream before trellis encoding said first linear block encoded data stream, and interleaving said second linear block encoded data stream before applying said second linear block encoded data stream to said mapper means.
- 15. The method of claim 1, further comprising the steps of:
- f) applying said encoded output signal to an input of a communication channel, thereby forming an encoded channel output signal on an output of said communication channel;
- g) receiving said encoded channel output signal;
- h) generating an estimation of said first linear block encoded data stream from said received encoded output signal;
- i) detecting and correcting errors in said estimation to form a corrected estimation of said first linear block encoded data stream;
- j) uncoding said corrected estimation of said first linear block encoded data stream to form a detected version of said first uncoded data stream;
- k) trellis encoding said corrected estimation of said first linear block encoded data stream to form an estimation of said concatenated trellis and linear block encoded data stream;
- l) employing said received encoded output signal and said estimation of said concatenated trellis and linear block encoded data stream to generate a detected version of said second uncoded data stream; and
- m) combining said detected versions of said first and second uncoded data streams to form a detected output data stream.
- 16. The method of claim 15, wherein said step of generating an estimation of said first linear block encoded data stream is carried out using a Viterbi algorithm.
- 17. The method of claim 15, wherein said trellis encoding is performed in a feedback free manner.
- 18. The method of claim 5, further comprising the steps of:
- g) applying said encoded output signal to an input of a communication channel thereby forming an encoded channel output signal on an output of said communication channel;
- h) receiving said encoded channel output signal;
- i) generating an estimation of said first linear block encoded data stream from said received encoded output signal;
- j) detecting and correcting errors in said estimation to form a corrected estimation of said first linear block encoded data stream;
- k) uncoding said corrected estimation to form a detected version of said first uncoded data stream;
- l) trellis encoding said corrected estimation of said first linear block encoded data stream to form an estimation of said concatenated trellis and linear block encoded data stream;
- m) employing said received encoded output signal and said estimation of said concatenated trellis and linear block encoded data stream to generate a detected version of said second linear block encoded data stream;
- n) detecting and correcting errors in said received second linear block encoded data stream to form a corrected estimation of said second linear block encoded data stream;
- o) uncoding said corrected estimation of said second linear block encoded data stream to form a detected version of said second uncoded data stream; and
- p) combining said detected versions of said first and second uncoded data streams to form a detected output data stream.
- 19. The method of claim 18, wherein said trellis encoding is performed in a feedback free manner.
- 20. The method of claim 15, further comprising the steps of interleaving said first linear block encoded data stream before trellis encoding said first linear block encoded data stream;
- deinterleaving said estimation of said first linear block encoded data stream before detecting and correcting errors in said estimation; and
- interleaving said corrected estimation of said linear block encoded data stream before trellis encoding said corrected estimation of said first linear block encoded data stream.
- 21. A method for decoding a received digital signal which has been both trellis and linear block encoded, said method comprising the steps of:
- a) generating an estimation of a first linear block encoded data stream from said received encoded signal;
- b) detecting and correcting errors in said estimation to form a corrected estimation of said first linear block encoded data stream;
- c) uncoding said corrected estimation of said first linear block encoded data stream to form a detected version of a first uncoded data stream;
- d) trellis encoding said corrected estimation of said first linear block encoded data stream to form an estimation of a concatenated trellis and linear block encoded data stream;
- e) employing said received encoded signal and said estimation of said concatenated trellis and linear block encoded data stream to generate a detected version of a second uncoded data stream; and
- f) combining said detected versions of said first and second uncoded data streams to form a detected output data stream.
- 22. Apparatus for encoding digital data comprising:
- a) means for separating a digital data stream to be encoded into first and second uncoded data streams;
- b) a first linear block encoding means for receiving said first uncoded data stream and forming a first linear block encoded data stream;
- c) trellis encoding means for receiving said first linear block encoded data stream and forming a concatenated trellis and linear block encoded data stream; and
- d) mapper means for receiving said second uncoded data stream and said concatenated trellis encoded and linear block encoded data stream and forming an encoded output signal.
- 23. The apparatus of claim 22, wherein said linear block encoding means further comprises a Reed-Solomon encoding means.
- 24. The apparatus of claim 23, wherein said trellis encoding means further comprises a binary convolutional encoding means.
- 25. The apparatus of claim 22, further comprising:
- e) a second linear block encoding means for receiving said second uncoded data stream and forming a second linear block encoded data stream which is received by said mapper means.
- 26. The apparatus of claim 25, wherein said first and second linear block encoder means are selected to have first and second coding strengths, respectively, with said first coding strength being greater than said second coding strength.
- 27. The apparatus of claim 26, wherein said first and second coding strengths are selected to balance the error rates in said concatenated trellis and linear block encoded data stream, and in said second linear block encoded data stream.
- 28. The apparatus of claim 27, wherein said trellis encoding means is feedback free.
- 29. The apparatus of claim 27, wherein said first and second linear block encoding means further comprise first and second Reed-Solomon encoding means.
- 30. The apparatus of claim 29, wherein said trellis encoding means is feedback free.
- 31. The apparatus of claim 22, wherein said trellis encoding means is feedback free.
- 32. The apparatus of claim 22, wherein said mapper means comprises a QAM mapper having a point selector input receiving said second uncoded data stream, and a cell selector input receiving said concatenated trellis encoded and linear block encoded data stream.
- 33. The apparatus of claim 22, further including:
- e) interleaving means disposed between said first linear block encoding means and said trellis encoding means for interleaving said first linear block encoded data stream.
- 34. The apparatus of claim 25, further comprising:
- f) a first interleaving means disposed between said first linear block encoding means and said trellis encoding means for interleaving said first linear block encoded data stream; and
- g) a second interleaving means disposed between said second linear block encoding means and said mapper means for interleaving said second linear block encoded data stream.
- 35. The apparatus of claim 22 further comprising:
- e) a communication channel having an input for receiving said encoded output signal, and an output for generating an encoded channel output signal;
- f) means for receiving said encoded channel output signal;
- g) means for generating an estimation of said first linear block encoded data stream from said received encoder output signal;
- h) means for detecting and correcting errors in said estimation to form a corrected estimation of said first linear block encoded data stream;
- i) means for uncoding said corrected estimation of said first linear block encoded data stream to form a detected version of said first uncoded data stream;
- j) second trellis encoding means for trellis encoding said corrected estimation of said first linear block encoded data stream to form an estimation of said concatenated trellis and linear block encoded data stream;
- k) means responsive to said received encoded output signal and said estimation of said concatenated trellis and linear block encoded data stream for generating a detected version of said second uncoded data stream; and
- l) means for combining said detected versions of said first and second uncoded data streams to form a detected output data stream.
- 36. The apparatus of claim 35, wherein said means for generating an estimation of said first linear block encoded data stream comprises a sequence estimator.
- 37. The apparatus of claim 36, wherein said sequence estimator employs a Viterbi algorithm to generate said estimation of said first linear block encoded data stream.
- 38. The apparatus of claim 35, wherein said trellis encoding means is feedback free.
US Referenced Citations (3)