Method for acquiring timing and carrier synchronization of offset-QPSK modulated signals

Abstract
Embodiments of the invention consist in a method of carrier synchronization, comprising determining a frequency offset estimate from a rate of change of a phase difference between a local oscillator signal and a carrier signal of a received signal; and adjusting a frequency of the local oscillator signal by the frequency offset estimate.
Description

Embodiments of the present invention relate to a method of carrier synchronization.


BACKGROUND TO THE INVENTION

Phase locked loops are common in many systems such as, for example, receivers in communication systems. Phase locked loops can be used to provide a local oscillator signal which is locked in frequency and phase to a carrier signal of a received communications signal. If the received signal comprises an information signal multiplied by a carrier signal, the received signal is typically mixed with (multiplied by) the local oscillator signal and low-pass filtered to recover the information signal.


A QPSK (Quadrature Phase Shift Keying) modulated signal typically comprises a signal of constant frequency which can have one of four phases, each phase representing two bits. It can be generated, for example, by multiplying two binary information signals, an in-phase signal I(t) and a quadrature-phase signal Q(t), by a carrier signal at a phase of 0° and 90° respectively (i.e. a cosine signal and a sine signal respectively). The resulting signals are then summed to form the QPSK signal.


An ideal received QPSK signal typically comprises the signal R(t) where:

R(t)=I(t)·cos(ω1t+φ1)+Q(t)·sin(ω1t+φ1)   (1)


where:

    • I(t) is the transmitted in-phase signal,
    • Q(t) is the transmitted quadrature-phase signal,
    • ω1, is the carrier signal frequency, and
    • φ1 is the received carrier static phase.



FIG. 1 shows a typical Costas phase locked loop 100 which can be used to demodulate a QPSK signal. The Costas Loop 100 comprises a first mixer 102 which mixes a received signal R(t) with a local oscillator signal provided by a voltage controlled oscillator (VCO) 104. The Costas Loop 100 also comprises a second mixer 106 which mixes the received signal R(t) with the local oscillator signal delayed by 90°, as represented by a 90° delay unit 108.


The output of the first mixer is low-pass filtered by a first low-pass filter (LPF) 110. The output of the second mixer is low-pass filtered by a second low-pass filter 112. If the VCO 104 is generating a sinusoidal signal which is locked in frequency and phase to the incoming signal R(t) (i.e. it is generating a signal proportional to cos(ω1t+φ1)) then the output of the first LPF 110 will be the signal I(t), and the output of the second LPF will be the signal Q(t).


To achieve frequency and phase lock, the outputs of the filters 110 and 112 are provided to a phase detection apparatus 114 which is, in practice, a third mixer. The output of the third mixer is provided to a loop filter 116 which is, in practice, a third low pass filter. The output of the filter 116 is a control voltage which is applied to the VCO 104 to control the frequency of its output. Over a period of time, the frequency and phase of the local oscillator signal provided by the VCO 104 will approach those of the carrier signal of the received signal R(t). The receiver is then said to be carrier synchronized with the transmitter.


A typical QPSK demodulator also must achieve timing synchronization (also known as symbol synchronization). The signals Q(t) and I(t) must be sampled at periodic instants to determine their amplitude and therefore the information that the signals are representing. Timing synchronization is typically performed separately from carrier synchronization in QPSK demodulation.


OQPSK (Offset QPSK) is another modulation scheme where the signal Q(t) or I(t) is delayed by half a symbol when the OQPSK is modulated. In the subsequent transmitted symbol, phase shifts are restricted to a maximum of 90° at a time. This gives OQPSK desirable properties over QPSK which can have phase shifts of 180°.


Some OQPSK synchronization schemes introduce a half-symbol delay to the signal I(t) in the carrier synchronization loop. However, the half-symbol delay introduces a carrier phase shift which is no longer negligible when a large carrier frequency offset (difference in frequency between the local oscillator signal and the carrier signal of a received signal R(t)) is present. Therefore these schemes are unsuitable where a large carrier frequency offset is present.


