The present invention relates to the estimation of a frequency offset in a received wireless signal, particularly but not exclusively for the purpose of synchronization in a cell search of a cellular mobile communication system such as a Wideband Code Division Multiple Access (W-CDMA) system.
In order for a wireless receiver to be able to acquire meaningful data from a transmitter, it is necessary for the receiver to be properly synchronized with the received signal. That is to say, the receiver must sample the data at the correct timing with respect to the received signal. To achieve this, the transmitter must broadcast some kind of synchronization signal whose form is known to the receiver, and which the receiver can use as a reference to determine the timing of the received data.
For example, to acquire a signal in a W-CDMA system, the receiver synchronizes to three broadcast channels, the Primary Synchronization Channel (P-SCH), the Secondary Synchronization Channel (S-SCH) and the Common Pilot Channel (CPICH). For the initial cell search, a primary synchronization is first performed using the P-SCH to provide information on the slot timing, and then a secondary synchronization is performed using the S-SCH to provide information on the code group and frame boundary (i.e. slot position within a frame, or frame boundary acquisition).
One method for performing a synchronization search is discussed in a paper titled “Cell Search Robust to Initial Frequency Offset in WCDMA Systems” (June Moon and Yong-Hwan Lee, School of Electrical Engineering, Seoul National University; from the 13th IEEE International Symposium on Personal, Indoor and Mobile Radio Communications, 2002; ISBN: 0-7803-7589-0). Summarized briefly, this involves correlating the received P-SCH with a locally generated version of the P-SCH code using a matched filter, then averaging the results over a number of time slots using a coherent combing scheme before performing a peak detection followed by the secondary synchronization.
A difficulty with synchronization is discussed in relation to
The transmitter 2 transmits data to the receiver 4 at a first frequency ftx dependent on the first clock (cktx) 6, including the P-SCH, S-SCH and CPICH. The receiver 4 samples the data at a second frequency frx dependent on the second clock (ckrx) 8. The first frequency ftx and second frequency ftx are nominally the same. However, in reality no two clocks can ever be completely identical, for example due to manufacturing differences. Therefore the second clock (ckrx) 8 will in practice be slightly (but not necessarily negligibly) different from the first clock (cktx) 6, resulting in a frequency offset f0 such that frx actually equals ftx+f0. In the case where the receiver is a mobile terminal such as a mobile phone, the frequency error is likely to be particularly significant because the crystal oscillators used in the clocks 8 of such consumer devices tend to be cheaper and therefore more prone to error and manufacturing spread.
Because of the nature of the received data, any frequency difference f0 between the transmitter frequency ftx and the receiver frequency frx will be seen as an ordinary stationary data vector spinning around the origin, i.e. multiplied by a factor ejφt where φ is dependent on the frequency error f0.
Moon & Lee describe a synchronization method which is more robust against such frequency errors due to an improved, coherent combining scheme. However, one point which is overlooked by the above Moon & Lee reference is that there will be a time shift because of the receiver sampling clock 8 being different from the transmitter clock 6. That is, because data is sampled at a slightly different rate than it is transmitted, the sampling shift will be perceived as a constant movement in time of the data, or a sliding of the received data relative to the transmitted data.
After attempting primary synchronization for example, the secondary synchronization may fail, because the data is not where it is expected to be and so the correlation values returned may be very poor. The degree of averaging and hence the accuracy of the estimation is therefore also determined by the time drift. In practice, to reliably detect a P-SCH at the cell edge limits the allowable frequency error using current techniques is between 1 kHz and 2 kHz depending on implementation. This degree of frequency correction is usually termed fine AFC (automatic frequency control).
Coarse AFC, for correction of frequency errors greater than this, would typically involve trial and error searches with the receiver clock adjusted in incremental amounts for each search. This is a slow process.
It would be advantageous to provide a fast and accurate method of frequency error estimation. It would also be advantageous to be able to cope with larger frequency errors. Particularly, in a case where the receiver 4 is a mobile consumer device such as a mobile phone, it would be preferable to be able to use a cheaper oscillator for the clock 8.
According to one aspect of the present invention, there is provided a method of estimating a frequency offset, the method comprising: receiving a wireless signal timed according to a first frequency; generating a local signal timed according to a second frequency; performing a plurality of synchronization searches, each search comprising obtaining a set of correlation results indicative of a correlation between the wireless signal and the local signal at different timing offsets of the wireless signal relative to the local signal; finding a series of results, with a result from each of a plurality of said synchronization searches, for which the difference in timing offset between results from adjacent searches in the series is within a maximum specified value; and determining from said series a frequency offset between the first and second frequencies.
This solution advantageously provides a faster and more accurate method of frequency error estimation than existing techniques. The solution is also cheaper because it is easy to implement in code, and because it accommodates larger frequency errors allowing cheaper oscillator crystals.
In embodiments the method may comprise, for each synchronization search, ordering the respective correlation results in order of a corresponding received signal energy. This improves the efficiency of the estimate by allowing the results to be prioritized according to signal energy.
In further embodiments, said step of finding of said series may be performed using only a top portion of the correlation results having the greatest received signal energy from each synchronization search. Thus the efficiency may be further improved by ignoring certain low energy results altogether.
In further embodiments, the step of determining the frequency offset may comprise determining the frequency offset from a difference in timing offsets between at least two of the correlation results from different searches in said series. The step of determining the frequency offset may comprise determining a phase from sums of real and imaginary parts of the correlation results in said series. The latter is preferred because the accuracy of the estimation is not as strongly affected by the time interval between the synchronization searches.
In further embodiments, the step of determining the frequency offset may be conditional on a magnitude of a sum of real and imaginary parts of the correlation results in said series being above a predetermined threshold. This advantageously allows results to be thresholded to reduce the likelihood of false alarms.
In yet further embodiments, the method may comprise using said estimation to correct for the frequency offset. The step of receiving the wireless signal may comprise receiving a synchronization channel on which is broadcast a synchronization code, and the step of generating the local signal comprises generating a local version of the synchronization code. The synchronisation channel may be a primary synchronisation channel of a W-CDMA cellular communications system. The present invention is particularly effective and applicable in such contexts.
According to another aspect of the present invention, there is provided a wireless receiver, comprising: reception means arranged to receive a wireless signal timed according to a first frequency; generation means arranged to generate a local signal timed according to a second frequency; correlation means arranged to perform a plurality of synchronisation searches, each search comprising obtaining a set of correlation results indicative of a correlation between the wireless signal and the local signal at different timing offsets of the wireless signal relative to the local signal; and frequency offset estimation means arranged to find a series of results, with a result from each of a plurality of said synchronisation searches, for which the difference in timing offset between results from adjacent searches in the series is within a maximum specified value, and to estimate from said series a frequency offset between the first and second frequencies.
According to another aspect of the present invention, there is provided a computer program product for estimating frequency offset between a received wireless signal timed according to a first frequency and a generated local signal timed according to a second frequency, the program comprising code which when executed by a processor is configured to perform the steps of: performing a plurality of synchronisation searches, each search comprising obtaining a set of correlation results indicative of a correlation between the wireless signal and the local signal at different timing offsets of the wireless signal relative to the local signal; finding a series of results, with a result from each of a plurality of said synchronisation searches, for which the difference in timing offset between results from adjacent searches in the series is within a maximum specified value; and determining the frequency offset from said series.
According to another aspect of the present invention, there is provided a wireless cellular communication system comprising: a base station arranged to transmit a wireless signal timed according to a first frequency, and a mobile terminal comprising: reception means arranged to receive said wireless signal; generation means arranged to generate a local signal timed according to a second frequency; correlation means arranged to perform a plurality of synchronisation searches, each search comprising obtaining a set of correlation results indicative of a correlation between the wireless signal and the local signal at different timing offsets of the wireless signal relative to the local signal; and frequency offset estimation means arranged to find a series of results, with a result from each of a plurality of said synchronisation searches, for which the difference in timing offset between results from adjacent searches in the series is within a maximum specified value, and to estimate from said series a frequency offset between the first and second frequencies.
For a better understanding of the present invention and to show how the same may be carried into effect, reference will now be made by way of example to the accompanying drawings.
Reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
a shows an idealized output of the functions of
b shows the output of
c shows the output of
a is a table of correlation results;
b is a table of correlation results subject to a timing drift;
c is a table of correlation results subject to a timing drift and noise.
Those skilled in the art to which this application relates will appreciate that other and further additions, deletions, substitutions and modifications may be made to the described embodiments.
As already mentioned, one method for performing such a synchronisation search is discussed in the paper “Cell Search Robust to Initial Frequency Offset in WCDMA Systems” (Moon & Lee), as referenced above. The method is outlined here for completeness, but it will be appreciated that the skilled person will be familiar with this and other methods of performing a synchronisation search. The particular method chosen is not of crucial importance, and the principal of the present invention can be extended to different methods of synchronisation. The main point is that the search results in a set of measurements indicative of a correlation between the received signal and the local code at a range of different timing offsets of the received signal relative to the local code.
In embodiments, the receiver 4 is a software modem, or “soft modem”, whereby at least some of the signal processing is implemented in software running on a generic, programmable processor. Preferably, the software modem is a soft baseband modem. That is, on the receive side, all the radio functionality from receiving RF signals from the antenna up to and including mixing down to baseband is implemented in dedicated hardware. But all functionality in the baseband domain is implemented in software stored on a memory of the receiver 4 and executed by the receiver's processor (neither shown).
Thus, each of the matched filter 14, accumulator 16, and magnitude block 18 preferably comprises a portion of code stored in memory and executed by the processor.
In operation, reception of signals begins with down converting, low pass filtering and sampling at time t=iTc in the receive front-end (not shown). Tc is the chip time period and i is the chip index. The index i is a measure of the time offset from the beginning of the slot, measured in chips. The matched filter 14 then receives signal samples r[i] as its input from the receive front-end. The samples r[i] can be represented by:
r[i]=√{square root over (Etx[i]/2α[i]ejθ[i]CPSCH[i−k]+n[i])}
where Etx[i] is the transmitted energy of the P-SCH code; α[i] represents the variation in gain due to channel fading; θ[i] represents the phase distortion due to channel and RF carrier offset; CP-SCH[i] is the P-SCH code; kTc, is the delay due to the channel and receiver filtering; and n[i] is the noise term including intra-cell interference, inter-cell interference and thermal noise. Because the P-SCH code is transmitted in the first symbol (256 chips) of a ten-symbol slot (2560 chips), the transmitted Etx can be represented by:
And the P-SCH code can be generated using two codes X1 and X2 of length sixteen, such that :
C
P-SCH
[i]=(i+j)X1[i(div)16]X2[i(mod)16 ]
where:
and i(div)16 is the quotient of i/16 and i(mod)16 is the remainder of i/16.
The matched filter 14 outputs a plurality of partial correlation values ak, j[i] for each time index i, where j=1 . . . 4 and k is the slot index of the kth slot. These partial correlation values are a measure of the correlation between the received signal 10 and a locally generated reference signal (i.e. the locally generated version of the P-SCH code) at each of the i=0 . . . 2559 possible timing offsets between the local and received signals, for each quarter j of each slot k. The partial correlation values can be represented as:
where n[i] is the interference due to the correlation of n[i] and CP-SCH [i]
The accumulator 16 receives the partial correlation values ak, j[i] output from the matched filter 14, and combines the results for each chip index i over the j=1 . . . 4 quarters and k slots, thus producing a plurality of correlation results Z[i]. The accumulation is preferably according to a coherent combining scheme, whereby the correlation results are found as follows:
where K is the total number of slots under consideration, preferably equal to sixteen. So for each slot k, the accumulator 16 takes the complex conjugate of the first partial correlation value ak, 0[i] and multiplies it by the second partial correlation value ak, 1[i], takes the complex conjugate of the second partial correlation value ak, 1[i] and multiplies it by the third partial correlation value ak, 2[i], and takes the complex conjugate of the third partial correlation value ak, 2[i] and multiplies it by the fourth partial correlation value ak, 3[i]. The accumulator 16 then sums each these multiples over each of the slots k, resulting in a correlation result Z[i] for each of the i=0 . . . 2559 timing offsets between the received signal and the locally generated P-SCH code signal.
The magnitude block 18 receives the correlation results Z[i] output by the accumulator 16, and takes the modulus squared of each to produce a measure Erx[i] of the received P-SCH energy corresponding to the i=0 . . . 2559 different timing offsets of the received signal relative to the locally generated P-SCH code signal:
Erx[i]∞|Z[i]|2
In fact, in a preferred embodiment, the measurement described above is performed at twice the chip rate rather than once per chip, thus resulting in 5120 results. That is, t=½iTc so that the chip index i is actually a measure of the number of half chips' timing offset.
As illustrated schematically in
Moon & Lee also describe how the frequency error f0 can be determined based on the above calculations. However, Moon & Lee's method ignores the associated sampling drift, which will be perceived as a constant movement in time of the sampled data, or a sliding of the received data relative to the transmitted data. It would be desirable to correct for this effect, and particularly before moving on to the secondary synchronisation. Accordingly, an embodiment of the present invention is now described which provides an improved method of frequency error estimation.
Firstly, this involves performing a plurality of synchronisation searches, preferably each being performed in the manner described above. This produces a plurality of sets of correlation results Zn[i], where n is the number of the searches from 1 . . . N where N is the total number of searches. Also, as mentioned above, preferably i=0 . . . 5119 such that two results are taken per chip (with 2560 chips per slot). N might for example be about ten, but this is a matter of design choice.
A measure Erx[i] of the signal energy is determined for each result by taking the modulus squared of Z[i]. The results are then ordered by signal energy and all but the top M results are discarded (at least for the purpose of this calculation). The value M might for example be chosen to return the top 32 candidates. But the chosen value M is a matter of design choice, and may depend on the number of searches N chosen because using more searches gives a greater chance of peaks being returned over all. In fact, good results may be achieved by taking only the top candidate (i.e. M=1) depending on the frequency error, total number of searches and detection limit. However, this limiting case becomes harder as the maximum frequency error to correct increases. This is due to a reduction in correlation peak size, because each chip's vector added to the correlate is rotating.
Thus an N by M table of results Znm[i] is produced as shown in
In an idealized scenario as illustrated in
Note that there may in fact be extra peaks (not shown), particularly if the P-SCH sequence is split into four partial correlations there then there will be peaks at multiples of 64 chip offsets from the man peak 20. Further, the P-SCH code is hierarchical, so there may be other peaks at other positions.
A semi-idealized scenario is now considered with reference to
Note that because Z[i] is the result of an accumulation over a number of slots, then i can be thought of as a “wrap-around” variable. That is, if the drift is such that i+(n−1)δ>5119 (or whatever the slot length is), then i effectively becomes i-5120.
A more realistic situation is now discussed with reference to
As shown in
First, a maximum timing drift A is specified, which provides a constraint within which to search for the run. The value of Δ will depend on the maximum likely frequency difference between the transmitter clock 6 and receiver clock 8. This will usually depend largely on the error in the receiver clock 6 in the case where a cheaper crystal is used for the oscillator for a lower cost consumer device such as a mobile phone (at least relatively low cost compared to a transmitter such as a base station). A typical value of Δ might be half a chip.
The method then uses Δ to look for the run, i.e. to look for a series of entries corresponding to the cell boundary peak 20. So an entry will only be included in the run on the condition that it is within Δ of an entry from an adjacent search (i.e. adjacent in time in the sequence of searches). Until determined otherwise, each entry in the table may be considered a candidate. Starting at the first candidate in the first column (n=1 and m=1), it is determined whether any other candidate in the second column (n=2) has a timing offset which falls within the maximum time drift Δ of that first candidate. That is to say, it is determined whether t21≦t11+Δ, whether t22≦t11+Δ, whether t23≦t11+Δ and so on, up to and including determining whether t2M≦t11+Δ.
Then, moving on to the next candidate in the first column (n=1 and m=2), it is determined whether any other candidate in the second column (n=2) has a timing offset which falls within the maximum time drift Δ of that next candidate. That is, it is determined whether t21≦t12+Δ, whether t22≦t12+Δ, whether t23≦t12+Δ and so on, up to and including determining whether t2M≦t12+Δ. This continues for each of the M candidates in the first column (n=1), so for each value m in the first column it is determined whether any candidate in the second column has a timing offset which falls within the maximum time drift Δ of that Mth candidate. That is, it is determined whether t21≦t1m+Δ, whether t22≦t1m+Δ, whether t23≦t1m+Δ and so on, up to and including determining whether t2M≦t1m+Δ. A positive determination may be referred to herein as a “hit”.
In the example of
Note however that the noise entries can appear with literally any timing at all, so there is always a possibility that the above test will detect multiple “hits” if only two adjacent columns are compared, because an unwanted noise entry in the second column may happen by chance to have a timing offset within Δ of one of the entries in the first column. This is why it is important to look for runs across the table, rather than individual hits.
The method therefore continues as follows. For the first candidate in the second column (n=2 and m=1), it is determined whether any other candidate in the third column (n=3) has a timing offset which falls within the maximum time drift Δ of that candidate. That is to say, it is determined whether t31≦t21+Δ, whether t32≦t21+Δ, whether t33≦t21+Δ and so on, up to and including determining whether t3M≦t21+Δ. Then it is determined whether any candidate in the third column falls within Δ of the second candidate in the second column, i.e. whether t31≦t22+Δ, whether t32≦t22+Δ, whether t33≦t22+Δ and so on, up to and including determining whether t3M≦t22+Δ. This continues for each of the M candidates in the second column, such that for the mth candidate in the second column it is determined whether any candidate in the third column falls within Δ of that candidate, i.e. whether t31≦t2m+Δ, whether t32≦t2m+Δ, whether t33≦t2m+Δ and so on, up to and including determining whether t3M≦t2m+Δ. In the example of
Any false hits detected in the comparison between the first and second columns will thus most likely be able to be ruled out, because the chance of detecting two false hits in a row is very low. The chance can be diminished even further by continuing to compare the third and fourth columns, fourth and fifth columns, etc., up to and including comparing the (N−1)th column with the Nth column, so as to preferably build up a run of hits across the whole width of the table. Note though that a run may contain gaps, and that it may still be possible to use a run containing one or more gaps. In this case a multiple of Δ is considered from the last good candidate.
The generalized determination by be expressed as: for the mth candidate in the (n1)th column, determine whether the timing offset tnm of any candidate in the nth column falls within the maximum timing offset Δ of the timing offset t(n−1)m of that mth candidate in the (n−1)th column.
Note, the run analysis is preferably performed in both the +Δ and −Δ directions (left to right and right to left) to check for +ve and −ve frequency offsets. Once the run of N entries has thus been discovered, a comparison between the timing offset of the first and the final entry in the run can be used to estimate the timing drift δ. That is, δ=(tN−t1)/(N−1) where tN is the timing offset of the Nth entry in the run and t1 is the timing offset of the 1st entry in the run. Using the 1st and Nth entries gives the best estimate because they give the largest timing drift (N−1)δ, and thus the least error in the estimate. Other options may be possible, for example by a best-fit analysis.
Once the timing drift δ has been determined, it is straightforward to determine the frequency offset f0.
An alternative estimate is as follows. The coherent terms detected from the run in the table are added together, i.e. the real parts (Re) of the Z[i] results from the run are summed and the imaginary parts (Im) of the Z[i] results from the run are summed. These real and imaginary sums can then be used to generate a phase offset by arctan (Im/Re), which when multiplied by an appropriate scalar to give the frequency offset. That is:
This latter estimate is preferred because the accuracy of the former is determined by the time between searches, as well as the number of searches. Longer time between searches and/or more searches improves accuracy but the drawback is that this takes longer.
The latter estimate also has an additional advantage, because the magnitude of the coherent sum can be thresholded to reduce the likelihood of false alarms. I.e. a run will be detected as a false alarm if:
In embodiments, the former estimate may be used to check the results of the latter. Using both together provides a very robust technique in this field. For example, if the two estimates agree within some predetermined tolerance, then it can be established that the method is not locking onto an adjacent raster. If the carrier frequency is one raster (200 kHz) offset away from a valid signal then the algorithm will still indicate a detection but the frequency will be wrong due to the phasor wrapping round the unit circle a few times.
The estimate of the frequency offset can then be used in an automatic frequency control (AFC) operation to correct for the frequency difference, by applying a change in voltage to the crystal of the voltage controlled clock to give a change in frequency as will be familiar to a person skilled in the art.
The method is preferably implemented by the receiver 4 in software, by means of a frequency offset estimation function (not shown) comprising a portion of code stored in the receiver's memory and executed on the receiver's processor.
For completeness, note of course that the frequency offset estimation function implemented by the receiver 4 is unlikely to actually produce a table in the graphical sense of the word. Rather, it uses an organized array which may be considered as a table for easier understanding.
It will be appreciated that the above embodiments are described only by way of example. Other uses and variations may be apparent to the person skilled in the art. The scope of the invention is not limited by the described embodiments, but only be the following claims.
Number | Date | Country | Kind |
---|---|---|---|
0721758.1 | Nov 2007 | GB | national |
This application is the National Stage of, and therefore claims the benefit of International Application No. PCT/EP2008/064473 filed on Oct. 24, 2008, entitled “FREQUENCY OFFSET ESTIMATION IN A CDMA SYSTEM,” which was published in English under International Publication Number WO 2009/059907 on May 14, 2009, and has priority based on GB 0721758.1 filed on Nov. 6, 2007. Each of the above applications is commonly assigned with this National Stage application and is incorporated herein by reference in their entirety.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP08/64473 | 10/24/2008 | WO | 00 | 6/15/2010 |