This application relies on the priority of U.S. Provisional Application Ser. No. 60/648,762 filed on Jan. 31, 2005 having the same title as the present application.
This invention relates generally to the field of frequency offset correction in signal demodulation and, more particularly, to an improved coordinate rotation digital computer (CORDIC) for rotation angle calculation.
Legacy communications systems such as the Personal Handy-phone System (PHS) are configured to be simple and low cost. Differential demodulation has been adopted based on the technological constraints present at the time of designing these systems for baseband demodulation and therefore does not have the capability to combat inter-symbol-interference typically introduced by multi-path fading.
It is therefore desirable to provide a modernized baseband design compatible with or to retrofit these legacy systems. It is further desirable to employ advanced DSP algorithms and introduce adaptive equalization to realize coherent demodulation. It is further desirable to provide enhanced frequency offset determination capability and improved rotation angle calculation.
To enhance the speed and simplicity of hardware implementation of the rotation angle calculation, it is desirable to use shift and add operations, eliminating multiplication operations.
A CORDIC angle calculator for a baseband IC receiver provides a CORDIC algorithm calculating processor. An input scaling means receives input data, scales the input data and provides it to the CORDIC processor. An output scaling means receives output data from the CORDIC processor and rescales the output data to provide a calculated angle. In an exemplary embodiment, the input scaling means includes means for shifting the input data for bit reduction and providing a shift signal corresponding to the input data shift and wherein the output scaling means is responsive to the shift signal.
In the exemplary embodiment, the CORDIC angle calculator incorporates an input initialization function and an Angle Accumulation Initialization function for acting on angle data larger than π/2. A 16 bit adder receives a 12 bit input X0 from the input initialization function and prior increment data stored in a first register. A shift register receives Y0 input from the input initialization function and right shifts the data n bits where n=0, 1 . . . 11 with a sign set based on a SIGN output. A second 16 bit adder receives a 12 bit input Y0 from the input initialization function and prior increment data from a second register. A second shift register receives X0 from the input initialization function and right shifts n bits for input to the second adder with its sign set based on the SIGN output. The output of the second adder is the sign output, and the sign for the first shift register output is (−1)sign and the sign for the second shift register output is −(−1)sign. A third shift register rescales an output of the first adder using the shift bits output from the input scaling. An angle accumulator receives input from the Angle Accumulation Initialization function and a prior sample from a second prior sample register and a new input from a CORDIC Lookup table which is unsigned. The sign of the table input to the angle accumulator is determined based on the SIGN output from the second adder with the sign determined as −(−1)sign. Rounding and saturating of the output from the angle accumulator is accomplished and provides an output as a correction angle for use in carrier recovery and initial signal rotation.
These and other features and advantages of the present invention will be better understood by reference to the following detailed description when considered in connection with the accompanying drawings wherein:
The present invention is defined for an exemplary embodiment employed with a PHS communication system and standard (a 2G legacy mobile system). A complete description of the exemplary system is provided in copending patent application Ser. No. 60/693,457, attorney docket no. U001 100150P filed on Jun. 22, 2005 and entitled FAST CONVERGENCE ADAPTIVE EQUALIZATION IN PHS BASEBAND DEMODULATION, the disclosure of which is incorporated by reference as though fully set forth herein.
As shown in
The converted digital signal is passed to a hardware accelerator 14 and further filtered and decimated 16 to 3× symbol rate, e.g. 576 kHz. This signal first passes a Carrier Recovery block 18 and then a Rotator block 20 and then to a storage register 22 which for the embodiment disclosed herein is a dual or A/B register. The function of Carrier Recovery block is to detect the burst and estimate carrier frequency offset between received and transmitted signals. This allows the following Rotator block to compensate the carrier offset. This rotated signal is then passed to a DSP 24 with an Equalizer 26. An adaptive decision-directed equalizer is applied where the training sequence is the unique word (UW) in the burst. Therefore an accurate position of UW is required. This information is acquired via a correlation block 28. The input data is correlated with UW and therefore, after the peak of the correlation result is detected, the UW location in the burst data can be determined. This process, typically known as conventional coherent detection, is employed in the present invention even though the base-band modulation is DQPSK. Theoretically this kind of coherent detection can have 3 dB better performance than differential detection.
As for every coherent demodulator, the recovery of the carrier is most crucial. Its quality impacts the performance of the function blocks at later stages. The most widely used carrier frequency recovery scheme is automatic frequency control (AFC). However in the PHS system, the data is transmitted in burst mode, therefore the response time for AFC to be stable is relatively short, normally within a few to tens of symbols. Therefore open-loop carrier frequency estimation is employed in the present invention. Slow tracking circuitry is then applied to follow the slow varying carrier characteristics.
In the coherent demodulation of PSK signals, carrier frequency offset due to either limited oscillator precision or the Doppler effect caused by moving vehicles, can cause a significant loss in performance. In the PHS system, the system base station or cell station (CS) may have offset of up-to ±2 ppm and mobile or personal station (PS) may have offset of up-to ±5 ppm. Correcting the frequency offset in such demodulation will help improve receiver performance and relieve the stringent accuracy requirements on an oscillator and therefore reduce cost.
The Carrier Recovery block of the PHS employing the present invention has two basic functions, one is to detect a TDD (time division duplex) burst and the other is to estimate the carrier frequency offset between the received and the transmitted signal. This estimated carrier offset is employed either to drive a rotator to compensate the offset in received signal or to drive an AFC to correct frequency of the local carrier generator.
For a TDD system like PHS, the synchronization between PS and CS is extremely important as the first step in building the communication link. When the system is powered on for the first time, there is no timing information whatsoever. It is the PS's task to seek the timing information from the received air signal. Therefore for PS to acquire the timing information from CS, it needs to search for the proper indication. In PHS, the preamble signal (PR) in the control slot has appropriate characteristics to be used to detect such a burst (or slot).
As shown in
The present invention is incorporated in a CORDIC (coordinate rotation digital computer) algorithm for angle calculation in the demodulation system of the embodiment disclosed. CORDIC is an iterative solution for a wide range of functions, such as sine, cosine, tangent, arctangent, vector magnitude, etc. It is best known for its hardware implementation efficiency since it only uses shifts and adds instead of multiplications.
The CORDIC algorithm is derived from the general rotation transform,
x′=x cos(θ)−y sin(θ)=cos(θ)·(x−y·tan(θ))
y′=x sin(θ)+y cos(θ)=cos(θ)·(y+x·tan(θ))
If θ is defined as θ=arctan(1/2i), then the multiplication of tan(θ) can be reduced to a shift. An arbitrary angle rotation can be achieved by performing a series of elementary rotations. Each rotation direction is decided by di, where di=±1. The equations of a series rotations are
xi+1=ki·(xi−di·yi·2−i),
yi+1=ki·(yi+di·xi·2−i),
where ki=1/√{square root over (1+2−2i)} and di=±1.
The accuracy of CORDIC algorithm depends on both the bit precision of the input data and the iteration times. In general, the CORDIC algorithm can produce one additional bit of accuracy if the iteration times or input bit precision are increased by one.
An angle calculator arctan(I/Q) can be realized using the following iterative equations,
xi+1=xi−di·yi·2−i,
yi+1=yi+di·xi·2−i,
and zi+1=zi−di·arctan(2−i), where di=1 if yi>0, di=−1 otherwise.
The initial value of the equations are x0=I, y0=Q and z0=0. Then after n iterative times, we have xn=An√{square root over (I2=Q2)}, yn=0, zn=arctan(I/Q), where
For the embodiment of the invention disclosed herein, the number of iterations is chosen as n=12 and the arctangent table employed is 12×16. The form of the table is shown in Table 1 where π can be represented as 0×10000.
An exemplary CORDIC Angle Calculator 36 employed in the present embodiment of the invention is shown in
The CORDIC angle calculator receives the I and Q data from the decimation filter and incorporates the scaling function for the input. The scaling function incorporates a shift register 40 to shift the I and Q data and provides a shift bits output 42 which is employed in re-scaling the amplitude output, as will be described subsequently.
An input initialization function 44 and companion Angle Accumulation Initialization function 46 are employed for acting on angle data larger than π/2. The initialization function is accomplished as shown in
A physical embodiment of the CORDIC Angle Calculator 36 incorporates a 16 bit adder 48 receiving the 12 bit input X0 and prior increment data stored in register 50. A shift register 52 receives the Y0 input and right shifts the data n bits where n=0, 1 . . . 11 with a sign set based on the sign output 54. Similarly, a second 16 bit adder 56 receives the 12 bit input Y0 and prior increment data from register 58. A second shift register 60 receives X0 and right shifts n bits for input to the second adder, again with its sign set based on the SIGN output. The output of the second adder, sign, determines the sign for the first shift register output as (−1)sign and the sign for the second shift register output as −(−1)sign. The output of the first adder is rescaled in shift register 62 using the shift bits output from the input scaling. The rescaled data is then employed for calculation of the signal amplitude for further use in carrier recovery as will be described subsequently.
Actual angle calculation is achieved based on the Angle accumulator initialization as previously described which is input to the angle accumulator 64 with the prior sample stored in register 66 and the new input from the CORDIC Lookup table 68 which is unsigned. The sign of the table input to the Angle accumulator is determined based on the SIGN ouput from the second adder, previously described, with the sign determined as −(−1)sign. The output from the Angle accumulator is then operated on to round and saturate 70 and output as the correction angle 72 for use in carrier recovery and initial signal rotation.
The burst detector 30 is employed to detect a TDD burst. In PHS, the PR signal in the control slot provides a suitable signature for detection. For a received in-band signal, sr(t)=A(t) cos(Δωct+θ′(t)+φ)+n(t), where
g(t) is a raised-cosine pulse, Δωc is the carrier offset, θ′(t) is the receiver modulation phase and φ is the fixed phase offset between transmitter and receiver, n(t) is white Gaussian noise. The phase signal of Sr(t) is simply phz(t)=2πΔft+θ(t)+φ if the difference between the transmitter modulation phase and receiver modulation phase is ignored.
After a single differentiator, the phase difference becomes
phzDiff1(t)=phz(t)−phz(t−T)=2πΔfT+θ(t)−θ(t−T). The single differentiated signal is a periodic signal centered at 1/4 π+2πΔfT with period of 2T, and the phase value is within
After a double differentiator, the phase becomes phzDiff2(t)=phzDiff1(t)−phzDiff1(t−T)=θ(t)+θ(t−2T)−2θ(t−T). The double differentiated signal is a periodic signal centered at 0 and with period of 2T. The value of the signal is within [−π,π].
The burst detect algorithm is derived by taking advantage of this characteristic of PR. Let
where M is the window length. M=16 for the embodiment described herein. The above equation can be simplified
If sumPhase is less than a burst detect threshold ThB then a burst is detected. For exemplary embodiments, ThB=3*π.
The burst detector of
The average detector 74 of
Derived amplitude from the CORDIC angle calculator is used to perform average detection. The calculated instant amplitude value is smoothed through an alpha filter E{A}n=(1−α)E{A}n−1+α·An, where α is a register. After about 20-30 symbols (60-90 samples), the average value is a good prediction of true average signal. The block diagram of an embodiment of the average detector is shown in
This average detection is reset at each burst. The input to the average detector is provided by the amplitude output 76 of the CORDIC angle calculator.
Since the instant amplitude is calculated as a by-product of angle calculation, the input to the average detector is continuous during the PR searching stage. However it does not produce meaningful value since the burst boundary is not clear. Therefore the average detector is disabled during burst search. When carrier recovery enters BCCH searching mode, the burst boundary is somewhat clearer. During this period, the average detector is triggered to begin processing for a time period during every burst, and the resulting value is sent to the DSP with the burst data indicating the respective CS transmitted signal strength. The average detector is enabled and reset at beginning of every burst. After one CS is selected, the respective average value can be used to set PGA gain.
The carrier offset calculator 32 of
After modulation, the transmitting signal is represented as
where gr(t) is the root-square raised cosine shaping filter, and ωc is the carrier frequency in radius and T is the symbol time period. θ(t) is the modulation phase. For π/4-shift DQPSK modulation in PHS, θ(t)=θ(t−T)+Δθ(t), and the relation between transmit symbol (ak, bk) and Δθ(k) is listed in Table 2
On the receiver side, a root-square raised cosine matched filter is applied and hence the base-band demodulated signal can be represented as
sr(t)=A(t)cos(Δωct+θ′(t)+φ)+n(t)
where
g(t) is raised-cosine pulse, Δωc=2πθfc is the carrier offset, θ′(t) is the receiver modulation phase and φ is the fixed phase offset between transmitter and receiver, and n(t) is white Gaussian noise.
Let x(t)=E{sr(t)sr*(t−2T)}, where Sr*(t) is the conjugate of sr(t), resulting in
x(t)=σAej[2Δωt+θ(t)−θ(t−2T)]+N(t), where σA=E{A(t)2}, and
N(t)=E{sr(t)n*(t−2T)}+E{n(t)sr*(t−2T)}+E{n(t)n*(t−2T)} is the noise term and is ignored without loss of generality.
In PHS, PR is a periodic signal with a bit stream pattern of “1001”, resulting in θ(t)−θ(t−2T)=−π/2. Let x1(t)=E{A2(t)}sin(2ΔωcT) and xQ(t)=E{A2(t)}cos(2ΔωcT), where x1(t), XQ(t) are the in-phase and quadrature part of x(t), respectively.
If x1(t) and XQ(t) is being accumulated for N symbols, where N is the searching window,
The amplitude is defined as Amp(k)=Acqi2(k)+Acqq2(k), where k=0, 1, . . . m−1 and 0≦t0≦T is the sampling time. T1 is the sampling period where T=mTs and m is the number of the sample points within a symbol period.
After a burst is detected, the carrier offset Δfc can be estimated by finding max{Amp(k)} for each k=0, 1, . . . m−1, over a window length N. Let Amp(k0)=max{Amp(k)} correspondent to each k, where A0=A2(t0+k0Ts+nT), n=0, . . . N−1, then the carrier offset can be calculated as
The Carrier offset calculator is triggered by the burst detection flag 78. I/Q data is entered into a delay buffer. For use in the present embodiment of the invention, the delay buffer employs a sliding window summing arrangement for more efficient storage. Further disclosure of the delay buffer is provided in copending patent application Ser. No. 11/306986, Attorney docket no. U001 100148, entitled Storage Efficient Sliding Window Sum, filed Jan. 18, 2006 which is incorporated by reference as though fully set forth herein.
This module can be bypassed by setting the control register. Another flag to control carrier offset calculator is an enable flag. During TCH, the carrier offset calculator is no longer working, therefore the enable flag can be set to disable to save power. The data will then merely flow through the delay buffer into the rotator.
Having now described the carrier recovery elements and returning to
For a complex represented input signal x=x1+jxQ, if the rotation angle is θ, then the output of the rotator is y=y1+jyQ, where y1=x1 cos(θ)−XQ sin(θ) and yQ=X1 sin(θ)+XQ cos(θ). Direct operation on the rotation involves 4 multiplications and 2 additions for each sample. Moreover, there is a calculation of sin( ) and cos( ) functions.
The CORDIC algorithm is again employed in the present invention to realize vector rotation, which reduces cost by using only shifts and adds instead of multiplications. Iteration is again selected at 12 and the size of the CORDIC table is 16×12 allowing common table use with the CORDIC angle calculator in the Carrier Recovery system.
Basic operation of the rotator is again described with respect to
12 cycles are required for one data rotation in the current embodiment based on the input signal 12 bit width.
A physical implementation of the CORDIC is shown in
SIGN calculation is achieved based on input θ from the Rotation Angle Register with an angle accumulator initialization 97, described in detail subsequently, which is input to angle accumulator 95 with the prior sample stored in register 93 and the new input from the CORDIC Lookup table 91 which is unsigned. The sign of the table input to the angle accumulator is determined based on the SIGN ouput from angle accumulator, with the sign determined as −(−1)sign. The output from the angle accumulator also provides the SIGN for operation in the first and second adder as previously described.
The Angle Accumulator Initialization for the CORDIC Rotator is shown in
For each TDD burst, the initial phase is unknown and therefore the initial phase, PR and UW are unknown due to π/4−DQPSK modulation. Let r(t)=a(t)ej2πΔft+φ(t)+θ
After the first rotator, the initial phase θ0 and estimated frequency offset phase 2πΔft are removed, provided that θ0 can be derived which will be described subsequently, we have r1(t)=r(t)*e−j(θ
r2(t) is the signal after the information-bearing phase θ(t) is removed, r2(t)=r1(t)*e−φ(t)=α(t)ej(2πΔf
The quadrature part of r2(t) is therefore r2q(t)=α(t) sin(2πΔfEt+θn(t)). Properly choosing an average window can smooth out the noise phase. A smoothing window of 6 symbols is employed in the embodiment of the invention disclosed herein. Therefore we have
The frequency offset adjustment is done according to the differential of sumq(t).
θ0 can be derived based on UW which is detected by correlation. corr(t)=r(t)*e−jφ
If Δf is small enough to be ignored, then we have,
A slow tracker is implemented in the present embodiment described as shown in
Having now described the invention in detail as required by the patent statutes, those skilled in the art will recognize modifications and substitutions to the specific embodiments disclosed herein. Such modifications are within the scope and intent of the present invention as defined in the following claims.
Number | Date | Country | |
---|---|---|---|
60648762 | Jan 2005 | US |