OQPSK synchronization schemes are described in Peter W. Kinman, Jeff B. Berner, “Carrier Synchronization of Offset QPSK for Deep Space Telemetry”, Aerospace Conference Proceedings, 2002. IEEE, Volume 3, 9-16, March 2002, pages 3-1327 to 3-1336, and M. K. Simon, “Carrier Synchronization of Offset Quadrature Phase Shift Keying”, Telecommunications and Mission Operations Progress Report 42-133, January-March 1998, May 15, 1998. http://tmo.jpl.nasa.gov/tmo/progress_report/42-133/133J.pdf


SUMMARY OF THE INVENTION

According to a first aspect of embodiments of the invention, there is provided a method of carrier synchronization, comprising determining a frequency offset estimate from a rate of change of a phase difference between a local oscillator signal and a carrier signal of a received signal; and adjusting a frequency of the local oscillator signal by the frequency offset estimate.


Other aspects of embodiments of the invention are defined in the appended claims.




BRIEF DESCRIPTION OF THE DRAWINGS

Embodiments of the invention will now be described, by way of example only, with reference to the accompanying drawings, in which:



FIG. 1 shows a prior art Costas Loop used for QPSK demodulation;



FIG. 2 shows a demodulator according to embodiments of the invention;



FIG. 3 shows a synchronization unit according to embodiments of the invention;



FIG. 4 shows an example of a constellation diagram for QPSK or OQPSK;



FIG. 5 shows an example of OQPSK Q(t) and I(t) waveforms;



FIG. 6 shows an example of assignment of samples in a data stream to other data streams;


FIGS. 7(a) and (b) show an example of the phase offset θ(t) when the frequency offset is positive and negative respectively;



FIG. 8 shows an example of an interpolated phase offset;



FIG. 9 shows an example of an implementation of a loop filter; and



FIG. 10 shows the example waveforms of FIG. 5 with peaks indicated.




DETAILED DESCRIPTION OF EMBODIMENTS OF THE INVENTION

The demodulator 200 shown in FIG. 2, which comprises a phase locked loop according to embodiments of the invention, includes a first mixer 202 which mixes a received signal R(t) with a local oscillator signal provided by a numerically controlled oscillator (NCO) 204. The demodulator 200 also comprises a second mixer 206 which mixes the received signal R(i) with the local oscillator signal delayed by 90°, as represented by a 90° delay unit 208.


