The present invention relates to spread spectrum communication systems generally and to noise reducing units in mobile handsets of such communication systems in particular.
A conventional spread spectrum signal can be viewed as the result of mixing a narrowband information-bearing signal i[t] with an informationless wideband “spreading” signal p[t] . If Bi and Bp denote the bandwidths of i[t] and p[t], respectively, then the “processing gain” available to the receiver is Bp/Bi. The receiver synchronizes the incoming signal to a locally generated version p0[t] of p[t] and mixes the received signal with p0[t], thereby removing p[t] from the signal and “collapsing” the signal to the “information bandwidth” Bi.
The spreading signal p[t] is typically a coding sequence of some kind, such as a pseudo-random code. In many code division multiple access (CDMA) systems, the code is an M-sequence which has good “noise like” properties yet is very simple to construct.
For example, in the IS-95 standard for cellular communication, the forward channel (base to mobile units) employs, as a spreading code, the product of a 64 chip Walsh code (aimed at separating up to 64 different users per base) and a periodic pseudorandom noise (PN) sequence (aimed at separating the different bases). See TIA/EIA IS-95A “Mobile System-Base Station Compatibility Standard for Dual-Mode Wideband Spread Spectrum Cellular System” Telecommunication Industry Association. Thus, the spreading signal p[t] for each user is its Walsh code combined with the current 64 chips of the PN sequence of its base station.
In order to synchronize the local version p0[t] of the spreading signal with the original version p[t], the base station additionally transmits the current PN sequence via a pilot signal z[t] (the pilot signal z[t] is simply the current PN sequence multiplied by the all one Walsh code). The mobile unit then synchronizes its local code generator to the pilot signal after which the mobile unit can despread the received information bearing signals using its Walsh code and the current PN sequence.
The Walsh codes Wi, I=1, . . . 64 are perfectly orthogonal to each other such that, in a non-dispersive transmission channel, there will be complete separation among the users even despite being transmitted at the same time and on the same transmission frequencies.
Practical channels, however, are time dispersive, resulting in multipath effects where the receiver picks up many echoes of the transmitted signal each having different and randomly varying delays and amplitudes. In such a scenario, the code's orthogonality is destroyed and the users are no longer separated. Consequently, a mobile unit, when attempting to detect only a single user, regards all other channel users (including signals from other base stations) as creators of interference. This contributes to a decrease in signal-to-noise ratio (SNR) and thus, reduces the reception quality of the mobile unit.
In the presence of multipath channels, the mobile units additionally process the informationless pilot signal to identify and track the multipath parameters of the channel. For this purpose, the mobile units include a channel estimator which detects and tracks the attenuation, denoted by channel “tap” ĥi, and the relative delay, denoted by {circumflex over (τ)}i, for each of the main paths. The mobile units then utilize the channel information in their detection operations.
In pilot interference cancellation, estimates of interference from co-channel pilot signals from one or more base stations are formed at the receiver and subtracted out from the received signal in order to improve the detection of the desired signal or even multiple desired signals. Since each receiver sees less effective interference, it may need less transmitted power from the base station to obtain its desired block error rate. This transmit power savings may be used to support more users, or to provide higher data rates. The overall reduction in interference can also provide other benefits, such as increasing coverage area.
Pilot channel interference cancellation is particularly attractive because of its low implementation complexity. The information content and structure of pilot channels are known a priori, which makes accurate estimation and generation of interference terms relatively simple. However, it would be desirable to further reduce the computational complexity of pilot channel interference cancellation techniques.
Thus, there is a need for even less complex techniques for canceling pilot channel interference.
A detector 10, shown in
The signal r(n) is the version of the received signal after the latter has been filtered and down converted to a baseband signal and has been sampled at rate of M samples per chip and N chips per symbol where M and N are typically integers. In the IS-95 CDMA standard, there are 64 chips per symbol n and the chip rate is 1.2288×106 chips per second, i.e. Tchip is about 0.8 μsec.
Synchronizer 13 synchronizes the detector to the PN sequence of the base station and provides the current PN sequence to the rake receiver 12 and the interference processor 20. Channel estimator 14 estimates the channel tap hi and the delay τi associated with each finger. Rake receiver 12 despreads the user data signal of the current user using the user's Walsh code (which is known a priori), the current PN sequence, the estimated channel taps ĥi and the estimated finger delays {circumflex over (τ)}i. Rake receiver 12, shown in more detail in
The received signal r(n) consists of the data signals of all of the active users (of the current base station and possibly of other, neighboring base stations), the pilot signals of at least the current base station and other interference terms caused by different noise sources in transmission, reception, etc. The term “pilot signal” may be used to refer to the pilot signal of the current base station which is, normally, the strongest pilot signal received by the mobile unit.
The interference processor 20 determines the crosstalk interference effect C(n) of the pilot signal on the user data signal X(n). Since the power of the pilot signal is typically significantly larger than that of any other channel user (to ensure that every synchronizer 13 can synchronize to it), removing the interference effect C(n) of the pilot signal (via a subtractor 22) should considerably improve the estimated user data signal X(n). Furthermore, as described hereinbelow, the interference effect is relatively simple to calculate and thus, interference processor 20 can be implemented in a mobile handset where the computational burden is advantageously reduced.
Subtractor 22 removes the interference effect C(n) from the rake receiver output X(n) thereby producing a new version X′ (n) of the data signal. In some embodiments a subtractor 22 may be used within the rake receiver, for example, for each finger, instead of subtracting the total pilot interference from the rake output as shown in
The interference processor 20, shown in
Since the baseband filter taps are known a priori and do not change over time, ρp(k′) can be determined a priori for all possible values of k′ and stored in a lookup table 30. A priori transmitter-receiver shaping filter effect generator 32 determines ρp(k′) as follows:
where k′ typically varies from −LT
Since all Walsh codes and the entire PN sequence are known a priori (the PN sequence is finite and periodic), and since each symbol is transmitted with N values of the PN sequence, ρa (k,n) can also be generated a priori, for all possible values of k and n and stored in a lookup table 34. A priori spreading code cross-correlator 36 determines ρa (k,n) as follows:
qx(m, n)=x_Walsh(m)*PN(m+nN)
x=pilot or user
0≦m≦(L−1) per symbol n
−∞≦n≦∞
PN(m+nN+kQ)=PN(m+nN)∀ m, n, k
where, as defined in the above equation, the pilot and user Walsh codes q(m,n) are sequences of N chips and PN(n) is a periodic extension of a pseudo-random number sequence of length Q where, for the IS-95 standard, Q is 215.
The interference processor 20 additionally comprises a finger crosstalk determiner 38 which receives the estimated channel taps ĥi, and the estimated finger delays {circumflex over (τ)}i, from the channel estimator 14 and utilizes them and the information stored in the two lookup tables 30 and 34 to determine the crosstalk effect of two fingers i,j for the given channel, channel delays and pilot signal.
Specifically, interference processor 20 begins by determining the value of k0′, where k0′={circumflex over (τ)}i−{circumflex over (τ)}j, after which interference processor 20 activates crosstalk effect determiner 38 to determine the crosstalk effect aij(n) as follows:
where the sum is performed for all k and k′ within the ranges around k0′ defined by |k−int(k0′)|<J and |k′−k0|<J, respectively. J is a design parameter and is typically in the range of 1 to 10. The delay differences k′ and k are stepped by steps of one chip, where all delay difference k′ includes the fractional portion of k0′. Thus, if k0′, is, for example, 7.25 chips, then k′ might have values of 5.25, 6.25, 7.25, 8.25 and 9.25 and k might have values 5, 6, 7, 8 and 9.
The quantity ai,j(n) is an estimate of the interference of the pilot signal along finger i to the user signal at finger j. Any number of fingers can be assumed, although three are common. For three fingers, i and j vary from 0 to 2. In the IS-95 standard the Walsh codes are perfectly orthogonal, and the term ai,i(n) is identically zero. However, with non-orthogonal codes, this term is generally non-zero.
To calculate ai,j(n), interference processor 20 retrieves the value of ρp(k,n) for each value of k and for the nth symbol from lookup table 34 and the value of τp(k′) for each value of k′ from lookup table 30. Interference processor 20 activates the crosstalk effect determiner 38 for each set (i,j) of fingers where, for each set, the value of ko′ is first determined as are the ranges of k and k′.
Interference processor 20 additionally comprises a finger interference effect determiner 40 and a total interference effect determiner 42 in one embodiment. Finger interference effect determiner 40 determines the interference effect Bj(n) per finger as:
where the sum is performed over the number of fingers in the channel.
The total interference effect determiner 42 determines the total interference effect C(n) as the sum of the Bj(n). The total interference effect C(n) is the output of interference processor 20. As shown in
By removing the interference effect of the pilot signal, a significant portion, though not all, of the noise which affects the user signal X(n) is removed, thus increasing the performance quality of the decoder 18. Furthermore, the computational burden of interference processor 20 is relatively small, in particular since the two crosscorrelations ρa(k, n) and ρp(k′) can be determined a priori and stored in the lookup tables 30 and 34 in some embodiments. Alternatively, ρa(k, n) can be determined “on-the-fly”, from equation 2, since its computation only involves summation on PN “chips” which, in the IS-95 standard, accept only the values of ±1±j.
Rake receiver 12, shown in
The first finger, known as the 0th finger, serves as the reference finger. The second and third fingers (referred to as the 1st and 2nd fingers), respectively, have delays defined by {circumflex over (τ)}2 and {circumflex over (τ)}2, respectively, relative to the 0th finger. Delays 60 delay the received signal r(n) by their delay relative to the 0th finger. For completion, {circumflex over (τ)}0 is set to zero.
Despreaders 50 despread the received signal r(n) (the 0th finger) or the delayed signal (the 1st and 2nd fingers) via the spreading signal quser. Windowing summer 52 sums the output of despreaders 50 over a window of N samples and divides the result by N. Samplers 54 sample every Nth datapoint. Finger gain multipliers 56 multiply the sampled signal by the complex conjugate of the associated channel tap ĥi. Converters 58 take the real portion of the resultant signal. A summer 62 sums the output of each finger and produces therefrom the data signal X(n).
The rake receiver 12′ of
The data detector 10′ of
Both pilot signals interfere with the transmitted data signal.
The data detector 10′ is similar to data detector 10 of
In summary, the total pilot interference at the output of the rake receiver 12 is:
where:
Bf(n) is the pilot interference corresponding to finger f, defined in Equation 4;
af,p(n) is the pilot interference from the channel tap of finger p on finger f, defined in Equation 3 (As was mentioned earlier, af,p(n)=0 for f=p since the Walsh codes are orthogonal—hence the corresponding elements in Equation 5 need not be calculated.);
ρa(f,p)(k,n) is the crosscorrelation term between the desired user signature at finger f and the pilot signature of finger p, at delay k and for the n-th symbol, defined in Equation 2;
ρp(k′) is the crosscorrelation between the transmit and receive filters, defined in Equation 1.
ĥf is the estimated amplitude/phase of finger f;
ĥp is the estimated amplitude/phase of path p;
F is the number of rake fingers at the receiver;
P is the total number of pilot paths over all paths of all base stations;
k0 is the integer part of {circumflex over (τ)}f−{circumflex over (τ)}p, i.e. the delay in integer multiples of chips between finger f and finger p;
J is a design parameter, as explained in the text following Equation 3.
As can be seen, there are many different elements that need to be calculated and combined to produce the total pilot interference as seen at the rake output for the n-th symbol—Itotal(n). In order to further reduce the computational complexity, several different embodiments for different selection mechanisms are described herein. It is desirable to select those terms in Equation 5 that contribute the most to Itotal(n), thus reducing the computational complexity associated with the calculation of the different terms and reducing the computational complexity associated with their combining into the single term Itotal(n) while minimizing the loss in performance.
While the pilot cancellation mechanism described above is based on cross-correlation calculations, other pilot cancellation mechanisms can be derived based on re-generation of the pilot signals themselves rather than their cross-correlation effects at the rake outputs. The selection mechanisms described below apply to at least some of those pilot cancellation approaches as well.
Also, the same methods described herein below can be utilized when pilot channel interference cancellation is used in conjunction with multi-user detection receivers (known in the art) and in conjunction with interference cancellation receivers (known in the art).
In one embodiment, all terms ĥf*ĥpρa(f,p)(k0+k, n)ρp(k·M−({circumflex over (τ)}f−{circumflex over (τ)}p)) are calculated, then these terms are sorted according to their magnitudes, and finally only the S strongest are used. S is a user defined parameter that allows trading combining complexity with performance.
In another embodiment, all terms ĥf*ĥpρa(f,p)(k0+k, n)ρp(k·M−({circumflex over (τ)}f−{circumflex over (τ)}p)) are calculated, but only those terms that are above a pre-defined threshold TH1 are utilized.
The above two embodiments would indeed reduce the combining complexity, but still all terms need to be generated. A further reduction in performance that avoids generating all the terms, can be obtained by generating the selection decisions based on the channel tap estimates ĥf ĥp, and the cross-correlation between the Tx & Rx filter ρp(k′). The advantage is that the channel taps are normally very slowly varying compared to the symbol rate, and the elements of ρp(k′) are also very slowly varying (even slower than the channel taps). Hence, the selection can be made at a very low rate (e.g. once every 100 symbols); accordingly there is no need to calculate all the cross-correlation terms between the signature sequences and to combine them. Only, those terms that correspond to the selected elements need to be calculated and combined.
Referring to
In yet another embodiment, the different products ĥp*·ĥf are first calculated, then sorted according to their magnitude, and finally only the S largest terms are considered. Therefore, the combining complexity is reduced, but also there is no need to calculate all the cross-correlation terms ρa(f,p)(k, n) that are associated with those products ĥp*·ĥf that were not selected. This saves both combining complexity and cross correlation complexity.
In yet another embodiment, in order to save the need to calculate all the cross-products ĥp*·ĥf, the channel taps ĥf may first be sorted according to their magnitudes, then only cross products of the S1 strongest taps are calculated out of which the S2 largest products are selected.
In yet another embodiment, in addition to the above selection, additional complexity reduction may be achieved by setting the value of J in the term
to be different according to the delay between the p and f fingers. Thus, if the delay between the fingers is close to an integer multiple of Tc, ρp(k′) is close to a Nyquist pulse sampled at the correct sampling instances and hence J may be chosen to be close to zero. As the fractional delay approaches Tc/2, J should be increased to cover the effective time span of ρp(k1).
As yet another embodiment is presented in
For each pilot path the sub-crosstalk terms associated with the desired user code for each finger of the receiver 12, including baseband transmit and receive filter effects, can be determined as indicated in block 76 to compute
or access these values from memory, if they have been precomputed and stored to speed and simplify subsequent computations.
Each of the sub-crosstalk terms may be appropriately weighted with the complex amplitude estimate of the corresponding pilot path to generate
In such case, one or more of the following options may be implemented. In a first option, the finger interference terms resulting from pilot path p interference, may be computed for the selected sub-crosstalk terms, Cf,p. In a second option, the rake-weighted finger interference terms resulting from pilot path p interference, ĥf*ĥpCf,p, may be computed for the selected sub-crosstalk terms, Cf,p. As a third option, the individual rake-weighted sub-crosscorrelation terms ĥ*pĥfρa(f,p)(k0+k, n)·ρp(k·M−({circumflex over (τ)}f−{circumflex over (τ)}p)) are computed.
The first option may be desirable when each finger's pilot interference is subtracted separately. The second and third options may be desirable when the total pilot interference is subtracted from the output of the rake receiver at one time.
Each finger of the receiver 12 then forms an estimate of the pilot interference, by adding up all of the crosscorrelation terms associated with the different pilot paths, as indicated in block 84. Next, the appropriate pilot interference from each finger of the receiver 12 may be subtracted out as indicated in block 86.
In one embodiment each finger's pilot interference may be subtracted separately in block 86. Then for each finger:
In another embodiment, the total pilot interference may be subtracted from the output of the rake received at one time:
The received path/finger amplitudes, ĥf*, ĥp, and the product of the two values, ĥf*ĥp, can also be obtained from the values computed in block 74.
A certain degree of complexity arises from the above-described operations, particularly with respect to the operation set forth in blocks 76, 78 and 84. As an example, assume there are B base stations with L paths per base station. In addition, assume that in taking into account the affect with a baseband filter on the crosscorrelation calculation, we consider T taps of a combined transmit/receive baseband filter. Therefore, the number of operations involved in blocks 76, 78 and 84 are approximately as follows. To determine the weighting for the crosscorrelation terms, (BL-1)LT crosscorrelation computations are needed including (BL-1)LT multiplications and (BL-1)L(T-1) additions. For third generation CDMA systems, these may all be complex-valued operations. The determination of weighted crosscorrelation terms may involve (BL-1)L complex-valued multiplications and the estimate of the pilot interference may involve (BL-2)L complex-valued additions.
If the spreading codes of the pilots and user signals are periodic and there is sufficient memory to store all of the crosscorrelations over the period of codes, some complexity may be reduced by not repeating calculations set forth at block 76 in each symbol. Rather, the stored crosscorrelation values can simply be updated when any change occurs, for example, upon the birth or death of a new finger, or when the relative timing of the received signal paths changes significantly.
The complexity of the pilot interference calculation may be further reduced by selecting only the strongest crosscorrelation terms to be estimated and processed. In accordance with one embodiment, the selection of the crosscorrelation terms may be based on the complex amplitude estimates of the corresponding pilot paths, as indicated at block 74. This approach essentially reduces the number of pilot paths being processed.
For example, the selection criteria to reduce crosscorrelation terms may involve simply taking the strongest L paths, all being chosen according to the processing power available. Alternatively, the criteria may be based on some threshold value such as the path that contains a minimum percentage of the total base station receive power or the path whose relative power is above some minimum value.
The methodology, in accordance with one embodiment, for selecting the sub-crosstalk terms in block 74 may be based on the magnitudes of the estimated received amplitudes, of a path and/or a finger:
Alternatively the magnitudes of products of estimated received amplitudes of path and/or finger
may be used as the selection criteria. As still another embodiment, the estimated equivalent transmit/receive filter tap weights
may be used. Another embodiment may involve using the magnitudes of 3-way products of estimated received amplitudes of path and finger and the equivalent Tx/Rx filter tap weight:
Still another embodiment may use the magnitudes of sub-crosstalk terms as the selection criteria:
Another useful selection criteria are the magnitudes of sub-crosscorrelation terms weighted by equivalent Tx/Rx filter tap weights
Also the magnitudes of sub-crosscorrelation terms weighted by equivalent Tx/Rx filter tap weights and the product of received amplitudes of corresponding path and finger
can be used in this fashion as can magnitudes of crosscorrelations terms,
the magnitudes of crosscorrelation terms weighted by corresponding received path amplitude for each term
and the magnitudes of crosscorrelation terms weighted by product of received amplitudes of corresponding path and finger
The selection process may be as follows in some embodiments:
1. choose the S terms with the strongest selection parameter values (S fixed) such as those described above; and/or
2. choose all terms with selection parameters above some absolute threshold; and/or
3. choose all terms with selection criteria above some relative threshold.
Eliminating P paths using this approach saves PLT complex-valued crosstalk computations that would occur at block 76. This includes PLT complex-valued multiplications and PL(T-1) complex-valued additions, assuming that crosscorrelations are not stored in memory. In addition, PL complex valued multiplications may be saved, during the operation indicated at block 80, and PL complex-valued additions may be saved in the operation indicated at block 84.
In accordance with still another embodiment, the selection of the crosstalk terms may be based on the crosstalk values that result from the computation of the crosstalk terms in the operation indicated at block 76. In this case, the crosstalk values, once computed, may be selected as indicated at block 78.
A number of different types of selection criteria may be utilized to select from among the crosstalk values. For example, the selection criteria may involve simply taking the strongest S1 crosstalk values, S1 being chosen according processing power available. As another embodiment, the criteria may be based on some threshold value such as the crosstalk value that contains a minimum percentage of the total crosstalk power or that the crosstalk relative power is above some minimum value.
Eliminating N crosstalk values from being processed based on this criteria saves N complex-valued multiplications in the operation indicated in block 79 and N complex-valued additions in the operation indicated in block 84.
As still another approach, instead of basing the selection criteria on crosstalk values alone, the selection criteria may be based on the weighted crosstalk values as indicated in block 82. Eliminating N weighted crosstalk values from being processed, based on this criteria, saves N complex-valued additions in the operation indicated at block 84.
Again, it may be possible in some embodiments to store the selection decisions of all weighted crosstalk values over the entire period of the spreading code. This avoids recomputation of the weighted crosstalk values that were already determined to be negligible. If the formerly negligible, weighted crosstalk values change significantly, then the selection decision table entry may be reset.
In some embodiments, a variety of the approaches represented by blocks 74, 78, 79 and 82 may be utilized in tandem, alone, or in any combination. Using the first approach, indicated in block 74, eliminates certain pilot paths from consideration. Using the second approach, indicated in block 78, further eliminates some of the crosstalks of the remaining pilot paths from being processed. Finally, using the approach indicated in block 82 further reduces the number of weighted crosscorrelations that are processed in the operation indicated in block 84.
In the embodiments previously described, the pilot interference cancellation and the application of crosstalk selection is primarily done in terms of post-despread cross-correlation based pilot interference cancellation. A similar approach can be used to simplify the implementation of respread/despread pilot interference cancellation. In this interference cancellation algorithm, the actual interference signal is regenerated by respreading the pilot data with the appropriate pilot spreading code and then filtering with the appropriate baseband filter taps at the sample rate.
Cancellation of the interference is contributed by a pilot path to a user signal path (a finger) can then be done by canceling the regenerated spread pilot signal estimate from the received signal at the sample rate. As another example, the regenerated pilot signal estimate may be correlated with the user code and then the resulting crosstalk may be canceled from the despread received signal at the symbol rate. The approaches to simplification illustrated in
The principles set forth herein apply equally well to systems involving the joint detection of multiple users as well as the cancellation of the interference resulting from multiple user channels and/or multipath. Instead of just L multipath detection branches of a single data user, one may have KL detection branches for detecting K users. For each detection branch, the weighted crosscorrelation terms The principles set forth herein apply equally well to systems involving the joint detection of multiple users as well as the cancellation of the interference resulting from multiple user channels and/or multipath. Instead of just L multipath detection branches of a single data user, one may have KL detection branches for detecting K users. For each detection branch, the weighted crosscorrelation terms resulting from all other signals and paths including, but not limited to, the pilot signals, may be canceled.
Finally, while embodiments of the present invention have been described in the context of a CDMA downlink, the principles set forth herein apply equally to CDMA uplinks including pilot channels such as those used in third generation CDMA systems.
With particular embodiments of the present invention, improved capacity, coverage and performance may be achieved in wireless CDMA systems without requiring any changes to the transmitters including the base stations. In addition, the capacity gains can also be translated to supporting the delivery of hired data rate services in some embodiments.
Finally, referring to
In general, the software 90 receives the estimates, as indicated at block 92, of the receiver amplitude/phase for each pilot path determined at the block 72 (
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.
Number | Name | Date | Kind |
---|---|---|---|
6009089 | Huang et al. | Dec 1999 | A |
6034986 | Yellin | Mar 2000 | A |
6067292 | Huang et al. | May 2000 | A |
6175587 | Madhow et al. | Jan 2001 | B1 |
6570909 | Kansakoski et al. | May 2003 | B1 |
Number | Date | Country |
---|---|---|
1 022 862 | Jul 2000 | EP |
WO 9843362 | Oct 1998 | WO |
WO 0024135 | Apr 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20030021337 A1 | Jan 2003 | US |