In the code-division multiple access (CDMA) downlink (base station to mobile station communication link), equalization can restore the orthogonality lost in multipath channels, and exceed the performance attained by a Rake receiver. For practical implementation of the equalizers, two forms of an adaptive least-mean-square (LMS) algorithm have been proposed. Both forms operate on the individual received chips, however, the straightforward LMS algorithm updates the weights at every chip time, whereas the second approach (called “LMS-G”) performs an extra correlation at the equalizer output and updates the weights at the symbol rate. It has also been shown that with careful adjustment of the LMS step size, μ, the LMS-G algorithm is superior for both SISO (single input single output) and MIMO (multiple input multiple output) equalizers.
Unfortunately, the adaptive algorithms have fairly high complexity in the MIMO case, due to the large number (M N) of parallel filters required (where M is the number of transmit antennas and N the number of receive antennas in the MIMO system). The convergence time of the LMS-G algorithm for the channels of interest is 3 msec (for a 4×4 equalizer on the TU (Typical Urban) channel) which restricts its use to slowly moving mobile terminals.
Application of LMS algorithm in the frequency domain for a SISO TDMA (time division multiple access) system has also been proposed. This so-called FLMS (frequency LMS) algorithm operates in a block mode, using either overlap-add or overlap-save to perform the time domain linear convolutions. FLMS can be both less complex than ordinary LMS and offer faster convergence when an individual step-size is chosen for each frequency bin. The so-called TLMS (transform domain LMS) algorithms operate in a sample-by-sample mode and have substantially greater complexity than FLMS.
According to the present invention, the block mode FLMS algorithm using overlap-save has been adapted for use in a CDMA system by extending the algorithm to include an extra correlator on the pilot code or signal. This new algorithm may be referred to as FLMS-G. Namely, the FLMS algorithm is trained and converged using the known pilot signal of the CDMA system. This permits adaptive adjustment of the FLMS set of frequency domain weights at the symbol rate of the equalized signal. Additionally, according to the present invention, the new FLMS-G is further modified for application to MIMO transmission and reception.
The present invention further provides a significant reduction in convergence time, particularly, for MIMO equalizers when the step size matrix of the FLMS algorithm is generalized to include terms corresponding to the spatial cross-spectrums.
According to one embodiment of the present invention, a method of receiver processing of CDMA signals in a CDMA system includes first converting a received signal in the time domain to a received signal in the frequency domain, and equalizing the received signal in the frequency domain using a set of frequency domain weights. The equalized received signal in the frequency domain is converted to an equalized received signal in the time domain. The set of frequency domain weights are adaptively adjusted at a symbol rate of the received signal in the time domain based on an error signal produced from the received signal in the frequency domain and a frequency domain representation of a known pilot signal of the CDMA system.
The present invention will become more fully understood from the detailed description given herein below and the accompanying drawings, wherein like elements are represented by like reference numerals, which are given by way of illustration only and thus are not limiting of the present invention and wherein:
To better understand the present invention, the time domain version of the LMS-G algorithm will be reviewed, followed by an explanation of the derivation for the FLMS-G algorithm according to the present invention. Then SISO and MIMO equalizer implementations of the new FLMS-G algorithm according to the present invention will be described.
Review of LMS-G Algorithm
As discussed above, a time domain chip-level equalizer followed by an additional pilot-channel correlator, which updates at the symbol rate, has been proposed. This LMS-G algorithm has also been used for the MIMO CDMA case with code re-use across antennas. In this section, this (time-domain) LMS-G algorithm, for SISO and for MIMO channels, will be briefly reviewed.
The equalizer output the k-th chip is yk=rkTwj, where rk is the received vector and wj the equalizer weight vector as expressed below,
rk=[r(k−E+1), . . . , r(k−1),r(k)]T
wj=[w(0), w(1), . . . , w(E−1)]T (2.1)
and where the equalizer length is E chips. Note that j is an index for the equalizer updates, which occurs at a multiple of the symbol rate, j=└(k+1)/(BG)┘, where G is the number of chips per symbol, and B is the number of pilot symbols per update. For simplicity, assume E=BG.
The equalizer output is despread with B consecutive pilot symbols. The despreader output at time j is aj=pjHRjwj, where
pj=[p(k−d), p(k−d+1), . . . , p(k−d+BG−1))]T
Rj=[rk+BG-1 rk+BG-2 . . . rk+BG-E]BG×E (2.2)
Here, p(k) denotes the pilot chip at time k, and 0≦d<E−1 is a delay that a system designer is free to choose. The error at the j-th update is defined as,
ej=aj−BGAp 2.21
where Ap is the amplitude of the pilot signal. Defining the cost function J=∥ej∥2 and taking the derivative w.r.t. wj, the LMS-G algorithm is derived as,
wj−1=wj+μRjHpj[GAp−aj] (2.3)
where μ is the (scalar) LMS step-size.
This basic procedure can be extended to MIMO channels. A separate equalizer is used for each of the M transmitters (nothing is gained by a “joint” procedure that uses all M pilots simultaneously). The N FIR filters (one per receive antenna) making the equalizer are,
wj=[wm,1T, wm,2T, . . . , wm,NT]
whose subcomponents are analogous to equation (2.1). Then the received signal is grouped into,
Rj=[R1,j,R2,j, . . . , RN,j]
where each subcomponent is analogous to equation (2.2) for each receive antenna. The MIMO LMS-G algorithm is again given by (2.3), where the m-th pilot signal is used in pj.
Derivation of FLMA-G Algorithm
To derive the new FLMS-G procedure according to the present invention for SISO channels, note that the terms RjHpj and Rjwj correspond to linear convolutions, which may be converted to circular convolutions by “embedding” them in circulant matrices, e.g.,
The lower left quadrant of this circulant matrix is identical to Rj in equation (2.2). The last row of matrix C is obtained from Rj beginning in the lower left corner and moving right along the last row, collecting samples in reverse-time order until reaching r(k+BG−2E). Each higher row of C is the left circular shift of the preceding row. These linear convolutions may be efficiently implemented by taking the FFT of the first column C (denoted c1) and computing,
The symbol ⊙ denotes “element-by-element” multiplication. The “save” output of equation (3.2) corresponds to Rjwj. Similar reasoning gives an expression for RjHpj, however, it is necessary to take the conjugate of the result.
For frequency-domain equalization according to the present invention, the scalar step-size, μ, in equation (2.3) may be generalized to a diagonal matrix Dj whose elements are computed adaptively as,
Dl=μPj−1
Pj=(1−β)Pj−1+β diag(|FFT{rj−1}|2) (3.3)
where diag (•) denotes a diagonal matrix, the norm is taken per-element, and β is a forgetting factor set by the system designer based on empirical study (e.g., the forgetting factor may have a value of 0.05). This generalization is responsible for the improved convergence speed of FLMS-G.
According to one exemplary embodiment, FLMS-G receiver processing of CDMA signals according to the present invention includes the steps of:
The FLMS-G receiver processing method described above requires 3 FFT operations per update (each of length 2E) .
The extension to MIMO is straightforward, as was shown above for LMS-G. A beneficial simplification results from summing the spatial filters in the frequency-domain, drastically reducing the number of IFFTs needed. Following equation (3.3), the MIMO step size matrix is diagonal, with elements that correspond to the power spectrum of the signals received on each of the N antennas. This will be described in detail in the next section below.
Improvement Using Cross-Spectrum
By analogy to the recursive-least-squares (RLS) algorithm, we can see that the “optimal” step size matrix is the inverse of the complete covariance matrix,Ropt=E{{overscore (y)}{overscore (y)}H, {overscore (y)}=[{overscore (y)}1T, . . . , {overscore (y)}1T, . . . , {overscore (y)}NT]t, and this may be approximated by taking only the diagonal elements so the resulting matrix is easy to invert. In the previous sections, the subscript index represented a time index. However, in this section and the equation given below, the subscript index represent an index on the number of receive antennas N. A better approximation results if the cross-spectrum terms are also included, leading to an über-matrix of diagonal matrices as shown in equation 4.1 below.
where N is the number of receive antennas and indices i and n each index a particular receive antenna.
The improved step size matrix is then D=μ(ÜD)−1. The structure of the ÜD matrix makes it easy to invert.
SISO Implementation of FLMS-G
Next, a SISO implementation of FLMS-G will be described with respect to
are converted to the frequency domain by a first converter 10. A first multiplier 12 obtains the product {overscore (z)}j between the received signal {overscore (y)}j in the frequency domain and the set of frequency domain weights {overscore (w)}j to produce the equalized received signal in the frequency domain.
A second converter 14 converts the signal {overscore (z)}j to the time domain. A second of the E chips in the time domain dot product serve as the equalized received signal that is output by the equalizer. The inner product or dot product of this equalized received signal and the chips of the known pilot signal for the CDMA system is obtained by a second multiplier 16. The output of the second multiplier 16 results in an estimate of a pilot symbol amplitude from the equalized received signal in the time domain.
A subtractor 18 subtracts the amplitude of the pilot signal GAp from the output of the second multiplier 16. An inverter 20 inverts the output of the subtractor 18 to produce a scalar that represents a difference in amplitude between the estimated pilot symbol amplitude and a known amplitude of the known pilot signal in the CDMA system.
A third converter 22 obtains the conjugate of the output from the first converter 10, and a fourth converter 24 converts E zero chips and E chips of the known pilot signal to the frequency domain. A third multiplier 26 mixes this frequency domain version of the pilot signal with the conjugate of the output from the first converter 10. The resulting output indicates a direction of an error in the equalization. The output of the inverter 20 provides the magnitude of this error. A fourth multiplier 28 combines the two to obtain the error signal{overscore (g)}j.
A step matrix calculator 30 generates the diagonal matrix Dj according to equation 3.3. A fifth multiplier 32 multiplies this diagonal matrix and error signal. This affects the error signal per tone (i.e., frequency), so that the error signal from weak tones may be boosted. An adder 34 adds the output of the fifth multiplier 32 and output of the fifth multiplier delayed by a delay 36 to generate the set of frequency domain weights.
MIMO Implementation of FLMS-G
Next, a MIMO implementation of FLMS-G will be described with respect to
The structure for generating and applying the sets of frequency domain weights includes a first set of multipliers 50. Each multiplier in the first set of multipliers 50 multiplies a respective one of the received signals in the frequency domain by a respective set of frequency domain weights. An adder 52 adds the output of each multiplier in the first set of multipliers 50. From the output of the adder 52, the equalized received signal and the magnitude of the error signal are produced in the same manner described above with respect to
Each converter in a set of converters 54 obtains the conjugate of a respective received signal in the frequency domain, and a converter 24 converts E zero chips and E chips of the pilot signal associated with this structure to the frequency domain (in this case the pilot signal of the mth transmit antenna). A second set of multipliers 56 mixes this frequency domain version of the pilot signal with each conjugate of the output from the set of converters 54. The resulting outputs each indicate a direction of an error in the equalization. The output of the inverter 20 provides the magnitude of this error. Each multiplier in a third set of multipliers 58 combines the output from a respective one of the third set of multipliers 56 and the output of the inverter 20 to generate an error signal.
An uber matrix calculator 60 generates a set of power-spectra and cross-power spectra are generated by multiplying all pairs of received frequency-domain inputs and talking time averages (see eqn 4.1 ). The individual spectra are arranged as diagonal matrices, and then an “uber-diagonal” matrix is formed. The uber matrix calculator 60 produces the inverse of the uber-diagonal matrix as the step-size matrix, applies this to a matrix multiplier 62. The matrix multiplier 62 performs matrix multiplication between the step size matrix and the respective error signals. This affects each error signals per tone (i.e., frequency), so that the error signal from weak tones may be boosted. As will be appreciated, the matrix multiplication produces an output vector for each error signal. Each adder in a set of adders 64 adds a respective output from the matrix multiplier 62 and the respective output of the matrix multiplier 62 delayed by a respective delay in a set of delays 66 to generate a set of frequency domain weights.
The method and apparatuses according to the present invention significantly reduce the complexity of the equalization process by performing operations in the frequency domain. This is particularly true with a MIMO CDMA system. Furthermore, the uber-diagonal matrix of the present invention provides for improved convergence time, again particularly with a MIMO CDMA system.
The invention being thus described, it will be obvious that the same may be varied in many ways. For example, using FFT operations of length 2E chips and performing the skip/save operation may not be strictly necessary. Instead, only the current E chips of the received signal may be used (with a corresponding decrease in the number of chips in the other operations as well). Such variations are not to be regarded as a departure from the invention, and all such modifications are intended to be included within the scope of the invention.