The output of the first mixer 202 is filtered by a first matched filter (MF) 210. The output of the second mixer 206 is filtered by a second matched filter 212. If the NCO 204 is generating a sinusoidal signal which is locked in frequency and phase to the * incoming signal R(t) (i.e. it is generating a signal proportional to cos((ω1t+φ1)), then the output X(t) of the first filter 210 will be the signal I(t), and the output Y(t) of the second filter 212 will be the signal Q(t).


The matched filters 210 and 212 have two purposes. Firstly, they suppress the mixing products containing summed frequency terms. Secondly, by having an impulse response matched to the pulse shape of the I(t) and Q(t) signals, the matched filters 210 and 212 increase the signal-to-noise ratio (SNR) of the downconverted I(t) and Q(t) signals by effectively performing an auto-correlation.


The signals X(t) and Y(t) are provided to a synchronization unit (SU) 220. The synchronization unit 220 provides information on the local oscillator signal generated by the NCO 204 to a loop filter 222, which subsequently passes the filtered information to the NCO in the form of a numerical control value. The information comprises three values: θ, φ and ω. These will be explained in more detail below.



FIG. 3 shows an embodiment of the synchronization unit 220. The synchronization unit 220 includes a phase detection function module 300 which accepts the signals X(t) and Y(t) as inputs. The phase detection function module 300 provides a plurality of samples P={p0,p1,p2, . . . } of a phase detection function P(t) to a 1:N demultiplexer 302. The samples P are provided to the demultiplexer 302 at a rate of 2NFs, where N is a positive integer and Fs is the symbol rate of the symbols in the signals I(t) and Q(t).


For a received signal R(t) as defined above, the signals X(t) and Y(t) comprise:

X(t)=I(t)·cos((ω1−ω2)t+φ1−φ2)+Q(t)sin((ω1−ω2)t+ω1−ω2)   (2)
Y(t)=Q(t)·cos((ω1−ω2)t+ω1−ω2)−I(t)sin((ω1−ω2)t+φ1−φ2)   (3)


where:

    • ω1 is the carrier frequency,
    • φ1 is the received carrier static phase,
    • ω2 is the NCO (local oscillator) frequency, and
    • φ2 is the NCO static phase.


The carrier phase offset is given by:

θc(t)=(ω1−ω2)t+ω1−ω2   (4)


Hence:

X(t)=I(t)·cos θc(t)+Q(t)sin θc(t)   (5)
Y(t)=Q(t)·cos θc(t)−I(t)sin θc(t)   (6)


Dividing (5) by (6) gives:
X(t)T(t)=I(t)Q(t)+tanθc(t)1-I(t)Q(t)·tanθc(t)(7)


Using the identity
tan(A+B)=tanA+tanB1-tanA·tanB

in equation 7:
X(t)Y(t)=tan(tan-1(I(t)Q(t))+θc(t))(8)tan-1(X(t)Y(t))=θc(t)+tan-1(I(t)Q(t))(9)


The phase detector function P(t) is defined as:
P(t)={tan-1(X(t)Y(t))-sgn(X(t)·Y(t))·π4forY(t)0π4·sgn(X(t))forY(t)=0where:(10)sgn(x)={-1forx<00forx=01forx>0(11)


P(t) is bounded by the limits −π/4≦P(t)≦π/4.


For the general case of Y(t)≠0, substituting (5), (6) and (9) into (10) gives:
P(t)=θc(t)+tan-1(I(t)Q(t))-sgn(sin2θc(t)·Q(t)2-I(t)22+I(t)·Q(t)·cos2θc(t))·π4(12)


When the condition Q(t)=±I(t) is satisfied, equation (12) reduces to:

P(t)=θc(t)±π/4−±sgn(cos 2θc(t)π/4   (13)


The values of θc(t) that satisfy P(t) fall within the limits −π/4<θc(t)<π/4.



FIG. 4 shows a constellation diagram showing the relative positions -of the four symbols in an example implementation of QPSK or OQPSK. A symbol 400 lies in each quadrant 402. Each symbol represents two transmitted bits. Points 404 represent the phase of the local oscillator signal when there is a phase difference θc(t) between the carrier of the received QPSK or OQPSK signal and the local oscillator signal. The phase of the local oscillator signal will be displaced from that of one of the symbols 400 by θc(t). The value of θc(t) may be greater than π/4 or less than −π/4. Therefore a carrier phase offset estimate θ(t) is defined as being the phase difference between the local oscillator signal and the phase of the symbol 400 in the same quadrant 402 as the local oscillator signal. The value of θ(t) therefore lies within the range −π/4≦θ(t)≦π/4 in the example QPSK or OQPSK implementation. It is θ(t) which is determined by the phase detection function module 300.


There is a phase ambiguity between θc(t) and θ(t) as θc(t) may lie outside of the range for θ(t). Therefore, the bounded value −π/4<θc(t)<π/4 is replaced in equation (13) with θ(t) which yields:

P(t)=θ(t)   (14)


Therefore, the phase detection function P(t) equals the carrier phase offset estimate θ(t) when Q(t)=±I(t). The phase locked loop of embodiments of the invention will therefore synchronize the phase of the local oscillator signal with that of one of the symbols 400.



FIG. 5 shows examples of waveforms of the demodulated signals I(t) and Q(t). Each waveform takes the form of a binary signal shaped using a sinusoidal signal of a period
2Fs,

where F, is the symbol rate of the signals I(t) and Q(t). The condition Q(t)=±I(t) will be satisfied twice in a single symbol period
1Fs

as shown by vertical dashed lines. The time period between instances when the condition is satisfied is therefore
12Fs.


Referring back to FIG. 3, the phase detection function module 300 provides samples of P(t) to the 1:N demultiplexer 302 at a rate of 2NFs. The demultiplexer 302 splits the samples into N data streams Vi(t), i=0, . . . , N−1, each of which contain samples at a rate of 2Fs. If samples P={p0,p1,p2, . . . ) are provided to the demultiplexer, then each data stream Vi(t) will contain the samples Vi={pi,pN+i,p2N+i,p3N+i, . . . }.



FIG. 6 shows an example of the operation of the demultiplexer when N=4. The horizontal lines represent time and a circle on a line represents a sample of P(t). The vertical arrows show how the samples of P(t) are added to the data streams Vi(t). It can be seen that the data streams Vi(t) are interleaved, and two data streams Vi(t) and Vi+1(t) (for example V2(t) and V3(t), or V3(t) and V0(t)) are time-displaced relative to each other by a time period of
12NFs.

This time period is also the time period between samples in P(t). The time period between samples in a data stream Vi(t) is
12Fs.

As the time period between instances when Q(t)=±I(t) is also
12Fs,

one of the data streams Vi(t) will represent or approximate the function θ(t). This data stream will be referred to herein as Vi(t)=θ(t). FIG. 7 shows examples of Vi(t)=θ(t). FIG. 7(a) shows an example where there is a positive carrier phase offset estimate. FIG. 7(b) shows an example where there is a negative carrier phase offset estimate. As θ(t) is bound by the range −π/4≦θ(t)≦π/4, the value of Vi(t) will also lie within this range. Where the phase difference θ(t) would otherwise make a transition outside of this range, a −π/2 phase shift (positive or negative as appropriate) occurs in Vi(t), as shown at the points 700.


Other data streams Vi(t)≠θ(t) may contain irregular waveforms.


Referring back to FIG. 3, the demultiplexer 302 passes samples from all of the data streams Vi(t) continuously to a phase interpolation module 304. The phase interpolation module removes the π/2 phase transitions from the data streams Vi(t), i.e. it interpolates the data streams Vi(t). The phase interpolation module 304 determines N interpolated data streams Ti={t0,i,t1,i,t2,i, . . . }, i=0, . . . , N−1 using the following:
tk,i=vk-1,i+ak,i(15)ak,i=ak-1,i+wk-1,i(16)wk,i={π2fordk,i<-π4-π2fordk,i>π40for-π4dk,iπ4(17)dk,i=vk,i+ak,i-(vk-1,i+ak-1,i)-wk-1,i-ωn,i2Fs(18)


where:

    • ωn,i is the gradient of the nth signal Ti(t);
    • Fs is the symbol rate of the received signal R(t); and
    • a0,i=w0,i0,i=0.



FIG. 8 shows an example of a data stream Ti(t) produced by the phase interpolation module 304 when interpolating the data stream Vi(t) shown in FIG. 7(a). It can be seen that the π/2 phase transitions have been removed and the resulting data stream Ti(t) is a straight line. When the data stream Vi(t)=θ(t) is interpolated, the resulting data stream Ti(t) is defined as an interpolated carrier phase offset estimate φ(t).


The phase interpolation module 304 provides samples from the data streams Ti(t) continuously to a linear regression module -306, as shown in FIG. 3. The linear regression module provides the values of ωn,i, n≧1 to the phase interpolation module 304. The linear regression module 306 does this by performing a linear regression calculation, detailed below, on a finite “window” of W samples from each of the data streams Ti(t). Therefore, the linear regression module calculates the (n+1)th gradient ωn,i on the samples Ti={tnW,i,tnW+1,i,tnW+2,i, . . . ,tnW+(W−1),i}. Therefore, for the first W samples passed to the linear regression module 306 from the phase interpolation module 304, the linear regression module has passed no gradient to the phase interpolation module. This “initial” gradient ω0,i is therefore defined as zero. In certain embodiments, the linear regression module 306 may pass a zero value gradient to the phase interpolation module 304 for this purpose. Additionally or alternatively, the phase interpolation module may automatically assume that ω0,i=0.


The linear regression module determines the gradients ωn,i using a linear regression calculation as follows:
ssxx,i=j=0W-1(xj+n-x_n)2(19)ssxy,i=j=0W-1(xj+n-x_n)·(tj+n,i-t_i+n)(20)ωn,i=ssxy,issxx,i(21)


where:

    • xj+n are values of time t at instants when the samples tj+n,i are taken;
    • xn is the mean value of all xj+n, 0≦j≦(W−1); and
    • ti+n is the mean value of all tj+n,i, 0≦j≦(W−1) from data stream Ti(t).


The linear regression module 306 also calculates a sum of squared errors (SSE) for each data stream Ti(t) as follows:
ssyy,i=j=0W-1(tj+n,i-t_i+n)2(22)SSEi=ssyy,i-(ssxy,i)2xxxx,i(23)


The smallest SSEi corresponds to the interpolated data stream Ti(t) that is closest to a straight line. That data stream Ti(t) is taken to be the interpolated carrier phase offset estimate φ(t) as it is unlikely that the waveforms of the other interpolated data streams Ti(t) form a straight line. The linear regression module therefore provides a further control signal 308, as shown in FIG. 3, which is used to control the outputs from the synchronization unit 220 as explained below. In certain embodiments, the control signal 308 takes the value i associated with Vi(t)=θ(t) and Ti(t)=φ(t).


The demultiplexer 302 provides the data streams Vi(t) to a first N:1 switch 310. The switch 310 also accepts the control signal 308. The switch 310 outputs a selected data stream Vi(t) from the synchronization unit 220 according to the value of the control signal 308. Thus the selected data stream Vi(t) is the data stream comprising the carrier phase offset estimate θ(t).


The phase interpolation module 304 provides the interpolated data streams Ti(t) to a second N:1 switch 312. The second switch 312 outputs a selected interpolated data stream Ti(t) according to the value of the control signal 308. Thus the selected interpolated data stream Ti(t) is the interpolated data stream closest to a straight line and hence comprising the interpolated carrier phase offset estimate φ(t).


The linear regression module 306 provides the calculated gradients ωn,i to a third N:1 switch 314. The third switch 312 outputs a selected gradient ωn,i according to the value of the control signal 308. The selected gradient ωn,i is defined as the carrier frequency offset estimate ω. The maximum carrier frequency offset estimate ωmax detectable by the phase detection function module 300 is given by:
ωmax=±π/41/2Fs=±Fs·π2(24)


The linear regression module 306 also outputs the control signal 308 from the synchronization unit 220 as a symbol timing estimate S. The symbol timing estimate S can be used to interpret the signals Q(t) and I(t) as explained below.


The three values θ(t), φ(t) and ω can be used to achieve phase and frequency lock between the local oscillator signal and the carrier signal of the received signal R(t). The value of ω can be used to perform a fast frequency adjustment as the value of ω is the carrier frequency offset estimate, i.e. the approximate difference in frequency between the local oscillator signal and the carrier signal of the received signal R(t). Thus the present invention provides faster frequency correction when compared to prior art systems in the presence of large frequency offsets (i.e. when the magnitude of the frequency offset in radians per second is comparable with the symbol rate in symbols per second). The value of φ(t) can be used to perform fine frequency adjustment. The value of θ(t) can be used to perform phase correction.


In certain embodiments, the carrier frequency offset estimate ω may be obtained instead from the carrier phase offset estimate θ(t). However, using the interpolated carrier phase offset estimate φ(t) improves the accuracy of ω.


Referring back to FIG. 3, the outputs θ(t), φ(t) and ω from the synchronization unit are provided to the loop filter 222. The loop filter carries out an appropriate function on the three values to determine a control value C to be provided to the NCO 204. FIG. 9 shows an example implementation of the loop filter. The filter 222 comprises an integral part 900 for integrating θ(t), and a proportional part 902 for scaling φ(t). The filter also comprises a summer 904 for summing ω and the outputs of the integral part 900 and the proportional part 902. The output of the summer 904 is the output C from the loop filter 222.


Referring back to FIG. 2, the synchronization unit 220 provides the symbol timing estimate S to a downsampler (DS) 224. The symbol timing estimate is effectively a value which indicates the instances in time when Q(t)=±I(t) as shown in FIG. 5 This value can be used to determine the position of the peaks in the Q(t) and I(t) waveforms, which are approximately half-way between instances when Q(t)=±I(t). FIG. 10 shows the example waveforms for Q(t) and I(t) from FIG. 5. The dashed vertical lines in FIG. 10 show the peaks of each waveform. The downsampler 224 samples the-waveforms at these instances in time and converts the sampled values to binary bits as appropriate. The downsampler 224 then outputs binary bit streams QD and ID corresponding to the signals Q(t) and I(t) respectively. It can be seen that, for the OQPSK-encoded signals Q(t) and I(t), the peaks for Q(t) lie between the peaks for I(t).


The demodulator according to embodiments of the present invention may be implemented in a number of ways. For example, the demodulator may be implemented entirely using software that can be executed, for example, on a data processor capable of executing the software. Alternatively, the demodulator may be implemented in digital hardware using, for example, a programmable logic device (such as, for example, a FPGA) or an ASIC. The demodulator may also be implemented using a plurality of data processors. Where appropriate, the phase detection function module 300 (shown in FIG. 3) may be implemented in digital hardware using a CORDIC (COordinate Rotation DIgital Computer) algorithm, for example.


The demodulator may also be implemented fully or in part as an analog circuit using analog components as appropriate. Hence, a “signal” or a “data stream” described herein may comprise a plurality of discrete samples or a continuous signal.


In alternative embodiments, the demodulator is instead used as a phase locked loop and may omit certain components such as, for example, the downsampler 224 of FIG. 2. The output from the demodulator may then comprise, for example, the phase and frequency-locked local oscillator signal or the signals X(t) and Y(t), instead of the binary bit streams QD and ID.


The demodulator may be used in a wide variety of devices to demodulate an incoming signal and/or achieve frequency and/or phase lock with the carrier signal of an incoming signal. For example, the demodulator may be used in a wireless communications device such as a mobile phone. The demodulator may also be used in wired communications devices, or in any device which may require the use of a demodulator.


Embodiments of the invention are used with signals using an example of OQPSK modulation. Embodiments of the invention may be used with signals modulated using other schemes, such as other implementations of OQPSK, QPSK and other modulation schemes.


All of the features disclosed in this specification (including any accompanying claims, abstract and drawings), and/or all of the steps of any method or process so disclosed, may be combined in any combination, except combinations where at least some of such features and/or steps are mutually exclusive.


Each feature disclosed in this specification (including any accompanying claims, abstract and drawings), may be replaced by alternative features serving the same, equivalent or similar purpose, unless expressly stated otherwise. Thus, unless expressly stated otherwise, each feature disclosed is one example only of a generic series of equivalent or similar features.


The invention is not restricted to the details of any foregoing embodiments. The invention extends to any novel one, or any novel combination, of the features disclosed in this specification (including any accompanying claims, abstract and drawings), or to any novel one, or any novel combination, of the steps of any method or process so disclosed.

Claims
  • 1. A method of carrier synchronization, comprising: determining a frequency offset estimate from a rate of change of a phase difference between a local oscillator signal and a carrier signal of a received signal; and adjusting a frequency of the local oscillator signal by the frequency offset estimate.
  • 2. A method as claimed in claim 1, wherein determining a frequency offset estimate comprises: performing a phase detection function on a first signal X(t) and a second signal Y(t), where X(t) is derived from a received signal R(t) mixed with a first local oscillator signal, and Y(t) is derived from the received signal R(t) mixed with a second local oscillator signal; and determining an estimate of a difference between the frequency of a carrier signal of the received signal R(t) and at least one of the first and second local oscillator signals from the phase detection function.
  • 3. A method as claimed in claim 2, comprising mixing the received signal R(t) with the first local oscillator signal and filtering to produce the first signal X(t).
  • 4. A method as claimed in claim 2, comprising mixing the received signal R(t) with the second local oscillator signal and filtering to produce the second signal Y(t).
  • 5. A method as claimed in claim 1, wherein determining the frequency offset estimate comprises determining a gradient of the phase difference.
  • 6. A method as claimed in claim 1, wherein determining the frequency offset estimate comprises interpolating the phase difference.
  • 7. A method as claimed in claim 6, wherein determining the frequency offset estimate comprises determining a gradient of the interpolated phase difference.
  • 8. A method as claimed in claim 6, wherein determining the frequency offset estimate comprises determining a most recent value of the interpolated phase difference.
  • 9. A method as claimed in claim 1, further comprising determining the phase difference by performing a phase detection function P(t) such that the value of P(t) at periodic instants indicates the phase difference θ between the carrier signal of the received signal R(t) and at least one of first and second local oscillator signals.
  • 10. A method as claimed in claim 9, wherein a signal X(t) is derived from a received signal R(t) mixed with a first local oscillator signal, a signal Y(t) is derived from the received signal R(t) mixed with a second local oscillator signal, the signals X(t) and Y(t) include at least one of quadrature components Q(t) and I(t) of the received signal R(t) and the periodic instants are instants where Q(t)=±I(t).
  • 11. A method as claimed in claim 9, wherein:
  • 12. A method as claimed in claim 9, wherein performing the phase detection function comprises determining N time-displaced signals Vi from P(t), wherein the signals Vi, are displaced by
  • 13. A method as claimed in claim 12, wherein determining the signals Vi comprises determining pluralities of samples Vi={v0,i, v1,i, v2,i, . . . } from P(t).
  • 14. A method as claimed in claim 13, wherein interpolating the phase difference comprises determining N interpolated signals Ti={t0,i, t1,i, t2,i, . . . } from the signals Vi.
  • 15. A method as claimed in claim 14, wherein:
  • 16. A method as claimed in claim 15, comprising calculating ωn,i using a linear regression calculation for W previous samples of Ti.
  • 17. A method as claimed in claim 16, comprising performing the linear regression calculation for each signal Vi such that:
  • 18. A method as claimed in claim 17, comprising performing, for each signal Vi, a sum of squared errors calculation such that:
  • 19. A method as claimed in claim 18, wherein determining the frequency offset estimate comprises determining at least one of Vi, Ti and ωn,i associated with the lowest value of SSEi.
  • 20. A method as claimed in claim 1, comprising providing the frequency offset estimate to a controllable oscillator.
  • 21. A method as claimed in claim 1, wherein the received signal R(t) is an OQPSK signal.
  • 22. (canceled)
  • 23. (canceled)
  • 24. A data processor arranged to: determine a frequency offset estimate from a rate of change of a phase difference between a local oscillator signal and a carrier signal of a received signal; and adjust a frequency of the local oscillator signal by the frequency offset estimate.
  • 25. A data processor as claimed in claim 24, wherein determining a frequency offset estimate comprises: performing a phase detection function on a first signal X(t) and a second signal Y(t), where X(t) is derived from a received signal R(t) mixed with a first local oscillator signal, and Y(t) is derived from the received signal R(t) mixed with a second local oscillator signal; and determining an estimate of a difference between the frequency of a carrier signal of the received signal R(t) and at least one of the first and second local oscillator signals from the phase detection function.
  • 26. A data processor as claimed in claim 25, arranged to mix the received signal R(t) with the first local oscillator signal and to filter the mixed signal to produce the first signal X(t).
  • 27. A data processor as claimed in claim 25, arranged to mix the received signal R(t) with the second local oscillator signal and to filter the mixed signal to produce the second signal Y(t).
  • 28. A data processor as claimed in claim. 24, wherein determining the frequency offset estimate comprises determining a gradient of the phase difference.
  • 29. A data processor as claimed in claim 24, wherein determining the frequency offset estimate comprises interpolating the phase difference.
  • 30. A data processor as claimed in claim 29, wherein determining the frequency offset estimate comprises determining a gradient of the interpolated phase difference.
  • 31. A data processor as claimed in claim 29, wherein determining the frequency offset estimate comprises determining a most recent value of the interpolated phase difference.
  • 32. A data processor as claimed in claim 24, arranged to determine the phase difference by performing a phase detection function P(t) such that the value of P(t) at periodic instants indicates the phase difference θ between the carrier signal of the received signal R(t) and at least one of first and second local oscillator signals.
  • 33. A data processor as claimed in claim 32, wherein a signal X(i) is derived from a received signal R(t) mixed with a first local oscillator signal, a signal Y(t) is derived from the received signal R(t) mixed with a second local oscillator signal, the signals X(t) and Y(t) include at least one of quadrature components Q(t) and l(t) of the received signal R(t) and the periodic instants are instants where Q(t)=±I(t).
  • 34. A data processor as claimed in claim 32, wherein:
  • 35. A data processor as claimed in claim 32, wherein performing the phase detection function comprises determining N time-displaced signals Vi from P(t), wherein the signals Vi are displaced by
  • 36. A data processor as claimed in claim 35, wherein determining the signals Vi comprises determining pluralities of samples Vi={v0,i, v1,i, v2,i, . . . } from P(t).
  • 37. A data processor as claimed in claim 36, wherein interpolating the phase difference comprises determining N interpolated signals Ti={t0,i, t1,i, t2,i, . . . } from the signals Vi.
  • 38. A data processor as claimed in claim 37, wherein:
  • 39. A data processor as claimed in claim 38, arranged to calculate ωn,i using a linear regression calculation for W previous samples of Ti.
  • 40. A data processor as claimed in claim 39, arranged to perform the linear regression calculation for each signal Vi such that:
  • 41. A data processor as claimed in claim 40, arranged to perform, for each signal Vi, a sum of squared errors calculation such that:
  • 42. A data processor as claimed in claim 41, wherein determining the frequency offset estimate comprises determining at least one of Vi, Ti and ωn,i associated with the lowest value of SSEi.
  • 43. A data processor as claimed in claim 24, arranged to provide the frequency offset estimate to a controllable oscillator.
  • 44. A data processor as claimed in claim 24, wherein the received signal R(t) is an OQPSK signal.
  • 45. A demodulator comprising: an input for receiving a received signal R(t); a controllable oscillator for generating a first local oscillator signal; a system for generating a second local oscillator signal; a first mixer for mixing the received signal R(t) with the first local oscillator signal; a first filter for filtering an output of the first mixer to produce a first signal X(t); a second mixer for mixing the received signal R(t) with the second local oscillator signal; a second filter for filtering an output of the second mixer to produce a second signal Y(t); a data processor arranged to perform a phase detection function on X(t) and Y(t) and determine a frequency offset estimate from a rate of change of the phase detection function; a loop filter for filtering the estimate to produce a control value and providing the control value to the controllable oscillator.
  • 46. A data processor implementing the demodulator as claimed in claim 45.
  • 47. (canceled)
  • 48. (canceled)
  • 49. (canceled)
  • 50. (canceled)