The present invention relates to a normalized least means square (NLMS) equalizer used in a code division multiple access (CDMA) receiver. More particularly, the present invention relates to an equalizer including a plurality of equalizer filters which use pre-equalization despreading for reduced complexity of both the equalizer and the receiver.
Chip-level equalizers (CLE) are suitable candidates for CDMA receivers, such as those used in wireless transmit/receive units (WTRUs) and base stations. An NLMS-based CLE receiver offers superior performance for high data rate services such as high speed downlink packet access (HSDPA) over a Rake receiver. A typical NLMS receiver comprises an equalizer filter and an NLMS algorithm. The equalizer filter is typically a finite impulse response (FIR) filter.
The NLMS algorithm is used for tap-weights generation. It generates appropriate tap-weights used by the equalizer filter and updates them appropriately and iteratively in a timely basis. Typically, tap-weights generation includes error signal computation, vector norm calculation and leaky integration to generate and update the tap-weights.
The high complexity of the CLE is due to the over-sampling processing in the CLE. A typical process in the CLE equalizer includes filtering, tap-weight vector updating, vector norm square computing, or the like, which all operate at two or more times the chip rate. Two times the chip rate over-sampling processing induces twice as much complexity as the chip rate non-over-sampling processing in the equalizer filter.
Particularly, multiplications of a tap-input vector with tap-weights which are performed on a chip-by-chip basis are usually the component with major complexity and results in high complexity.
The present invention is related to an NLMS equalizer including two equalizer filters. In one embodiment, a single correction term generator is used to generate correction terms for tap coefficient updates of each of the equalizer filters based on a pilot signal. In another embodiment, two different correction term generators are used to generate correction terms for each of the equalizer filters, whereby one of the correction term generators uses data received from a hard decision unit at the output of one of the equalizer filters to generate correction terms for both of the equalizer filters.
A more detailed understanding of the invention may be had from the following description, given by way of example and to be understood in conjunction with the accompanying drawings wherein:
The preferred embodiments will be described with reference to the drawing figures where like numerals represent like elements throughout.
Hereafter, the terminology “WTRU” includes but is not limited to a user equipment (UE), a mobile station, a laptop, a personal data assistant (PDA), a fixed or mobile subscriber unit, a pager, or any other type of device capable of operating in a wireless environment. When referred to hereafter, the terminology “base station” includes but is not limited to an access point (AP), a Node-B, a site controller or any other type of interfacing device in a wireless environment.
The features of the present invention may be incorporated into an integrated circuit (IC) or be configured in a circuit comprising a multitude of interconnecting components.
Hereafter, the present invention will be explained with reference to an NLMS algorithm. However, it should be noted that any type of adaptive equalization or filtering, such as least mean square (LMS), Griffith's algorithm, channel estimation based NLMS (CE-NLMS), and other iterative or recursive algorithms may be used.
In accordance with the present invention, despreading is performed on a sample data stream before being equalized by an equalizer filter, thus reducing the complexity of the equalizer filter and other components. Equations (1) and (2) present the mathematically equivalent models of equalization and despreading processes.
SF denotes a spreading factor, L, denotes the number of tap-weights in the adaptive equalizer filter, ci, i=1, 2, . . . , SF denotes the i-th element of spreading code, xi, i=1, 2, . . . , L, . . . denotes the tap-input vector and wi, i=1, 2, . . . , L denotes the i-th tap-weight. Furthermore, yi, i=1, 2, . . . , SF denotes the results of the multiplication of tap-input matrix and tap-weight vector, and zi, i=1, 2, . . . , L denotes the results of the despreading of the tap-input matrix with the spreading code. Equation (1) is mathematically equivalent to Equation (2).
In Equation (1), the tap-input matrix is first multiplied with a tap-weight vector. This results in vector {right arrow over (y)}=[yi], i=1, 2, . . . , SF as follows:
Despreading is then followed to despread the vector {right arrow over (y)}=[yi], i=1, 2, . . . , SF such that:
The computation in Equations (3) and (4) requires SF×L complex multiplications and SF×L complex additions.
Equation (2) is a more efficient method to perform the equalization and despreading, which is utilized by the present invention. First, the tap-input matrix is despread with spreading code, which results in vector {right arrow over (z)}=[zi], i=1, 2, . . . , L as follows:
The despread output is then multiplied with tap-weight vector as follows:
Output 2 is equal to output 1. Since the despreading of a tap-input vector with a spreading code results in only a sign change or a phase rotation, as shown in Equation (2), instead of the complex multiplication and addition functions performed in Equation (1), the complexity of Equation (2) is much less than the complexity in Equation (1). The computation of output 2 in Equations (5) and (6) requires only L complex multiplications and SF×L complex additions. The number of complex multiplications in Equation (2) is reduced by a factor of
from SF×L to L. In general, the computational complexity increases with the number of computations, especially multiplications. The present invention makes NLMS more efficient in terms of the number of computations.
Referring to
The chips accumulator 116 accumulates the descrambled parallel vectors signal 112 to generate an accumulated parallel vectors signal 117, which is input to the P→S converter 118 and the correction term generator 138. The accumulated parallel vectors signal 117 is converted by the P→S converter 118 to an accumulated serial vectors signal 120, which is input to the equalizer filter 122.
The equalizer filter 122 generates an equalized signal 130 based in part on the accumulated serial vectors signal 120. The equalized signal 130 is then subtracted from a pilot symbol reference signal 134 by the summer 132 to generate an error signal 136 which is input to the correction term generator 138. The correction term generator 138 includes a vector norm square estimator (not shown) for generating a vector norm square of the accumulated parallel vectors signal 117 and for generating a pilot-directed correction term 140. The correction term generator 138 generates the pilot-directed correction term 140 based on the error signal 136 and the accumulated parallel vectors signal 117. The equalized signal 130 is further based on the pilot-directed correction term 140.
The chips accumulator 144 accumulates the despread descrambled parallel vector signal 115 to generate a despread descrambled parallel vector signal 146 which is input to the P→S converter 148. The despread descrambled parallel vector signal 146 is converted by the P→S converter 148 to a despread descrambled serial signal 150 which is input to the equalizer filter 152. The equalizer filter 152 outputs an equalized signal 160 based on the despread descrambled serial vector signal 150 and the pilot-directed correction term 140.
For multiple codes reception of data, the multiplier 113, the chips accumulator 144, the P→S converter 148 and the equalizer filter 152 may need to be run sequentially in serial for all codes. Alternatively, the multiple data processing branches for the multiplier 113, the chips accumulator 144, the P→S converter 148 and the equalizer filter 152 may also be simultaneously implemented in parallel.
In order for the correction term generator 138 to generate pilot-directed correction term 140 for tap coefficient updates of the respective equalizers 122, 152, the inputs for μp, ep and Xud are required. μp is the step size. ep is the error signal which is the differential signal between an equalized signal and a reference signal, which typically is used in the form of a pilot signal. Xud is the received signal after descrambling and despreading. ∥Xud∥ is the norm of the descrambled and despread signal Xud.
The pre-equalization despreading approach is applied to both pilot-directed or pilot/data-directed equalizers for reducing the complexity of the equalizers as previously described.
The present invention implements single receive antenna in conjunction with adaptive equalizers as described previously and shown in
The present invention implements receive diversity in conjunction with an adaptive equalizer, which improves the receiver performance. In the case when receiver diversity is implemented, the input signal 102 is operating at 4× chip rate (i.e., 4×=2×times 2×, in which 2× chip rate accounts for over-sampling and the other 2× for receive antenna diversity). The S→P to vector converter 104 has signals shift in at 4× chip rate and output vectors at 1× chip rate. The signals 120 and 150 are operating at 2× chip rate. The equalizer filters 122, 152 are joint equalizer filters which have signals input at 2× chip rate and output at 1× symbol rate. A joint equalizer filter coefficient vector adaptation scheme in accordance with the present invention is described below.
A weight vector {right arrow over (w)}n, jo int is defined for the equalizer filter as a union of multiple component weight vectors. Each component weight vector corresponds to data collected by a different antenna. Any permutation of elements from component vectors may comprise the joint weight vector so long as the permutation properly reflects the order in which data enters the joint NLMS equalizer. As these are mathematically equivalent, the permutation may be chosen for notational convenience. For example, for two antennas, the joint weight vector {right arrow over (w)}n, jo int can be defined as follows:
{right arrow over (w)}n,jo int=[{right arrow over (w)}n,1T,{right arrow over (w)}n,2T]T Equation (7)
where ( )T denotes a transpose operation. The total number of taps of the equalizer filter is denoted by L. {right arrow over (w)}n, jo int is a column vector.
For the chosen notation in Equation (7), the notation for the joint update vector {right arrow over (x)}n, jo int is defined as follows:
{right arrow over (x)}n,jo int=[{right arrow over (x)}n1,{right arrow over (x)}n2], Equation (8)
where {right arrow over (x)}n1,{right arrow over (x)}n2 are vectors based on the samples received from antenna 1 and antenna 2, respectively. {right arrow over (x)}n, jo int is a row vector.
The filter coefficient adaptation for the joint NLMS equalizer can then be processed in a usual way for an NLMS equalizer. For example, the updated coefficient vector can be obtained as follows:
where ( )H denotes a transpose conjugate operation, d[n] is the reference signal for NLMS and ε is a small number used to prevent from dividing by zero. The parameter α is a weighting parameter and μ is a scale factor of error signal. The μ can be estimated based on the vehicle speed and signal-to-interference and noise ratio (SINR) and interpolated to obtain a continuous estimation.
For pilot-directed NLMS, d[n] can be a pilot signal, training signal, or other known pattern signals. The signals may be either despread signals with pre-determined despreading factors, or non-despread signals. Similarly, for data-directed NLMS, d[n] can be despread or non-despread data symbols. The tap correction terms {right arrow over (Δ)}n, jo int are computed as follows:
where the factor en, jo int is a joint error signal and is computed by subtracting the equalizer filter output from the reference signal d[n] as follows:
en,jo int=d[n]−{right arrow over (x)}n,jo int{right arrow over (w)}n,jo int. Equation (11)
In the case of no receiver diversity, the new tap coefficients for the next iteration are obtained by adding the tap correction terms {right arrow over (Δ)}n to the (weighted) tap coefficients of the previous iteration. The weighting mechanism can be characterized by a parameter α (alpha) formulated as follows:
{right arrow over (w)}n+1=α·{right arrow over (w)}n+{right arrow over (Δ)}n Equation (12)
When the receiver diversity is implemented, the joint tap update vector in Equation (9) is simply obtained by substituting the joint weight vector {right arrow over (w)}n, jo int for {right arrow over (w)}n, the joint update vector {right arrow over (x)}n, jo int for {right arrow over (x)}n and joint tap correction terms {right arrow over (Δ)}n, jo int for {right arrow over (Δ)}n into the standard and no receiver diversity NLMS equation. Equation (9) uses the joint equalizer output and subtracts it from the desired signal or pilot signal to produce joint estimation error. The vector norm square for the input signal is a joint vector norm square. The joint estimation error together with the complex conjugate of input signal, μ and vector norm square of input signal produces a correction term which is added to the tap-weight vector of the iteration n to produce the tap-weight vector of iteration n+1, the updated tap-weight vector.
Referring still to
which is added, in the equalizer filters 122, 152 to the filter coefficients of the previous iteration to generate updated filter coefficients for the next iteration. The pilot-directed NLMS equalizer 100 outputs an equalized signal 160.
Alternatively, the correction term generator 138 may generate the pilot-directed correction terms 140 based on the correction term
The variable ε is a relatively small number that is used to improve the numerical properties and prevent the fixed-point computation from overflow when the correction terms are generated.
Referring to
The chips accumulator 116 accumulates the descrambled parallel vectors signal 112 to generate an accumulated parallel vectors signal 117 which is input to the P→S converter 118 and the correction term generator 138. The accumulated parallel vectors signal 117 is converted by the P→S converter 118 to an accumulated serial vectors signal 120, which is input to the equalizer filter 222.
The equalizer filter 222 generates an equalized signal 130 based in part on the accumulated serial vectors signal 120. The equalized signal 130 is then subtracted from a pilot symbol reference signal 134 by the summer 132 to generate an error signal 136 which is input to the correction term generator 138. The correction term generator 138 includes a vector norm square estimator (not shown) for generating a vector norm square of the accumulated parallel vectors signal 117 and for generating a pilot-directed correction term 140. The correction term generator 138 generates the pilot-directed correction term 140 based on the error signal 136 and the accumulated parallel vectors signal 117.
For multiple codes reception of data, the multiplier 113, the chips accumulator 144, the P→S converter 148, the equalizer filter 152, the hard decision unit 262, the summer 266 and the correction term generator 270 may need to be run sequentially in serial for all codes. Alternatively, the multiple data processing branches for the multiplier 113, the chips accumulator 144, the P→S converter 148, the equalizer filter 152, the hard decision unit 262, the summer 266 and the correction term generator 270 may also be simultaneously implemented in parallel.
In order for the correction term generator 138 to generate pilot-directed correction terms 140 for tap coefficient updates of the respective equalizers 222, 252, the inputs for μp, ep and Xud are required. μp is the step size. ep is the error signal which is the differential signal between an equalized signal and a reference signal, which typically is used in the form of a pilot signal. Xud is the received signal after descrambling and despreading. ∥Xud∥ is the norm of the descrambled and despread signal Xud.
The correction term generator 138 may generate the pilot-directed correction terms 140 based on the correction term
which is added, in the equalizer filters 222, 252 to the filter coefficients of the previous iteration to generate updated filter coefficients for the next iteration.
Alternatively, the correction term generator 138 may generate the pilot-directed correction terms 140 based on the correction term
The variable ε is a relatively small number that is used to improve the numerical properties and prevent the fixed-point computation from overflow when the correction term is generated.
Referring still to
The equalizer filter 252 feeds the equalized signal 260 to the hard decision unit 262 and the summer 266. The hard decision 262 demodulates the equalized signal 260 (i.e., it restores the original transmitted signal constellation, for either QPSK, QAM, or the like). The summer 266 subtracts the equalized signal 260 from a hard decision (i.e., data) signal 264 generated by the hard decision unit 262 (or vice versa) to generate an error signal 268 which is input to the correction term generator 270. The correction term generator 270 includes a vector norm square estimator (not shown) for generating a vector norm square of the despread descrambled parallel vectors signal 146 and for generating data-directed correction terms 272 based on the error signal 268 and the despread descrambled parallel vectors signal 146. The data-directed correction terms 272 are updated every data channel symbol duration (i.e., chips equal to data channel DSF). For every CPICH_DSF chip, new pilot-directed tap coefficients 140 are generated using a w=w+pilot correction term or w=alpha×w+pilot_correction_term. Furthermore, for every DATA_DSF chip, new data-directed tap coefficients 272 are generated using a w=w+data correction term or w=alpha×w+data_correction_term. In the case when CPICH_DSF and DATA_DSF are the same, the new equalizer tap coefficients are generated and updated simultaneously for pilot- and data-directed equalization using w=w+pilot_correction_term+data_correction_term or w=alpha×w+pilot_correction_term+data_correction_term.
Each of the equalizer signals 130, 260 are further based on the pilot-directed correction term 140 and the data-directed correction term 272.
In order for the correction term generator 270 to generate data-directed correction terms 272 for tap coefficient updates of the respective equalizers 222, 252, the inputs for μD, eD and Xud are required. μD is the step size. eD is the error signal which is the differential signal between an equalized signal and a reference signal, which typically is used in the form of a pilot signal. Xud is the received signal 146 after descrambling and despreading. ∥Xud∥ is the norm of the descrambled and despread signal Xud.
The correction term generator 270 may generate the data-directed correction terms 272 based on the correction term
which is added, in the equalizer filters 222, 252, to the filter coefficients of the previous iteration to generate updated filter coefficients for the next iteration.
Alternatively, the correction term generator 270 may generate the data-directed correction terms 272 based on the correction term
The variable ε is a relatively small number that is used to improve the numerical properties and prevent the fixed-point computation from overflow when the correction term is generated.
A pilot-directed equalizer may be used initially, once the equalizer is stable. A data-directed equalizer may then take over equalizer operations previously performed by the pilot-directed equalizer, whereby the pilot-directed equalizer may then be turned off.
Although the features and elements of the present invention are described in the preferred embodiments in particular combinations, each feature or element can be used alone without the other features and elements of the preferred embodiments or in various combinations with or without other features and elements of the present invention.
This application is a continuation of U.S. patent application Ser. No. 11/256,047, filed Oct. 21, 2005, which claims the benefit of U.S. Provisional Application No. 60/625,630, filed Nov. 5, 2004, which is incorporated by reference as if fully set forth.
Number | Name | Date | Kind |
---|---|---|---|
5666378 | Marchetto et al. | Sep 1997 | A |
6175588 | Visotsky et al. | Jan 2001 | B1 |
6215354 | Kolanek et al. | Apr 2001 | B1 |
6628781 | Grundstrom et al. | Sep 2003 | B1 |
6658047 | Komulainen et al. | Dec 2003 | B1 |
6687315 | Keevil et al. | Feb 2004 | B2 |
6798832 | Nakata et al. | Sep 2004 | B1 |
6856648 | Hyll | Feb 2005 | B1 |
7023265 | Helard et al. | Apr 2006 | B1 |
7082159 | Larsson | Jul 2006 | B2 |
7362802 | Saed | Apr 2008 | B2 |
7406122 | Shimobayashi et al. | Jul 2008 | B2 |
20020191568 | Ghosh | Dec 2002 | A1 |
20030066088 | Jung | Apr 2003 | A1 |
20030210646 | Ohseki et al. | Nov 2003 | A1 |
20040213340 | Kuribayashi | Oct 2004 | A1 |
20050100052 | Mailaender et al. | May 2005 | A1 |
20050286622 | Kim et al. | Dec 2005 | A1 |
20060114974 | Zeira et al. | Jun 2006 | A1 |
20090041094 | Ishii | Feb 2009 | A1 |
20090129458 | Pietraski et al. | May 2009 | A1 |
20090290630 | Pietraski et al. | Nov 2009 | A1 |
Number | Date | Country |
---|---|---|
1441484 | Jul 2004 | EP |
2346520 | Aug 2002 | GB |
I220350 | Aug 2004 | TW |
02080379 | Oct 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20090180528 A1 | Jul 2009 | US |
Number | Date | Country | |
---|---|---|---|
60625630 | Nov 2004 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11256047 | Oct 2005 | US |
Child | 12415023 | US |