In frequency shift key (FSK) communication systems, the transmitting frequency and the receiving frequency have to fee the same for optimal performance. Due to anomalies, such as the crystal differences between a transmitter and a receiver, the frequencies may be different, which results in communication errors.
A frequency shift key (FSK) receiver includes a phase compensator for compensating for frequency differences in a transmitter that transmits a FSK signal to the receiver. The phase compensating is performed before the FSK signal is demodulated by the receiver.
Communication systems require a transmitter node and a receiver node operating on the same frequencies. When the frequencies are offset from one another, errors in the communications will occur. In some examples, crystals in the transmitter and receiver nodes are slightly different, which results in frequency offsets. Frequency compensation is applied in the receiver in many situations to compensate for the frequency offsets. For example, components within the receiver estimate the frequency offset and compensate for the frequency offset accordingly.
One communication system where frequency compensation is applied is in frequency shift key (FSK) signaling or modulation.
During FSK communications, a preamble is transmitted to the receiver. The preamble contains repetitive “01010101” bit patterns that can be used to perform frequency offset estimations. The bits are sometimes referred to as symbols in FSK communications. In the following example, the input sample rate is four times that of the FSK symbol rate. More specifically, the symbols or bits are sampled at a rate that is four times faster than the symbol or bit rate, which is referred to as a four times oversampling. Due to the four times oversampling and because the input data can start from anywhere inside a preamble repetition, the receiver needs to search eight consecutive locations in the preamble to find the best sample phase for a zero bit. In order to distinguish between a zero bit and a one bit, there are eight possible sampling phases (eight samples on two bits). It is noted that due to pulse-shaping in the transmitter, the phase difference between two samples may not be the same even for the 4 samples in a single bit. The best sample phase is detected by the largest phase difference between samples. In some examples, the average of a certain number of preamble bits is averaged to find the largest phase difference for a zero bit or a one bit.
In the following example, it is assumed that a synchronization module has already found the starting sample phase of a zero bit in the preamble. A demodulator in the receiver calculates the phase rotation between two adjacent samples per equation (1) as follows:
Y
n=atan2(imag(XN*conj(XN-1)),real(XN*conj(XN-1))) Equation (1)
where atan2 is a four quadrant arctangent function that returns a value within −π and π, YN is the output for the Nth input sample XN, and XN-1 is the previous input sample. Functions other than atan2 that return or identify angles as known by those skilled in the art may be used in place of equation (1).
In examples where an FSK communication has a modulation index of one and four times oversampling versus the symbol rate, the nominal phase differences between adjacent samples are +/−π/4, depending on the instantaneous frequency being positive or negative. In some examples, positive instantaneous frequencies render an increasing phase of +π/4 from one sample to the next. Negative instantaneous frequencies render a decreasing phase of −π/4 from one sample to the next. For ease of discussion, it is assumed that zero bits map to a positive frequency and the phase difference between adjacent samples in zero bits maps to +π/4. One bits map to a negative frequency, so the phase difference between adjacent one bit samples maps to −π/4. In the example of Gaussian frequency shift keying (GFSK), Gaussian filtering is applied so the demodulator output for samples at the beginning and end of a symbol period have absolute values that are less than π/4. In examples where the modulation index is 0.5, the phase difference is half of the value versus the examples with a modulation index of one. Accordingly, the phase differences are +/−π/8.
In order to make the frequency offset estimation more accurate, only two samples are used for each bit or FSK symbol to perform the phase differentiation. Phase differentiation is a determination of the phase difference between two samples on the same FSK symbol or bit. The samples are taken near the middle of the bits for maximum phase differentiation. The samples are then demodulated by a demodulator. The output DK of the demodulator is defined by equation (2) as follows:
D
k
=Y
4k+2 Equation (2)
Due to the repetitive zero/one bit pattern in the preamble, the demodulator output Dk should alternate between +45 degrees (+π/4) and −45 degrees (−π/4). Because there are an equal number of ones and zeros in the preamble, the sum of all the demodulator outputs Dk in an integer number of preamble repetitions should ideally equal zero.
When there is a carrier frequency offset, the demodulator output will contain a constant phase rotation between adjacent samples. For example, in a 50 ksps FSK, a 60 ppm frequency offset for a 928 MHz carrier results in about 55.7 kHz frequency offset. This frequency offset translates into a phase rotation of about one-hundred degrees between consecutive samples at the four times sample rate described above.
As described above, the demodulator outputs are approximately +45 degrees and −45 degrees without frequency offsets.
P
0=mean(Dk) Equation (3)
The frequency offset is sometimes referred to as a frequency offset estimation and is equal to a constant multiplied by the mean phase offset P0 as shown by equation (4) as follow:
Frequency Offset=constant*P0 Equation (4)
The constant, which may be a constant scalar, can be determined by curve fitting. For example, a 50 ksps FSK signal operating at a four times sampling rate has a constant that is equal to 34.17, which is determined by a curve-fitting simulation.
In some situations, noise causes the output (phase difference) of the demodulator to be greater than 180 degrees, which provides a poor frequency offset estimation. With regard to the examples described above, a 50 ksps FSK having a modulation index of 1.0 with 40 ppm frequency offset at 928 MHz has a phase rotation between two adjacent samples that is up to 111.8 degrees. In a high noise scenario, the phase rotation between two adjacent samples can easily go beyond 180 degrees. As described above, the atan2 function operates in the demodulator, so the output wraps to n, which invalidates the frequency offset estimation result.
The circuits and methods described herein improve the frequency offset estimation by reducing the probability of the atan2 calculation, or a calculation based on a similar function, overflowing. More specifically, the circuits and methods provide for frequency offset compensation that does not cause the atan2 function to exceed π. In summary, phase compensation is performed before the preamble samples are used to determine the frequency offset estimation. The phase compensation partially or entirely removes the constant phase change of the FSK signal between two consecutive samples, which reduces the probability of the atan2 calculation overflowing. Therefore, the frequency offset estimation is improved, especially in low signal-to-noise ratio operating conditions. In some examples, a phase compensation module is provided to compensate the preamble signals before demodulation.
The circuits and methods described herein provide improvement for frequency offset estimation, including in low signal to noise ratio (SNR) environments. The examples described herein have a modulation index of 1.0, but the algorithms described herein are applicable to other modulation indices. In addition, the following examples map zero bits to a positive frequency and map one bits to a negative frequency. Ignoring any frequency offset, in the four samples of zero bits, each sample rotates 45 degrees from its previous sample, while in the four samples of the one bits, each sample rotates −45 degrees from its previous sample. This ±45 degree rotation is without any frequency offset, so the average is calculated over multiple preambles and cancels to zero. Because the average cancels to zero, it is not relevant to the frequency offset estimation. However, it still reduces the margin of the atan2 function and makes it easier or more likely to get an overflow from −π to π.
The circuits and methods described herein reduce the impact of the constant phase rotation from the FSK signal itself, providing more headroom for Dk and P0 calculation for the frequency offset. These circuits and methods reduce the probability of overflowing the atan2 function, which provides more accurate frequency offset estimation.
Z
N
=X
N
*C
t
,i=0.1 Equation (5)
Y
n=atan2 (imag(ZN*conj(XN-1))),real(ZN*con;(XN-1))) Equation (6)
where Ci is the phase compensation vector. The compensation vector removes the constant phase partially or entirely. For example, Ci=e−jp, where p is the compensation phase shift, which is described below. C0 is the phase compensation vector for zero bits and C1 is the phase compensation vector for one bits. C0 and C1 are conjugates of each other so that they can be canceled when the demodulator output of several preamble bits are averaged. The value of the compensated phase shift can be any value between 0 and π/4 for FSK signals with modulation indices of 1. For modulation indices of 0.5, the compensated phase shift is between 0 and π/8. The remaining algorithms are the same as prior algorithms described in equations (2)-(4) to calculate the frequency offset.
In one example a 50 ksps FSK signal with a modulation index of 1 is analyzed. Ignoring frequency offset, the adjacent samples have a +45 degree phase difference for zero bits, and a −45 degree phase difference for one bits. The compensation vectors are set as C0=e−jπ/8 and C1=ejπ/8 which corresponds to the +45 degree and −45 degree phase differences. The phase difference is calculated on the compensated sample and the second sample for each preamble bit and averaged over 4 preamble bytes to obtain the mean phase offset P0 for the frequency estimation. Once P0 is determined, equation (4) is used to map the frequency offset estimation, which is applied to the FSK signal.
In some examples, the circuits and methods described herein are used for wireless smart utility networks operating in the 902-928 MHz ISM frequency bands. In this situation and others, oversampling rates of two times the FSK symbol rate or greater, such as four times or eight times the FSK symbol rate may be used. In some examples, the atan2 function can be replaced by any angle estimation function as known by those skilled in the art. Any FSK symbol rates can be used such as 50 ksps, 100 ksps, 150 ksps, 200 ksps, or 300 ksps. Modulation indices can be any integer plus fractional value such as 0.5, 0.75, 1.0, 1.5, and 2.0. This method can also be extended from 2FSK to 4FSK since the preamble is typically sent using only 2 constellation points.
While some examples of FSK communications have been described in detail herein, it is to be understood that the inventive concepts may be otherwise variously embodied and employed and that the appended claims are intended to be construed to include such variations except insofar as limited by the prior art.
This application claims the benefit of U.S. provisional patent application 62/154,507 of Wenxun Qiu filed on Apr. 29, 2015 for A HEW METHOD OF FREQUENCY OFFSET ESTIMATION FOR FSK, which is incorporated herein for all that is disclosed,
Number | Date | Country | |
---|---|---|---|
62154507 | Apr 2015 | US |