US 6690739 B1 Abstract The intersymbol interference compensation (ISIC) method of the invention comprises an encoding step performed by an encoder and a data estimating step performed a data estimator. The encoder performs at least a trellis encoding of a data sequence using a trellis forward-error-correction (FEC) code to provide an encoded sequence, which is supplied to a channel. The data estimator, which advantageously processes a channel output sequence to arrive at an estimate of the data sequence, comprises at least a template generator for generating templates, a partial equalizer for processing the channel output sequence to provide a partially equalized sequence that is substantially free of precursor ISI, and an ISIC decoder for trellis decoding and ISI compensation. The ISIC decoder computes the branch metric for each current branch based on a single-sided template {circumflex over (q)}(x,y) that accounts for the postcursor ISI in the partially equalized sequence, where x is the vector of symbols associated with the past branch or branches that are connected to the current branch and y is the vector of symbols associated with the current branch. The number of states in the ISIC decoder is determined by the trellis code and is independent of the ISI span of the channel. The invention also provides for techniques for adapting the partial equalizer using the templates, estimating the ISI profile, and updating the templates. In one embodiment of the invention, concatenated coding is employed. In yet another embodiment of the invention, the data estimator employs a decision-directed-ISIC (DD-ISIC) decoder that computes the branch metric for each current branch based on a double-sided template ŝ(x,y,z), where z is the vector of symbols associated with the future branch or branches connected to the current branch and is determined by an interim estimate of the data sequence. A double-sided partial equalizer that removes only some of the precursor and postcursor ISI provides the input to the DD-ISIC decoder, which compensates for the unequalized ISI and performs trellis decoding simultaneously.
Claims(28) 1. A method of intersymbol interference compensation (ISIC) for preparing a plurality of data symbols for use as input to a channel and recovering said plurality of data symbols from a plurality of channel output samples for use by a data sink, said method comprising the steps of
encoding said plurality of data symbols to provide encoded symbols for use as input to said channel, said step of encoding further including the steps of
(a) trellis encoding said plurality of data symbols using a trellis code to provide trellis-encoded symbols; and
(b) mapping said trellis-encoded symbols to provide said encoded symbols such that said encoded symbols assume values from a predetermined alphabet; and
performing data recovery on said plurality of channel output samples to provide estimated data symbols for use by said data sink, said step of performing data recovery further including the steps of
(a) partially equalizing said plurality of channel output samples to provide partially equalized samples using a partial equalizer, thereby equalizing substantially all of the precursor intersymbol interference (ISI) and at most some of the postcursor ISI in said plurality of channel output samples;
(b) generating a set of single-sided templates based on a noiseless channel model having a truncated ISI profile, wherein each single-sided template {circumflex over (q)}(•,•) is a function of two vector arguments having elements taken from said predetermined alphabet; and
(c) ISIC decoding said partially equalized samples to provide said estimated data symbols, said step of ISIC decoding further including the step of computing a branch metric for each current branch of a decoder trellis of said trellis code based on the partially equalized samples associated with said current branch and the single-sided template {circumflex over (q)}(x,y) with vector argument x being the vector of a predetermined number of symbols associated with the past branches connected to said current branch and vector argument y being the vector of symbols associated with said current branch; and the step of using said branch metric in a trellis decoding algorithm.
2. A method as recited in
3. A method as recited in
4. A method as recited in
5. A method as recited in
6. A method as recited in
7. A method as recited in
calculating a first error signal by subtracting the current one of said partially equalized samples from the single-sided template {circumflex over (q)}(a,b) with vector argument b being an estimate of current one of said encoded symbols and vector argument a being an estimate of said predetermined number of ones of said encoded symbols preceding said current one of said encoded symbols; and
applying said first error signal to a first adaptive algorithm to adjust said partial equalizer such that said first error signal is reduced.
8. A method as recited in
inserting training symbols into said encoded symbols; and
using said training symbols to determine the vector arguments a and b employed in said step of calculating a first error signal.
9. A method as recited in
re-encoding said estimated data symbols using said trellis code to provide re-encoded symbols; and
using said re-encoded symbols to determine the vector arguments a and b employed in said step of calculating a first error signal.
10. A method as recited in
applying said fully equalized samples to a slicer to provide slicer-estimated symbols; and
using said slicer-estimated symbols to determine the vector arguments a and b employed in said step of calculating a first error signal.
11. A method as recited in
estimating an ISI profile using an estimator comprising the steps of
(a) multiplying a plurality of estimator input symbols by the estimator tap weights of said estimator to provide products;
(b) summing said products to provide an estimated channel output sample;
(c) subtracting said estimated channel output sample from the current one of said plurality of channel output samples to provide a second error signal;
(d) applying said second error signal to a second adaptive algorithm to provide updated estimator tap weights such that said second error signal is reduced; and
(e) replacing the estimator tap weights with said updated estimator tap weights; and
updating the single-sided templates comprising the steps of
(a) truncating said updated estimator tap weights to provide an updated-truncated ISI profile such that said updated-truncated ISI profile contains substantially zero precursor ISI and up to L non-zero postcursor ISI components with L being the length of said vector argument x;
(b) replacing said truncated ISI profile with said updated-truncated ISI profile; and
(c) using said updated-truncated ISI profile to update the single-sided templates.
12. A method as recited in
inserting training symbols into said encoded symbols; and
using said training symbols as said plurality of estimator input symbols.
13. A method as recited in
re-encoding said estimated data symbols using said trellis code to provide re-encoded symbols; and
using said re-encoded symbols as said plurality of estimator input symbols.
14. A method as recited in
fully equalizing said plurality of channel output samples to provide fully equalized samples using a full equalizer, thereby equalizing substantially all of the precursor and postcursor ISI in said plurality of channel output samples;
applying said fully equalized samples to a slicer to provide slicer-estimated symbols; and
using said slicer-estimated symbols as said plurality of estimator input symbols.
15. A method as recited in
16. A method of intersymbol interference compensation for preparing a plurality of data symbols for use as input to a channel and recovering said plurality of data symbols from a plurality of channel output samples for use by a data sink, said method comprising the steps of
encoding said plurality of data symbols to provide encoded symbols for use as input to said channel, said step of encoding further including the steps of
(a) trellis encoding said plurality of data symbols using a trellis code to provide trellis-encoded symbols; and
(b) mapping said trellis-encoded symbols to provide said encoded symbols such that said encoded symbols assume values from a predetermined alphabet; and
performing data recovery on said plurality of channel output samples to provide estimated data symbols for use by said data sink, said step of performing data recovery further including the steps of
(a) partially equalizing said plurality of channel output samples to provide partially equalized samples using a partial equalizer, thereby equalizing substantially all of the precursor ISI and at most some of the postcursor ISI in said plurality of channel output samples;
(b) generating a set of single-sided templates based on a first noiseless channel model having a first truncated ISI profile, wherein each single-sided template {circumflex over (q)}(•,•) is a function of two vector arguments having elements taken from said predetermined alphabet;
(c) ISIC decoding said partially equalized samples to provide interim data decisions, said step of ISIC decoding further including the step of computing a first branch metric for each first current branch of a first decoder trellis of said trellis code based on the partially equalized samples associated with said first current branch and the single-sided template {circumflex over (q)}(x
_{1},y_{1}) with vector argument x_{1 }being the vector of a first predetermined number of symbols associated with the past branches connected to said first current branch and vector argument y_{1 }being the vector of symbols associated with said first current branch; and the step of using said first branch metric in a first trellis decoding algorithm; (d) applying double-sided partial equalization to said plurality of channel output samples to provide double-sided partially equalized samples using a double-sided partial equalizer, thereby equalizing at most some of the precursor and postcursor ISI in said plurality of channel output samples;
(e) generating a set of double-sided templates based on a second noiseless channel model having a second truncated ISI profile, wherein each double-sided template ŝ(•,•,•) is a function of three vector arguments having elements taken from said predetermined alphabet; and
(f) decision-directed-ISIC decoding said double-sided partially equalized samples to provide said estimated data symbols, said step of decision-directed-ISIC decoding further including the step of computing a second branch metric for each second current branch of a second decoder trellis of said trellis code based on the double-sided partially equalized samples associated with said second current branch and the double-sided template ŝ(x
_{2},y_{2},z_{2}) with vector argument x_{2 }being the vector of a second predetermined number of symbols associated with the past branches connected to said second current branch and vector argument y_{2 }being the vector of symbols associated with said second current branch and vector argument z_{2 }being the vector of a third predetermined number of symbols determined using said interim data decisions to be associated with the future branches connected to said second current branch; and the step of using said second branch metric in a second trellis decoding algorithm. 17. A method as recited in
_{1},y_{1})is equal to the output of said first noiseless channel model in response to applying vector argument y_{1 }to said first noiseless channel model preceded by vector argument x_{1}, wherein said first truncated ISI profile has substantially zero precursor ISI and up to L_{1 }non-zero postcursor ISI components with L_{1 }being the length of said vector argument x, wherein the double-sided template ŝ(x_{2},y_{2},z_{2}) is equal to the output of said second noiseless channel model in response to applying vector argument y_{2 }to said second noiseless channel model preceded by vector argument x_{2 }and followed by vector argument z_{2}, and wherein said second truncated ISI profile has up to L_{2 }predetermined number of non-zero postcursor ISI components and up to L_{3 }non-zero precursor ISI components with L_{2 }being the length of said vector argument x_{2 }and L_{3 }being the length of said vector argument Z_{2}.18. A method as recited in
19. A method as recited in
20. A method as recited in
updating said partial equalizer including the steps of
(a) calculating a first error signal by subtracting the current one of said partially equalized samples from the single-sided template {circumflex over (q)}(a
_{1},b_{1}) with vector argument b_{1 }being an estimate of current one of said encoded symbols and vector argument a_{1 }being an estimate of said first predetermined number of ones of said encoded symbols preceding said current one of said encoded symbols; and (b) applying said first error signal to a first adaptive algorithm to adjust said partial equalizer such that said first error signal is reduced; and
updating said double-sided partial equalizer including the steps of
(a) calculating a second error signal by subtracting the current one of said double-sided partially equalized samples from the double-sided template ŝ(a
_{2},b_{2},c_{2}) with vector argument b_{2 }being an estimate of current one of said encoded symbols and vector argument a_{2 }being an estimate of said second predetermined number of ones of said encoded symbols preceding said current one of said encoded symbols and vector argument c_{2 }being an estimate of said third predetermined number of ones of said encoded symbols following said current one of said encoded symbols; and (b) applying said second error signal to a second adaptive algorithm to adjust said double-sided equalizer such that said second error signal is reduced.
21. A method as recited in
estimating an ISI profile using an estimator comprising the steps of
(a) multiplying a plurality of estimator input symbols by the estimator tap weights of said estimator to provide products;
(b) summing said products to provide an estimated channel output sample;
(c) subtracting said estimated channel output sample from the current one of said plurality of channel output samples to provide a third error signal;
(d) applying said third error signal to a third adaptive algorithm to provide updated estimator tap weights such that said third error signal is reduced; and
(e) replacing the estimator tap weights with said updated estimator tap weights; and
updating the single-sided templates comprising the steps of
(a) truncating said updated estimator tap weights to provide a first updated-truncated ISI profile such that said first updated-truncated ISI profile contains substantially zero precursor ISI and up to L
_{1 }non-zero postcursor ISI components with L_{1 }being the length of said vector argument x. (b) replacing said first truncated ISI profile with said first updated-truncated ISI profile; and
(c) using said first updated-truncated ISI profile to update the single-sided templates; and
updating the double-sided templates comprising the steps of
(a) truncating said updated estimator tap weights to provide a second updated-truncated ISI profile such that said second updated-truncated ISI profile contains up to L
_{2 }non-zero postcursor ISI components and up to L_{3 }non-zero precursor ISI components with L_{2 }being the length of said vector argument x_{2 }and L_{3 }being the length of said vector argument Z_{2}. (b) replacing said second truncated ISI profile with said second updated-truncated ISI profile; and
(c) using said second updated-truncated ISI profile to update the double-sided templates.
22. A method of intersymbol interference compensation for preparing a plurality of data symbols for use as input to a channel and recovering said plurality of data symbols from a plurality of channel output samples for use by a data sink, said method comprising the steps of
encoding said plurality of data symbols to provide encoded symbols for use as input to said channel, said step of encoding further including the steps of
(a) outer-FEC encoding said plurality of data symbols using an outer FEC code to provide outer-FEC-encoded symbols;
(b) interleaving said outer-FEC-encoded symbols to provide interleaved symbols;
(c) trellis encoding said interleaved symbols using a trellis code to provide trellis-encoded symbols; and
(d) mapping said trellis-encoded symbols to provide said encoded symbols such that said encoded symbols assume values from a predetermined alphabet; and
performing data recovery on said plurality of channel output samples to provide estimated data symbols for use by said data sink, said step of performing data recovery further including the steps of
(a) partially equalizing said plurality of channel output samples to provide partially equalized samples using a partial equalizer, thereby equalizing substantially all of the precursor ISI and at most some of the postcursor ISI in said plurality of channel output samples;
(b) generating a set of single-sided templates based on a first noiseless channel model having a first truncated ISI profile, wherein each single-sided template {circumflex over (q)}(•,•) is a function of two vector arguments having elements taken from said predetermined alphabet;
(c) ISIC decoding said partially equalized samples to provide ISIC-decoded symbols, said step of ISIC decoding further including the step of computing a first branch metric for each first current branch of a first decoder trellis of said trellis code based on the partially equalized samples associated with said first current branch and the single-sided template {circumflex over (q)}(x
_{1},y_{1}) with vector argument x_{1 }being the vector of a first predetermined number symbols associated with the past branches connected to said first current branch and vector argument y_{1 }being the vector of symbols associated with said first current branch; and the step of using said first branch metric in a first trellis decoding algorithm; (d) processing said ISIC-decoded symbols to provide interim data decisions;
(e) applying double-sided partial equalization to said plurality of channel output samples to provide double-sided partially equalized samples using a double-sided partial equalizer, thereby equalizing at most some of the precursor and postcursor ISI in said plurality of channel output samples;
(f) generating a set of double-sided templates based on a second noiseless channel model having a second truncated ISI profile, wherein each double-sided template ŝ(•,•,•) is a function of three vector arguments having elements taken from said predetermined alphabet;
(g) decision-directed-ISIC decoding said double-sided partially equalized samples to provide DD-ISIC decoded symbols, said step of decision-directed-ISIC decoding further including the step of computing a second branch metric for each second current branch of a second decoder trellis of said trellis code based on the double-sided partially equalized samples associated with said second current branch and the double-sided template ŝ(x
_{2},y_{2},z_{2}) with vector argument x_{2 }being the vector of a second predetermined number of symbols associated with the past branches connected to said second current branch and vector argument y_{2 }being the vector of symbols associated with said second current branch and vector argument z_{2 }being the vector of a third predetermined number of symbols determined using said interim data decisions to be associated with the future branches connected to said second current branch; and the step of using said second branch metric in a second trellis decoding algorithm; (h) deinterleaving said DD-ISIC decoded symbols to provide deinterleaved symbols; and
(i) outer-FEC decoding said deinterleaved symbols based on said outer FEC code to provide said estimated data symbols.
23. A method as recited in
deinterleaving said ISIC-decoded symbols to provide deinterleaved ISIC-decoded symbols;
outer-FEC decoding said deinterleaved ISIC-decoded symbols based on said outer FEC code to provide outer-FEC-decoded-and-ISIC-decoded symbols;
outer-FEC re-encoding said outer-FEC-decoded-and-ISIC-decoded symbols based on said outer FEC code to provide re-encoded symbols; and
interleaving said re-encoded symbols to provide said interim data decisions.
24. A method as recited in
25. A method as recited in
26. A method of intersymbol interference compensation for preparing a plurality of data symbols for use as input to a channel and recovering said plurality of data symbols from a plurality of channel output samples for use by a data sink, said method comprising the steps of
(a) error-detection encoding said plurality of data symbols using an error-detection code to provide ED-encoded symbols;
(b) outer-FEC encoding said ED-encoded symbols using an outer FEC code to provide outer-FEC-encoded symbols;
(c) interleaving said outer-FEC-encoded symbols to provide interleaved symbols;
(d) trellis encoding said interleaved symbols using a trellis code to provide trellis-encoded symbols; and
(e) mapping said trellis-encoded symbols to provide said encoded symbols such that said encoded symbols assume values from a predetermined alphabet; and
(a) partially equalizing said plurality of channel output samples to provide partially equalized samples using a partial equalizer, thereby equalizing substantially all of the precursor ISI and at most some of the postcursor ISI in said plurality of channel output samples;
(b) generating a set of single-sided templates based on a first noiseless channel model having a first truncated ISI profile, wherein each single-sided template {circumflex over (q)}(•,•) is a function of two vector arguments having elements taken from said predetermined alphabet;
(c) ISIC decoding said partially equalized samples to provide ISIC-decoded symbols, said step of ISIC decoding further including the step of computing a first branch metric for each first current branch of a first decoder trellis of said trellis code based on the partially equalized samples associated with said first current branch and the single-sided template {circumflex over (q)}(x
_{1},y_{1}) with vector argument x_{1 }being the vector of a first predetermined number of symbols associated with the past branches connected to said first current branch and vector argument y_{1 }being the vector of symbols associated with said first current branch; and the step of using said first branch metric in a first trellis decoding algorithm; (d) processing said ISIC-decoded symbols to provide interim data decisions;
(e) applying double-sided partial equalization to said plurality of channel output samples to provide double-sided partially equalized samples using a double-sided partial equalizer, thereby equalizing at most some of the precursor and postcursor ISI in said plurality of channel output samples;
(f) generating a set of double-sided templates based on a second noiseless channel model having a second truncated ISI profile, wherein each double-sided template ŝ(•,•,•) is a function of three vector arguments having elements taken from said predetermined alphabet;
(g) decision-directed-ISIC decoding said double-sided partially equalized samples to provide DD-ISIC decoded symbols, said step of decision-directed-ISIC decoding further including the step of computing a second branch metric for each second current branch of a second decoder trellis of said trellis code based on the double-sided partially equalized samples associated with said second current branch and the double-sided template ŝ(x
_{2},y_{2},z_{2}) with vector argument x_{2 }being the vector of a second predetermined number of symbols associated with the past branches connected to said second current branch and vector argument y_{2 }being the vector of symbols associated with said second current branch and vector argument z_{2 }being the vector of a third predetermined number of symbols determined using said interim data decisions to be associated with the future branches connected to said second current branch; and the step of using said second branch metric in a second trellis decoding algorithm; (h) deinterleaving said DD-ISIC decoded symbols to provide deinterleaved symbols;
(i) outer-FEC decoding said deinterleaved symbols based on said outer FEC code to provide outer-FEC-decoded symbols; and
(j) error-detection decoding said outer-FEC-decoded symbols based on said error-detection code to provide said estimated data symbols.
27. A method as recited in
delaying said ISIC-decoded symbols to provide first candidate interim data decisions;
generating second candidate interim data decisions including the steps of
(a) deinterleaving said ISIC-decoded symbols to provide deinterleaved ISIC-decoded symbols;
(b) outer-FEC decoding said deinterleaved ISIC-decoded symbols based on said outer FEC code to provide outer-FEC-decoded-and-ISIC-decoded symbols;
(c) outer-FEC re-encoding said outer-FEC-decoded-and-ISIC-decoded symbols based on said outer FEC code to provide re-encoded symbols; and
(d) interleaving said re-encoded symbols to provide said second candidate interim data decisions;
determining error indicators for said second candidate interim data decisions such that an error indicator value of 0 indicates that the corresponding one of said second candidate interim data decisions is error-free and an error indicator value of 1 indicates otherwise, said step of determining error indicators including the steps of
(a) performing error detection and error indicator generation on said outer-FEC-decoded-and-ISIC-decoded symbols based on said error-detection code to provide deinterleaved error indicators; and
(b) interleaving said deinterleaved error indicators to provide said error indicators; and
selecting between said first candidate interim data decisions and said second candidate interim data decisions to provide said interim data decisions, wherein one of said interim data decisions is set to be one of said first candidate interim data decisions if the corresponding one of said error indicators is equal to
1, otherwise said one of said interim data decisions is set to be one of said second candidate interim data decisions. 28. A method as recited in
Description This application claims priority of Provisional Application Ser. No. 60/176162 which was filed on Jan. 14, 2000. This invention relates to methods for intersymbol interference compensation in data communications and data storage systems with the objective of improving the reliability of data recovery. Intersymbol interference (ISI) is found in many communications and recording systems. In order to reduce the frequency spectrum of a modulated signal, ISI may be introduced deliberately at the modulator. An example of modulation schemes that introduce ISI is Gaussian minimum shift keying (GMSK) described in the article: “GMSK Modulation for Digital Mobile Radio Telephony,” by K. Murota and K. Hirade, IEEE Transactions on Communications, vol. COM-29, pp. 1044-1050, July 1981. Filtering at the transmitter to control the signal spectrum can extend the basic modulation pulse beyond one signaling interval, thus introducing ISI. The communications medium is another potential source of ISI. In digital subscriber line (DSL) systems, which support high-rate data transmissions in addition to voice traffic, the severe line attenuation and delay variation with frequency of the telephone lines have been found to cause significant ISI in the received signal, as described in the book: In reading data from a magnetic recording medium, a phenomenon referred to as bit crowding may occur if the bit packing density is high, as described in the book: Modern high-end disk drive systems employ the partial response maximum likelihood (PRML) technology to achieve better performance. In this scheme a certain amount of ISI is deliberately introduced into the recorded signal in order to reduce constraints on the bandwidth of the electronic circuitry. During data recovery, the ISI is usually removed using a maximum likelihood detection scheme such as the Viterbi algorithm. A popular choice of partial response is the class IV partial response (PR4) characterized by the transfer function 1−D The block diagrams of a data communications system and a data storage system presented in FIGS. 1 and 2, respectively, will be used to define the problem to be solved. In FIG. 1, data source FIG. 2, which is a block diagram of a data storage system, shows the encoded sequence being supplied to modulator FIGS. 1 and 2 use the same reference numerals for data source The intersymbol interference found in a channel output sample is usually made up of precursor and postcursor portions. The precursor ISI is defined as the interference on the current sample from the future symbols while postcursor ISI is the interference from the past symbols. The channel output sample for the k'th symbol interval, in response to the application of the encoded sequence {v where h The problem to be solved is to estimate the data sequence {u It is well known to those skilled in the art that the optimum estimator, in terms of providing the lowest probability of estimation error in the presence of additive white Gaussian noise (AWGN), is the maximum likelihood sequence estimator (MLSE). The Viterbi algorithm (VA) has been demonstrated to be an efficient implementation of MLSE in the article: “Maximum-Likelihood Sequence Estimation of Digital Sequence in the Presence of Intersymbol Interference,” by G. D. Forney, Jr., IEEE Transactions on Information Theory, vol. IT-18, pp. 363-378, May 1972. In MLSE, the channel is modeled as a linear transversal filter equivalent to a convolutional encoder operating on the data sequence. The MLSE implemented using the Viterbi algorithm, referred to here as the VA-MLSE, has M The high complexity of the VA-MLSE has an impact on the power consumption of the circuitry implementing the estimator. Keeping the power consumption to the minimum is critical in some applications, such as hand-held and mobile communications terminals. U.S. Pat. No. 5,644,603, “Maximum-Likelihood Sequence Estimator with Variable Number of States,” issued to A. Ushirokawa on Jul. 1, 1997, discloses a means for estimating the ISI span and selecting from a group of VA-MLSEs of different number of states to match the estimated ISI span. This approach may ease the power consumption but does not reduce the hardware/software complexity. The use of MLSE in conjunction with forward-error-correction (FEC) coding has been suggested. For example, U.S. Pat. No. 5,673,291, “Simultaneous Demodulation and Decoding of a Digitally Modulated Radio Signal using Known Symbols,” issued to P. Dent on Sep. 30, 1997 discloses an apparatus for performing demodulation and decoding simultaneously using a VA-MLSE. In this approach, a data sequence to be transmitted is encoded using a block or convolutional code. Symbols known to the receiver are inserted into the encoded sequence and the composite sequence is interleaved. The known symbols are used to aid the decoding for recovery of the data sequence. A drawback of this approach is that the known symbol represent an overhead in the channel, thus reducing the bandwidth efficiency of the system. Another example of the use MLSE in conjunction with FEC coding is U.S. Pat. No. 5,844,946, “Soft-Decision Receiver and Decoder for Digital Communication,” issued to T. Nagayasu on Dec. 1, 1998. In the first step, the invention of Nagayasu employs a VA-MLSE to process the received signal to estimate the transmitted symbols. In the second step, a maximum a posteriori (MAP) algorithm is used to calculate the soft-decision reliability values for the estimated symbols. In the last step, the soft-decision values are applied to a Viterbi decoder for the convolutional code. A drawback of this approach is its high complexity, particularly the complexity of the MAP algorithm. A technique simpler than the MLSE for processing signals with ISI is linear equalization. The theory of linear equalizers is well known to those skilled in the art, see the article: “Adaptive Equalization,” by S. Qureshi, IEEE Communications Magazine, March 1982, pp. 9-16. One implementation of a linear equalizer employs a transversal filter, also referred to as a tapped-delay line filter, which is made up of delay elements, multipliers, and adders. The output of a transversal filter whose input is the channel output sequence {r where w An equalizer with the capability to adjust its tap weights in response to variations in the channel characteristics is called an adaptive equalizer. The theory of adaptive equalizers is well known to those skilled in the art, see the article by S. Qureshi referenced above. A commonly used technique for adaptively adjusting the tap weights is the least mean square (LMS) algorithm. In describing the LMS algorithm it proves convenient to represent the tap weights as a column vector with (N
where the superscript H represents Hermitian transposition, i.e., complex conjugation and transposition combined. Let d
In the LMS algorithm, the equalizer tap weight vector w
where μ is an adaptation time constant that controls the rate of adaptation and affects how closely the tap weights can be adjusted to the optimum values in response to variations in the channel characteristics. As mentioned earlier, a drawback of a linear equalizer is the noise-enhancement effect. To reduce the amount of noise enhancement, a decision feedback equalizer, also well known to those skilled in the art, can be used instead of a linear equalizer. A decision feedback equalizer has a feedforward section that is identical to the transversal filter, with the channel output sequence {r where N A number of techniques have been suggested to overcome the error-propagation effects in decision feedback equalizers. U.S. Pat. No. 5,541,956, “Adaptive Equalizer and Adaptive Diversity Equalizer,” issued to K. Ueda on Jul. 30, 1996, discloses a system with a decision feedback adaptive equalizer, a linear equalizer, a comparing circuit, and a selecting circuit. The selecting circuit chooses the equalizer that has the better performance as determined by the comparing circuit, which compares the integrated estimation error value of the decision feedback equalizer with the integrated estimation error value of the linear equalizer. Another technique for dealing with error-propagation effects in decision feedback equalizers is disclosed in U.S. Pat. No. 5,668,833, “Decision-Feedback Type Equalizer,” issued to Y. Kurokami et al. on Sep. 16, 1997. The Kurokami invention provides a means for detecting an abnormal state and a selection circuit used for selecting either equalization signals or symbol decisions for supplying them as input signals to the backward equalizer, in order to reduce propagation or magnification of errors caused by noise. U.S. Pat. No. 5,742,642, “Signal Processing Method and Apparatus for Reducing Equalizer Error,” issued to A. Fertner on Apr. 21, 1998, presents a method for detecting incorrect symbol decisions and correcting the errors to prevent propagation of the error with possible adverse effects on subsequent equalizer decisions. U.S. Pat. No. 5,774,504, “Equalization and Decoding for Digital Communication Channel,” issued to S. R. Huszar et al. on Jun. 30, 1998, discloses a multiple sub-channel decision feedback equalizer/decoder which samples the received signal at an integer multiple of the symbol rate, creating multiple sub-channels. Estimates of each of the sub-channels are updated using a locally best estimate in the equalizer/decoder processing, thereby avoiding delay in updating channel estimates in a rapidly changing channel such as a digital cellular communications channels. The techniques proposed by these patents employ various arrangements to ease the error-propagation effects of decision feedback equalizers at the expense of an increase in complexity of hardware and software. Furthermore, the error-propagation effects are only reduced, not completely eliminated. The article: “Delayed Decision-Feedback Sequence Estimation,” by A. Duel-Hallen and C. Heegard, IEEE Transactions on Communications, vol. 37, pp. 428-436, May 1989, proposed the use of decision feedback to reduce the number of states in MLSE. The number of states in a delayed decision feedback sequence estimator is M The journal articles and U.S. patents on equalization cited above consider systems without the use of error-correction coding. Equalizers, linear or decision feedback, have been used in conjunction with error-correction decoders. U.S. Pat. No. 5,872,817, “Joint Viterbi Decoder and Decision Feedback Equalizer,” issued to L. Wei on Feb. 16, 1999, discloses a system which employs trellis coded modulation and a bank of decision feedback equalizers, one for each state in the decoder. The arrangement is intended to provide symbol decisions to the decision feedback equalizers without excessive delay due to decoder by making use of the tentative decisions associated with each state in the decoding trellis. The equalized signal is used to update the decoder path metrics. The article: “Joint Coding and Decision Feedback Equalization for Broadband Wireless Channels,” by S. Ariyavisitakul and Y. Li, IEEE Journal on Selected Areas in Communications, vol. 16, No. 9, pp. 1670-1678, December 1998, describes an approach for joint convolutional coding and decision feedback equalization based on the use of both soft decisions and delayed tentative decisions. Soft decisions are obtained by passing the real and imaginary parts of the equalizer output through a hyperbolic tangent function. Tentative decisions from the Viterbi decoder are used both to cancel ISI caused by multipath with large delays and to adapt the equalizer. The article states that a tentative decoding delay approximately equal to the constraint length of the code is found to be provide near-optimum performance. U.S. Pat. No. 5,546,430, “Detector for Demodulating a Received Signal and Producing an Information Data Signal with Reduced Intersymbol Interference,” issued to K. Liao et al. on Aug. 13, 1996 discloses a detector for decoded trellis-coded modulation signal corrupted by ISI. The detector comprises a predictor, a feedforward filter, and a trellis coded modulation estimator with a feedback filter that is adjusted with respect to the feedforward filter to form a decision feedback equalizer. A general approach of this group of techniques is to remove the ISI using a decision feedback equalizer, aided by arrangements that help to reduce the error propagation, and then decode the ISI-free signal. Such a cascade of two operations is sub-optimum since it yields less reliable data recovery than a technique, such as MLSE, that simultaneously removes the ISI and decodes the signal. The article: “Soft-Output Equalization and TCM for Wireless Personal Communications,” by Y. Chen et al., IEEE Journal on Selected Areas in Communications, vol. 16, No. 9, pp. 1679-1690, December 1998, describes the use of a maximum a posteriori probability (MAP) algorithm to realize soft-output equalization in a concatenated equalization and trellis coded modulation (TCM) decoding system. MAP algorithms compute the conditional probabilities of symbols. The computation involves a nonlinear function and requires knowledge of the noise variance. The article proposes a modified MAP algorithm that does not require knowledge of the noise variance and computes the probabilities in the logarithmic domain to avoid the need to calculate a nonlinear function. U.S. Pat. No. 5,825,832, “Method and Device for the Reception of Signals Affected by Inter-Symbol Interface,” issued to V. Benedetto on Oct. 20, 1998, discloses a receiver for a trellis-code modulated signal comprising two cascaded Viterbi decoders. The first decoder is intended essentially to take into account the memory effects of the channel. The output of the first decoder, which comprises a hard decision on the transmitted symbols as well as a reliability parameter, is supplied, possibly after a de-interleaving action, to the second Viterbi decoder that carries out the actual decision. The use of the first decoder instead of an equalizer to handle ISI reduces the noise enhancement and noise correlation effects. Like the techniques discussed in the preceding paragraph, this set of techniques employs a cascade of ISI equalization and FEC decoding operations and hence yields a sub-optimum performance when compared to a technique that simultaneously removes the ISI and decodes the signal. U.S. Pat. No. 5,031,195, “Fully Adaptive Modem Receiver using Whitening Matched Filtering,” issued to P. R. Chevillat et al. on Jul. 9, 1991, discloses a technique for combining equalization and decoding of trellis-coded modulation using a decoder with combined ISI-and-code states. The number of states, which is the product of the number of code states and the number of ISI states, can be too large for practice. The Chevillat invention also discloses a decoder that ignores some ISI so as to reduce the complexity. The use of an encoder that includes precoding has been employed to pre-distort the signal in order to compensate for the distortion that the channel is expected to introduce. A commonly used preceding technique is the Tomlinson-Harashima preceding algorithm described in the article: “Combined Equalization and Coding Using Precoding,” by G. D. Forney, Jr. and M. V. Eyuboglu, IEEE Communications Magazine, December 1991. Suppose the alphabet of the data is a set with M points: A={±1,±3, . . . ,(M−1)}. Suppose that u where the value of z
It can be seen that the channel output has no ISI. To recover the transmitted symbol u The use of preceding raises the average transmit power since the maximum precoded symbol amplitude is M, which can be contrasted with the maximum uncoded data symbol amplitude of M−1. The increase in the average transmit power is shown in the article by Forney and Eyuboglu to be M U.S. Pat. No. 5,513,216, “Hybrid Equalizer Arrangement for Use in Data Communications Equipment,” issued to S. Gadot et al. on Apr. 30, 1996 and U.S. Pat. No. 5,604,769, “Hybrid Equalizer Arrangement for Use in Data Communications Equipment,” issued to J. Wang on Feb. 18, 1997 disclose techniques for setting the precoder coefficients based on measurements made at the receiver using a hybrid intersymbol interference decision feedback equalizer (ISI-DFE) and a noise predictive decision feedback equalizer (NP-DFE). In particular, a hybrid DFE is designed so that the I(z) coefficient values dominate over the N(z) coefficient values. In the first patent, a respective Tomlinson precoding scheme in the transmitter uses only the I(z) values. In the second patent, the precoding coefficients are set to be (1+I(z)) (1+N(z))−1. In certain applications, it is desirable to transmit a constant-envelope signal. Such applications include transmitters that operate the power amplifier at saturation to achieve higher power efficiency. A constant-envelope signal has the desirable property that it is not degraded by a saturating amplifier. Clearly, precoding cannot be used if a constant-envelope signal is desired. Another drawback of precoding is that the channel impulse response must be known at the transmitter. I will now discuss prior art in ISI compensation in magnetic storage systems. The use of an equalizer followed by a Viterbi decoder has been proposed for combating ISI in magnetic storage devices. Here, the Viterbi decoder is used to perform maximum likelihood estimation of the read-back data corrupted by ISI by treating the ISI channel as an encoder. U.S. Pat. No. 5,343,335, “Signal Processing System Having Intersymbol-Interference Canceling Means and Method of Same,” issued to M. Hara on Aug. 30, 1994, discloses a reproduction equalizer comprising a linear equalization means, a nonlinear cancellation means for canceling the intersymbol interference included in the linearly equalized signal, a decoding means for decoding the ISI-free signal. U.S. Pat. No. 5,581,568, “Data Detection Apparatus,” issued to M. Togami on Dec. 3, 1996, discloses an arrangement that uses an integral equalizer for low-frequency-emphasizing-type equalization to provide a larger margin in detection timing and a higher signal-to-noise ratio. The arrangement uses a Viterbi decoder to process the equalized signal. U.S. Pat. No. 5,606,464, “Cancellation of Precursor Intersymbol Interference in Magnetic Recording Channels,” issued to The article: “Trellis Coding for Partial-Response Channels,” by J. Wolf and G. Ungerboeck, IEEE Transactions on Communications, vol. COM-34, No. 8, pp. 765-773, August 1986, proposes the use of trellis coding to provide a coding gain over partial-response signaling with a discrete-time transfer function of (1−D), which is referred to as a dicode signaling. The proposed arrangement employs a binary convolutional encoder, a precoder, and at the receiver, a Viterbi decoder with twice as many states as the convolutional encoder. The extra decoder states are to accommodate the states introduced by the partial-response channel. A drawback of this arrangement is that the extra decoder states for accommodating the ISI increase the complexity of the decoder. In summary, the prior art on intersymbol interference compensation using a maximum likelihood sequence estimator (MLSE) yields the best reliability in data recovery. The MLSE, however, is very complex. The number of estimator states required is M The object of the present invention is to provide a method for intersymbol interference compensation that meets these goals: (i) a method that is less complex than maximum likelihood sequence estimation and delayed decision feedback sequence estimation; (ii) a method that performs better than the linear equalizer in terms of less noise enhancement and noise colorization; (iii) a method that is substantially free of the error-propagation effects of decision feedback equalizers; and (iv) a method that supports constant-envelope signaling as well as non-constant envelope signaling. According to one embodiment of the present invention, the intersymbol interference compensation (ISIC) method comprises an encoding step performed by an encoder and a data estimating step performed by a data estimator. The encoder performs at least a trellis encoding of a data sequence using a trellis forward-error-correction (FEC) code such as a binary convolutional code or trellis coded modulation (TCM) code to provide a sequence of symbols for use as the input sequence to a channel. The output of the channel, referred to as the channel output sequence, comprises of samples represented as digital words. The data estimator advantageously processes the channel output sequence to provide an estimated data sequence. The data estimator comprises at least a partial equalizer, a template generator, and an ISIC decoder. The channel output sequence is supplied to the partial equalizer to provide a partially equalized sequence that is substantially free of the precursor ISI but contains at least some of the postcursor ISI of the channel output samples. The partially equalized sequence is applied to the ISIC decoder, which performs trellis decoding and ISI compensation simultaneously. The ISIC decoder implements a trellis decoding algorithm that computes branch metrics for a decoding trellis based on a set of templates {circumflex over (q)}(•,•). The templates are computed by taking into account the unequalized postcursor ISI and represent the statistical average values of the partially a equalized samples. The template generator supplies the template {circumflex over (q)}(x,y) in response to a pair of vectors (x,y) provided by the ISIC decoder, where x is the vector of symbols associated with the past branch or branches connected to a current branch in the decoding trellis, and y is the vector of symbols associated with the current branch. The number of states in the ISIC decoder is determined by the trellis code and is independent of the ISI span of the channel. The output of the ISIC decoder is the estimated data sequence for use by the data sink. In one embodiment of the present invention, the equalizer tap weights are pre-computed and preloaded into the partial equalizer. The templates are either preloaded into the template generator or computed when needed by the template generator using a set of preloaded coefficients representing the ISI profile at the output of the partial equalizer. This is the preferred embodiment when the ISI profile of the channel is time-invariant and known a priori. In another embodiment of the present invention, the equalizer tap weights are adaptive, adjusted in response to variations in the ISI profile of the channel. This is the preferred embodiment when the channel is time varying or when the channel ISI profile is not known a priori with sufficient accuracy. The invention provides for methods for partial equalizer adaptation based on known symbols called training symbols and adaptation based on estimated symbols. The desired output of the partial equalizer is the template {circumflex over (q)}(a,b), where a is a vector of past encoded symbols and b is the current encoded symbol. Subtracting the partial equalizer output from the desired output {circumflex over (q)}(a,b) yields an error signal that is used to adapt the equalizer tap weights. In yet another embodiment of the present invention, an ISI profile estimator is employed to estimate the impulse response of the channel. The estimated ISI profile is used to update the templates. In yet another embodiment of the present invention, the channel output sequence is supplied to a double-sided partial equalizer, which leaves some of the precursor and postcursor ISI unequalized. In particular, the double-sided partial equalizer removes only the ISI not accounted for by the double-sided templates ŝ(a,b,c), where a, b, and c represent the past, current, and future encoded symbols. (The term “double-sided template” is chosen to signify that ŝ(•,•,•) depends on both past and future symbols. In contrast, the template {circumflex over (q)}(•,•) does not depend on future symbols and will be referred to as a single-sided template. The term “template” will be used to refer to either {circumflex over (q)}(•,•) or ŝ(•,•,•) when its meaning is clear.) Thus, the desired output of the double-sided partial equalizer is ŝ(a,b,c). The output of the double-sided partial equalizer is supplied to a decision-directed-ISIC (DD-ISIC) decoder. In this embodiment of the present invention, the output of the ISIC decoder is not supplied to the data sink but is supplied instead to the DD-ISIC decoder for use as interim data decisions. The DD-ISIC decoder computes the branch metrics using the templates ŝ(x,y,z) with z representing the vector of symbols associated with the future branch or branches in the decoding trellis as determined by the interim data decisions. The output of the DD-ISIC decoder is the estimated data sequence for use by the data sink. In yet another embodiment of the present invention, concatenated coding is employed wherein the data sequence is applied to a cascade of an outer FEC encoder, an interleaver and at least a trellis encoder to provide an encoded sequence for use as the channel input. At the data estimator, the channel output samples are advantageously processed by a partial equalizer and an ISIC decoder to provide a sequence that is further advantageously processed by a cascade of a deinterleaver and an outer FEC decoder to provide an estimated data sequence for use by the data sink. In yet another embodiment of the data estimator for use with concatenated coding, the ISIC decoder output is supplied to a cascade of a first deinterleaver, a first outer FEC decoder, an outer FEC encoder, and an interleaver to provide an outer-FEC-decoded sequence for use by a DD-ISIC decoder as interim data decisions. The DD-ISIC decoder output is supplied to a cascade of a second deinterleaver and a second outer FEC decoder to provide an estimated data sequence for the data sink. In yet another embodiment of the present invention, an error-detection code is employed to detect errors in the outer-FEC-decoded sequence. A selector is used to select the interim data decisions for use by the DD-ISIC decoder. If errors are detected in the outer-FEC-decoded sequence, the interim data decisions are set to be the output of the ISIC decoder; otherwise, they are set to be the outer-FEC-decoded sequence. FIG. 1 is a block diagram of a data communications system; FIG. 2 is a block diagram of a data storage system; FIG. 3 is a block diagram representing either a data communications system or a data storage system, depending on whether channel FIG. 4 is a block diagram depicting the encoding block in one embodiment of the present invention; FIG. 5 is a trellis diagram of a constraint length 3, rate 1/2 convolutional code with code generators g FIG. 6 is a block diagram showing a method for generating the phase signal φ(t) for Gaussian minimum shift keying (GMSK) modulation; FIG. 7 shows the phase signal φ(t) and the quadrature baseband signal sin(φ(t)) for minimum shift keying (MSK) (top two graphs) and GMSK (bottom two graphs); FIG. 8 FIG. 8 FIG. 9 FIG. 9 FIG. 10 shows an 8-PSK constellation partitioned into two sets and the mapping of the rate 2/3, 4-state TCM encoder output sequence into an 8-PSK symbol and the corresponding complex symbol v FIG. 11 is a trellis diagram of the rate 2/3, 4-state TCM used as an example of TCM coding in one embodiment of the present invention, showing the input/output of the trellis branches and, with darken line segments, showing the encoded path for a data sequence of {u FIG. 12 is a block diagram of a channel model; FIG. 13 is a block diagram of a noiseless channel model; FIG. 14 is a block diagram illustrating the calculation of the templates {circumflex over (q)}(x,y) in one embodiment of the present invention; FIG. 15 shows a graph of the precursor equalizer tap weights used to remove substantially all of the precursor ISI for the GMSK modulation with BT=0.1 and a graph of the discrete-time impulse response at the output of the precursor equalizer; FIG. 16 shows a block diagram of an ISIC equalizer-decoder in one embodiment of the present invention comprising a partial equalizer, a template generator, and an ISIC decoder; FIG. 17 shows a block diagram of an ISIC equalizer-decoder in another embodiment of the present invention where {{circumflex over (v)} FIG. 18 shows a block diagram of an ISIC equalizer-decoder in yet another embodiment of the present invention where {{circumflex over (v)} FIG. 19 is a decoding trellis, derived from FIG. 5, for a constraint length 3, rate 1/2 binary convolutional code, with the trellis branches labeled by encoder output bits; FIG. 20 is a decoding trellis for a constraint length 3, rate 1/2 binary convolutional code, with the branches labeled by the encoded symbols v FIG. 21 shows a block diagram of an ISIC equalizer-decoder in one embodiment of the present invention where an ISI profile estimator is employed and, for adaptation, the ISI profile estimator makes use of a replica of the training sequence {v FIG. 22 shows a block diagram of an ISIC equalizer-decoder in another embodiment of the present invention where the ISI profile estimator, for adaptation, makes use of a replica of the training sequence {v FIG. 23 shows a block diagram of an ISIC equalizer-decoder in yet another embodiment of the present invention where the ISI profile estimator, for adaptation, makes use of a replica of the training sequence {v FIG. 24 shows an ISIC equalizer-decoder representing one of the six ISIC equalizer-decoder embodiments depicted in FIGS. 16, FIG. 25 is a block diagram of one embodiment of a data estimator of the present invention comprising an ISIC equalizer-decoder, a double-sided partial equalizer, and a decision-directed-ISIC (DD-ISIC) decoder; FIG. 26 shows a decoding trellis for a constraint length 3, rate 1/2 binary convolutional code used to explain the operation of the DD-ISIC decoding algorithm; FIG. 27 is a block diagram of an encoder employing concatenated coding in one embodiment of the present invention; FIG. 28 is a block diagram of a data estimator in one embodiment of the present invention for recovering the data having been encoded by the encoder of FIG. 27; FIG. 29 is a block diagram of a data estimator in another embodiment of the present invention for recovering the data having been encoded by the encoder of FIG. 27 using a DD-ISIC decoder with the interim data decisions estimated by an outer FEC decoder; FIG. 30 is a block diagram of an encoder employing concatenated coding and error-detection in yet another embodiment of the present invention; and FIG. 31 is a block diagram of a data estimator in one embodiment of the present invention for recovering the data having been encoded by the encoder of FIG. FIGS. 1 and 2, which have been described in the “Background of the Invention” section, are block diagrams depicting a data communications system and a data storage system, respectively. FIG. 3 is a block diagram that includes data source FIG. 4 shows a block diagram of encoder
where g
Since trellis encoder where {circle around (X)} stands for convolution operation and ⊕ stands for the modulo-2 operation, which is defined by the following set of equations: 0⊕0=0, 1⊕1=0, 1⊕0=1, and 0⊕1=1. The trellis-encoded sequence {c
for l=1,2, . . . and n=1,2, . . . , n As an example of the trellis encoding algorithm suppose the data sequence is {u It is customary to think of a trellis encoder as comprising a shift register with K stages, with the data sequence being supplied to the shift register from the left. The content of the shift register at time m is equal to the right hand side of equation (10) written in the reverse order: (u The trellis encoding process can be displayed in the form of a trellis. A trellis diagram for the K=3, rate 1/2 code is depicted in FIG. 5. A state is shown in the figure as a dot. All of the dots on the top row of the figure are state 00, all of the dots on the second row are state 01, and so on. A state is connected to another state by a branch. Each branch in the figure is labeled as data-input/encoded-output. The darkened path in the figure shows the encoding of the data sequence {u Referring back to FIG. 4, trellis encoder I will refer to the above mapping as antipodal mapping. For BPSK, the output of modulator
where f For QPSK, mapper For QPSK, the output of modulator
where Re stands for “the real part of” and exp is the exponential function. It proves convenient to express the modulated RF signal in terms of the complex baseband modulated signal p
For BPSK and QPSK, the complex baseband modulated signal is
In one embodiment of the present invention for MSK and GMSK modulation, the mapping of trellis-encoded sequence {c For example, if {V
To explain the rationale behind these mapping steps, I will express the complex baseband modulated signal for MSK and GMSK as
where φ(t) is the phase of the modulated signal. The quantities cos(φ(t)) and sin(φ(t)) are referred to as the in-phase and the quadrature baseband signals, respectively. Consider first MSK for which the phase signal is given by After some thought and plotting the phase signal for a few values of the trellis-encoded sequence {c Consider next the generation of the phase signal φ(t) for GMSK. In the continuous-time notation, the encoded sequence can be represented as where p where B is the one-sided 3-dB bandwidth. The product of the one-sided 3-dB bandwidth and the symbol duration, BT, is used as a parameter in specifying the GMSK modulation. For example, the European Global System for Mobile Communications (GSM) employs BT=0.3. A smaller value of BT yields a modulated signal that has a narrower spectrum but introduces more ISI. For example, using GMSK with BT=0.1 introduces much more ISI than using GMSK with BT=0.3 but cuts the signal bandwidth by approximately a factor of two. With reference to FIG. 6, the frequency signal may be written as where p FIG. 7 compares the phase signals and the quadrature signals of MSK and GMSK for the case where the sequence {v MSK and GMSK are members of a class of modulation schemes called continuous phase modulation (CPM), see the article: “Continuous Phase Modulation,” by C. Sundberg, IEEE Communications Magazine, vol. 24, No. 4, pp. 25-38, April 1986 and the article: “Multi-h Phase-Coded Modulation,” by I. Sasase and S. Mori, IEEE Communications Magazine, pp. 46-56, December 1991. Those skilled in the art should recognize that the encoding and mapping methods described above are applicable to CPM. I will now describe encoder
For EPR4 modulation, which has a discrete-time transfer function of 1+D−D
The discrete-time transfer function of the PR4 mapping is shown in FIG. 8 In yet another embodiment of the present invention, trellis encoder I will now present an example of a TCM encoder that can be used with the present invention. FIG. 9 FIG. 10 shows an 8-PSK constellation partitioned into two sets and the mapping of the rate 2/3, 4-state TCM encoder output sequence into an 8-PSK symbol and the corresponding complex symbol v FIG. 11 is a trellis diagram of the rate 2/3, 4-state TCM code discussed above. A branch on the trellis is labeled u Those skilled in the art should recognize that the preceding TCM example can easily be generalized, by using the arrangement shown in FIG. 9 Table 1 presents the exemplary encoding embodiments of the present invention. In summary, trellis encoding is performed on the data sequence {u
Quantities called templates will be a part of the data estimator embodiments of the present invention. A template is a function of two or three vector arguments and is the response of a noiseless channel model with a truncated ISI profile when the arguments of the templates are applied to the noiseless channel model. A template represents the statistical average values of the channel output samples after certain processing has been performed, as explained below. In the data estimator, templates are compared with processed channel output samples to provide a reliability metric. The results of these comparisons are used to aid data recovery. I will define the templates and show how they can be calculated or estimated. I will start with channel model
where {circle around (X)} stands for the convolution operation. The signal p
and
are the filtered signal and the filtered noise, respectively. In the case of a data communications channel, block
where,
and
The noise process n(t) is usually modeled as a zero-mean random process. Therefore, from equation (32), the signal component s The above discussion shows that, when a given encoded sequence {v In general, not all of the characteristics and impulse responses of the channel are known a priori. If the signal component {s
and
These two equations may be combined to yield
Here,
is the impulse response of block
In summary, the signal sequence {{overscore (s)} In the above procedure for calculating the signal sequence {{overscore (s)} Calculating the signal sequence {{overscore (s)} Since the channel with ISI can spread the input signal in time, the channel output usually has a longer duration than the channel input. Suppose an encoded sequence {v I will now define the templates, in particular the single-sided template {circumflex over (q)}(•,•), which is a function of two arguments. The arguments, which can be either vectors or scalars, assume values from the alphabet A I will use FIG. 14 to motivate the definition of templates for the present invention. The vector arguments x and y of the template {circumflex over (q)}(x,y) represent the input to noiseless channel model I will now show that templates may be computed from a truncated ISI profile obtained by setting selected components of the ISI profile of the channel to zero. Let {{tilde over (h)} where {ĥ It follows that the template {circumflex over (q)}(•,•) may be computed from a truncated ISI profile. To complete the discussion on calculating single-sided templates, I will describe the structure of precursor equalizer The equalizer tap weights required to provide an output {overscore (q)}
where R
where E is the statistical averaging operator, also known as the expectation operator. The quantity p is a N×1 cross-correlation column vector:
For a non-linear modulation such as GMSK, I have found by means of computer simulation that good performance can be achieved by using the tap weights calculated using a linear model as described above. More specifically, the desired output {circumflex over (q)} In summary, the single-sided template {circumflex over (q)}(•,•) is a function of two arguments and is a vector with the same number of elements as the second vector argument. For vector arguments x and y, the single-sided template {circumflex over (q)}(x,y) is the response of a noiseless channel model with a truncated ISI profile when vector y is applied to the channel preceded by vector x. The truncated ISI profile has zero precursor ISI and up to L Some embodiments of the present invention make use of the double-sided templates ŝ(•,•,•), which are a function of three arguments. For vector arguments x, y, and z, the double-sided template is equal to ŝ(x,y,z), where x and y are defined above and z=(z The components of the double-sided templates may be computed according to The single-sided templates {circumflex over (q)}(•,•) and the double-sided templates ŝ(•,•,•) differ in the truncated ISI profiles used to generate the templates. In the case of single-sided templates the truncated ISI profile has no non-zero precursor ISI whereas in the case of the double-sided templates the truncated ISI profile may have non-zero precursor ISI. In the preferred embodiments of the present invention, the parameters L In the preceding discussion I have used the same vector argument, namely x, for the first arguments of the single-sided templates {circumflex over (q)}(•,•) and the double-sided templates ŝ(•,•,•). This has been done to simplify the discussion and should not be considered a restriction on the present invention. The present invention provides for the use of vector arguments of different lengths for the first arguments of the two types of templates. For reasons that will become apparent later, the second arguments of the two types of templates have the same lengths. I will now examine the storage requirement of the templates. Recall that the arguments x, y, and z of the templates ŝ(x,y,z) and {circumflex over (q)}(x,y) are vectors of length L A similar method may be used to construct the vector templates ŝ(x,y,z) from the scalar templates ŝ(x,y,z). Consider (x,y,z) as a single vector with a length of L The number of scalar templates ŝ(x,y,z) and {circumflex over (q)}(x,y) that need to be stored is M I will now describe how the templates are used in the present invention. FIG. 16 shows a block diagram of a data estimator in one embodiment of the present invention comprising ISIC equalizer-decoder In one embodiment of the present invention the templates are pre-computed and preloaded into template generator Partial equalizer In one embodiment of the present invention, partial equalizer In another embodiment of the present invention, partial equalizer
Let a be the vector of L
Let b be the encoded symbol corresponding to channel output sample r
Partial equalizer
The error signal is used to update the tap weights. An adaptation algorithm that can be used is the LMS algorithm described by equation (5). In applications where the channel is time invariant (but with an unknown impulse response) or varying very slowly, the tap weights may be adapted only during the reception of the initial training signal and re-training signal inserted periodically into the data signal. In applications where it is unacceptable to send periodic re-training signals and tap weight adaptation is needed to track a slowly varying channel, the preferred embodiment of the present invention is to employ decision-directed adaptation using the estimated data sequence {û
and,
The calculation of the error signal and the weight adaptation follow the same steps described above for adaptation during reception of training signals. When using decision-directed adaptation, partial equalizer The re-encoded sequence {{circumflex over (v)} In applications such as mobile communications the channel may be varying too rapidly for the delay in adaptation introduced by ISIC decoder With reference to FIG. 18, the slicer-estimated sequence {{circumflex over (v)} For partial equalizer The three embodiments of the present invention for data estimator shown in FIGS. 16, In this exemplary description of the present invention, the partial equalizer is assumed to operate at the rate of one sample per symbol. Such an equalizer is generally referred to as a symbol-spaced equalizer. Those skilled in the art should realize that the partial equalizer might employ fractional tap spacing. See the article: “Fractionally-Spaced Equalization: An Improved Digital Transversal Equalizer,” by R. Gitlin and S. Weinstein, The Bell System Technical Journal, Vol. 60, No. 2, pp. 275-296, February 1981. For example, the equalizer taps may be spaced at one half of the symbol duration. In that case, the channel output sequence {r I will now describe ISIC decoder FIG. 20 shows that at trellis depth (k−1) there are four paths, known as survivor paths, one terminating at each of the four states. Associated with each survivor path is a path metric, P The length of each survivor path is D According to one embodiment of the present invention, ISIC decoder
Suppose {circumflex over (q)}(x,y)−q=d=(d
and,
Those skilled in the art should recognize that the above-described ISIC decoding algorithm is the same as the classical Viterbi algorithm for decoding a trellis-encoded signal with the exception that the branch metric is computed differently for the present invention. Those skilled in the art should also realize that an approximation to the branch metric might be used to reduce the implementation complexity, possibly at the expense of degraded data estimation. For example, the branch metric B=|d The three embodiments of the present invention for ISIC equalizer-decoders shown in FIGS. 16, FIG. 21 shows a block diagram of ISIC equalizer-decoder In one exemplary embodiment of the present invention, ISI profile estimator The estimator input sequence {{tilde over (s)} ISI profile estimator
The error signal is used to update the tap weights. Let the (N
The tap weight vector {tilde over (g)}
where β is an adaptation time constant that controls the rate of adaptation, chosen to work with the expected rate of change of the channel. ISI profile estimator Updating the templates can be computationally demanding. If the channel varies slowly, it is not necessary to update the templates every symbol period. In one embodiment of the present invention, template generator
where λ FIG. 22 shows a block diagram of ISIC equalizer-decoder ISIC equalizer-decoder Table 2 summarizes the exemplary ISIC equalizer-decoder embodiments of the present invention to illustrate the similarities and differences in the partial equalizer adaptation, ISI profile estimation, and template updating among the embodiments.
FIG. 24 shows ISIC equalizer-decoder FIG. 25 shows a block diagram of one embodiment of a data estimator of the present invention. The sequence {Û
Like the partial equalizer, the double-sided partial equalizer may have fixed or adaptive tap weights. The choice depends on the time-varying characteristics of the channel, as discussed above. To adapt the equalizer tap weights, double-sided partial equalizer
During data reception, double-sided partial equalizer
The vector (a,b,c) is supplied to ISIC equalizer-decoder
The error signal is used to update the tap weights. An adaptation algorithm that can be used is the LMS algorithm:
where α is an adaptation time constant. Note that if the templates ŝ(•,•,•) perfectly account for the all of the ISI profile of the channel, the equalizer tap weights will converge to W DD-ISIC decoder I will illustrate the DD-ISIC decoding algorithm by using trellis diagrams for the constraint length 3, rate 1/2 code, whose encoding trellis is shown in FIG. According to one embodiment of the present invention, DD-ISIC decoder
and,
where Q is the vector of double-sided-partially-equalized symbols for the transition from trellis depth (k−1) to trellis depth k. The rest of the decoding uses the same method as that used by ISIC decoder I will now describe one embodiment of the present invention that employs concatenated coding. Well known to those skilled in the art as a technique for improving the data estimation reliability, concatenated coding employs two FEC codes in cascade. FIG. 27 shows encoder RS encoding and decoding work with code symbols that are m-bit words. A common code symbol length is m=8, which I will assume for an exemplary embodiment. The code block length n of a RS code is related to m by the relationship: n=2 Referring back to FIG. 27, the output bit sequence of outer FEC encoder Suppose the interleaver size is J×n code symbols. Interleaver For an interleaver size of 2×n code symbols, for example, each super-block is composed of two code blocks. Interleaver FIG. 28 shows a block diagram of a data estimator of one embodiment of the present invention for recovering the data that has been encoded by encoder Referring back to FIG. 25, errors in the sequence of interim data decisions {Û A characteristic of RS decoding is that whenever there is a decoding error, i.e. whenever the decoded code block is not a perfect replica of the encoded code block, the decoded sequence usually has more code symbol errors than the input sequence to the decoder. As noted above, the performance of DD-ISIC decoder FIG. 30 is a block diagram of encoder In one embodiment of the present invention, the error-detection code is an (n FIG. 31 is a block diagram of a data estimator of one embodiment of the present invention that employs error detection to improve the reliability of the interim data decisions supplied to DD-ISIC decoder The delay introduced by block DD-ISIC decoder The output of DD-ISIC decoder I have described above several embodiments of the present invention. These embodiments provide different levels of reliability in data estimation. A higher reliability is achieved by the more complex embodiments. Some embodiments are better suited for applications where the impulse response of the channel is time varying while others, possibly less complex, embodiments are more suitable for time-invariant or very-slowly-varying channels. Those skilled in art should be able to choose the embodiments that are most suitable for their applications. The number of trellis states of the ISIC and the DD-ISIC decoders of the present invention is dependent only on the trellis code employed and independent on the ISI span. Hence, the intersymbol interference compensation methods of the present invention are less complex than maximum likelihood sequence estimation and delayed decision feedback sequence estimation. By using a partial equalizer to remove only the precursor ISI, the noise enhancement and noise colorization effects are reduced. Use of the double-sided partial equalizer further reduces these undesirable effects. The methods of the present invention do not employ decision feedback equalization to provide data estimates and are therefore not subject to the error-propagation effects of decision feedback equalizers. Some embodiments of the present invention provide for the use of decision feedback equalization but only as a means to aid the adaptation of the partial equalizer, the double-sided partial equalizer, and the ISI profile estimator. In such a use of decision feedback equalization the error propagation effects can be made insignificant by slowing down the rate of adaptation. The present invention does not employ precoding, hence it can be used to support constant-envelope signaling as well as non-constant envelope signaling. The above-described exemplary embodiments are intended to be illustrative in all respects, rather than restrictive, of the present invention. Those skilled in the art will be able to devise various arrangements, which, although not explicitly described herein, embody the principles of the invention, and thus are within its spirit and scope as defined by the following claims. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |