The present application is related to U.S. patent application Ser. No. 10/142,108 filed on May 9, 2002 and Ser. No. 10/142,110 filed on May 9, 2002.
The present invention relates to equalizers and, more particularly, to equalizers that adapt to the condition of a channel through which signals are received.
Equalizers such as adaptive decision feedback equalizers having a plurality of taps are widely used in digital communication receivers in order to provide correction for multipath channel distortion. Adaptive algorithms, such as the least mean squares (LMS) algorithm, are implemented in order to determine the tap weight values for the taps of the equalizer. Such adaptive algorithms are easy to implement and provide reasonably good performance. However, under difficult channel conditions, these algorithms may fail to provide tap weights that converge to the desired values.
It is well known that this failure may be avoided if the tap weights, instead of being initialized to values of zero as is often done, are initialized at least somewhat close to their final desired values based on a knowledge of the channel impulse response (CIR). An estimate of the channel impulse response may be derived from an a priori known training signal periodically transmitted prior to, and/or along with, the unknown data. One such system, in which an a priori known training signal is periodically transmitted prior to, and/or along with, unknown data, is specified in the ATSC 8VSB standard for digital terrestrial television broadcasting.
The channel impulse response is typically estimated in a receiver by cross-correlating the training signal as received with a representation of the known transmitted training signal stored in the receiver. The initial minimum mean square error (MMSE) tap weights may then be calculated from the initial channel estimate utilizing well known methods, such as those described in “Fast Computation of Channel-Estimate Based Equalizers in Packet Data Transmission,” IEEE Transactions on Signal Processing, N. Al-Dhahir, J. M. Cioffi, November 1995 and “A Fast Computational Algorithm for the Decision Feedback Equalizer,” IEEE Transactions on Communications, I. Lee, J. M. Cioffi, November 1995. The initial tap weights are then provided to the equalizer.
An example of such an equalizer is shown in
The operation of the decision feedback equalizer 10 is well known. The input to the feed forward filter 12 is the received data y. The feed forward filter 12 includes a plurality of outputs 141 through 14n and a corresponding plurality of multipliers 161 through 16n. The signal on each of the outputs 141 through 14n is multiplied by a corresponding tap weight gFF1 through gFFn from a tap weight update algorithm (such as the well known LMS algorithm) by a corresponding one of the multipliers 161 through 16n. The outputs from the multipliers 161 through 16n are added together by an adder 18, and the output from the adder 18 is supplied to the plus input of a subtractor 20.
The output of the subtractor 20 is considered the output of the decision feedback equalizer 10. The output of the subtractor 20 is also provided as an input to a non-linear decision device 22 and to the minus input of a subtractor 24. The non-linear decision device 22 operates as a slicer for the data at the output of the subtractor 20. When the non-linear decision device 22 receives training data at its input, the non-linear decision device 22 outputs sliced values of the a priori known training sequence. The output of the decision device 22 supplies sliced values to the input of the feedback filter 14 and to the plus input of the subtractor 24. The subtractor 24 compares the input of the decision device 22 to the output of the decision device 22 so as to form an error e[n] for the LMS algorithm.
The feedback filter 14 includes a plurality of outputs 261 through 26n and a corresponding plurality of multipliers 281 through 28n. The signal on each of the outputs 261 through 26n is multiplied by a corresponding tap weight gFB1 through gFBn from the above mentioned tap weight update algorithm by a corresponding one of the multipliers 281 through 28n. The outputs from the multipliers 281 through 28n are added together by an adder 30, and the output from the adder 20 is supplied to the minus input of the subtractor 20.
When the training sequence is first received, an estimate of the channel impulse response is typically calculated by cross-correlating the training signal as received with a stored version of the known training signal. The training sequence vector s of length N may be defined according to the following equation:
s=[s[0]. . . s[N−1]]T. (1)
The channel impulse response may be defined as having a length L such that L=(La+Lc+1), where La is the length of the anti-causal portion of the channel impulse response and Lc is the length of the causal portion of the channel impulse response. A matrix A based on the known training signal may be defined by the following equation:
The real vector of received symbols is designated as y with y[0] being designated as the first received training data element. The vector y of length N+L−1 may then be defined by the following equation:
y=[y[−La], . . . ,y[0], . . . ,y[Lc+N−1]]T. (3)
The raw cross-correlation channel estimate is then given by the following equation:
where ∥s∥ is the 2-norm of s, and where the 2-norm of s is generally given as √{square root over (|s1|2+|s2|2+ . . . +|sn|2)}.
Then, the initial tap weights of the decision feedback equalizer 10 are calculated utilizing MMSE methods which determine the tap weights for the equalizer based on the matrix A and the channel estimate ĥu
The present invention provides a novel technique for forming a more accurate estimate of the channel impulse response.
In accordance with one aspect of the present invention, a method for estimating a channel comprises the following: cross-correlating a known training sequence with received training data to produce a cross-correlation vector, wherein the cross-correlation vector is characterized by a noise component resulting from the finiteness of the cross-correlation; calculating a threshold value that is a fraction of the strength of the main peak of the cross-correlation vector; and, iteratively selecting, scaling, and subtracting correction vectors from a set of correction vectors based on the known training sequence, wherein the correction vectors in the set of pre-stored correction vectors are related to shifted versions of the noise component, and wherein such selections are based on cross-correlation peaks that are above the threshold value to produce a succession of channel estimates of improved accuracy.
In accordance with another aspect of the present invention, a method for estimating a channel comprises the following: (a) cross-correlating a known training sequence with received training data to produce a cross-correlation vector, wherein the cross-correlation vector is characterized by a noise component resulting from the finiteness of the cross-correlation; (b) calculating a threshold value that is a fraction of the strength of the main peak of the cross-correlation vector; (c) selecting and scaling in one step a subset of correction vectors from a set of pre-stored correction vectors based on the known training sequence, wherein the subset of correction vectors is selected based on the threshold value; (d) simultaneous-ly subtracting all of the selected and scaled correction vectors from the cross-correlation vector to produce a new channel estimate; (e) reducing the threshold value by a fixed factor; and, (f) iteratively repeating (c)-(e) until the 2-norm of the difference between the new channel estimate and a previous channel estimate is not greater than a given value.
These and other features and advantages will become more apparent from a detailed consideration of the invention when taken in conjunction with the drawings in which:
Equation (4) results in a cross-correlation vector h having L=La+Lc+1 elements. The inventors have recognized that, due to the finiteness of the correlation operation as represented by equation (4), the cross-correlation vector h is characterized by an a prior known noise component in the main path and in each reflected (ghost) path in proportion to the relative gain in each respective path. The inventors have also recognized that the vector h may be more accurately estimated by compensating for this noise component.
In general, this compensation is accomplished by deriving a representation of the noise component and by iteratively subtracting it from the main and each dominant reflected path detected in the initial (raw) channel impulse estimate, while taking advantage of a thresholding operation to allow for a reasonable termination of the iterative process.
The channel estimate h may be corrected in three steps. In the first step, the correction vector matrix to be permanently stored in the receiver is found. The training sequence vector s of length L is given by equation (1) above. The matrix A is assembled from values of the vector s as given by equation (2).
The L×L training sequence auto-correlation matrix Rsq can then be computed from the matrix A using the following equation:
Rsq=ATA (5)
A matrix Rsqn containing elements given by the following equation can then be defined:
where i=0, 1, . . . , (L−1), where j=0, 1, . . . , (L−1), and where ∥s∥22 is the square of the 2-norm of the vector s, as above. The matrix Rsqn is permanently stored in the receiver and its columns form a set of shifted and truncated correction vectors.
In the second step, the raw channel estimate ĥu is found according to equation (4) by cross-correlating the known training sequence in the form of the matrix A with the received training vector y that is given by equation (3). As previously explained, the raw channel estimate in the form of the cross-correlation vector ĥu may contain a substantial amount of baseline noise due to the effect of the finiteness of the cross-correlation. As described above, the channel impulse response may be defined as having a length L such that L=(La+Lc+1), where La is the length of the anti-causal portion of the channel impulse response and Lc is the length of the causal portion of the channel impulse response.
In the third step of correcting the channel estimate, the baseline noise is reduced from the raw estimate using Algorithm 1 set out below or, alternatively, the baseline noise is reduced from the raw estimate using Algorithm 2 also set out below.
Algorithm 1 involves iteratively subtracting shifted and scaled versions of the correction vectors given by the columns of the matrix Rsqn from the channel estimate in order to reduce the baseline noise due to the finiteness of the correlation used in calculating the raw channel estimate. Ghost paths in the raw channel estimate must have a strength above a given threshold in order to be selected for a noise reduction iteration.
Algorithm 1: Iterative Cleaning Algorithm for Each Path
In the first line of the algorithm, a threshold value threshold is calculated such that the threshold value threshold is a fraction α of the strength of the main peak ĥu[0] of the cross-correlation vector ĥu. The fraction α, for example, may be 0.15. Also, in the first line of the algorithm, a vector he is set equal to the cross-correlation vector ĥu.
In the second line of the algorithm, a pre-stored correction vector, i.e., column La, is selected from the matrix Rsqn that contains a set of such correction vectors. Column La corresponds to the main peak of the channel estimate. As indicated above, the matrix Rsqn is based on the autocorrelation of the known training sequence and contains a set of correction vectors that are related to shifted versions of the noise component. The pre-stored correction vector, i.e., column La, is scaled by the main peak he[0] of the vector he, and this scaled pre-stored correction vector, i.e., he[0] Rsqn[:, La] is subtracted from the vector he to produce a new vector he.
In the loop defined by the third through the tenth lines of the algorithm, the next largest cross-correlation peak at location n−La is selected from the cross-correlation vector ĥu. If the peak at location n−La in the vector he is greater than the threshold value threshold, then column n−La from the matrix Rsqn is scaled by the peak from the vector he at location n−La and that scaled column, he[n−La]Rsqn[:, n], is subtracted from the vector he determined in the second line of the algorithm to produce a new vector he. The loop in lines three through ten of algorithm is repeated until the vector he contains no peaks greater than the threshold value threshold. Accordingly, the loop iterates to produce a succession of channel estimates h of improved accuracy. The final vector he at the end of the iterations is the cleansed version of the raw channel estimate ĥu.
An alternative method for improving the channel impulse response estimate is in the form of Algorithm 2. Algorithm 2 involves the simultaneous subtracting of multiple shifted and scaled correction vectors (the columns of the matrix Rsqn) from the channel estimate. As in the case of Algorithm 1, Algorithm 2 starts with the raw channel estimate ĥu and the matrix Rsqn as before. Algorithm 2 then cleans the raw channel estimate noise due to all ghost paths having a strength above a given threshold all at once (in a single operation). Furthermore, Algorithm 2 is extended so that it operates multiple times, each time lowering the threshold, thus revealing more ghost paths in the resultant channel estimate allowing more baseline noise to be removed.
Algorithm 2: Iterative Cleaning Algorithm for All Paths at a Time
As in the case of Algorithm 1, the cross-correlation vector ĥu and the matrix Rsqn are inputs to Algorithm 2.
In the first line, a vector he is set equal to the cross-correlation vector ĥu and a vector hprev is set equal to he.
In the second line of Algorithm 2, a predetermined change factor δ is set to a value much closer to 0 than to 1. A typical value for δ may be 0.02. The predetermined change factor δ can be stored in memory or otherwise.
In the third line, a threshold value threshold, i.e., α ĥu[0], is calculated as a fraction α of the strength of the main peak ĥu[0] of the cross-correlation vector ĥu. A typical value for the fraction α is 0.15. The fraction α can be stored in memory or otherwise.
In the fourth line, a threshold reduction factor λ is set to a value less than 1. A typical value for the threshold reduction factor λ is 0.9. The threshold reduction factor λ can be stored in memory or otherwise.
Lines five through twenty form a loop.
In the sixth through twelfth lines of the loop, a vector he,th having k elements is defined such that each element k in the vector he,th is set equal to its corresponding element k of the vector he if the corresponding element k of the vector he is greater than the threshold α ĥu[0] and is otherwise set equal to zero.
In the thirteenth line, the correction vectors in the matrix Rsqn are scaled by he,th in one step according to (Rsqn)The,th. Because some of the elements in he,th are likely to be zero as a result of the operations performed in the sixth through twelfth lines, the operation (Rsqn)The,th both selects and scales the correction vectors in the matrix Rsqn. The selected and scaled correction vectors are then simultaneously subtracted from the cross correlation vector ĥu to produce a new vector he.
In the fourteenth through nineteenth lines, if the 2-norm of the difference between this new vector he and the previous vector he, i.e., hprev, is greater than the predetermined change factor δ, then (i) the vector hprev is set equal to the new vector he determined in the thirteenth line, (ii) a new threshold value threshold is determined by reducing the previous threshold value by the threshold reduction factor λ, and (iii) the loop consisting of the sixth through the nineteenth lines is repeated. Indeed, the loop is iteratively repeated until the 2-norm of the difference between the vectors he and hprev is not greater than the given value of δ.
As shown in
A block 44 cleans the “noise,” which is caused by the finiteness of the cross correlation, from the raw channel estimate ĥu in order to produce the cleansed channel estimate he using either of the algorithms described above. The block 44 supplies the cleansed channel estimate he to a block 46 that determines the initial minimum mean square error (MMSE) tap weights gFF and gFB utilizing well known methods, such as those described above. The block 46 supplies the tap weights gFF to the feed forward filter 12 and supplies the tap weights gFB to the feedback filter 14.
Modifications of the present invention will occur to those practicing in the art of the present invention. Accordingly, the description of the present invention is to be construed as illustrative only and is for the purpose of teaching those skilled in the art the best mode of carrying out the invention. The details may be varied substantially without departing from the spirit of the invention, and the exclusive use of all modifications which are within the scope of the appended claims is reserved.
Number | Name | Date | Kind |
---|---|---|---|
3136432 | Nicoll et al. | Jun 1964 | A |
5117291 | Fadavi-Ardekani et al. | May 1992 | A |
5526378 | Knutson et al. | Jun 1996 | A |
6954495 | Piirainen | Oct 2005 | B2 |
7072392 | Xia et al. | Jul 2006 | B2 |
Number | Date | Country | |
---|---|---|---|
20060039460 A1 | Feb 2006 | US |