Method of operating a receiver to process a preamble of a data packet, and to a receiver operating in accordance with the method
An improved receiver for use in a data pocket communications is provide, where the process of configuring the gain of the receiver and identifying a preamble in the data packet are made more robust. The improved receiver does not need to rely on the received power level exceeding a trigger threshold to initiate the gain control. Instead the gain control runs while the receiver is waiting for a data packet. The frequency correction process can run concurrently with the gain control process.
Latest Analog Devices Global Patents:
- Insulation jacket for top coil of an isolated transformer
- Via for magnetic core of inductive component
- System comprising a package having optically isolated micromachined (MEMS) switches with a conduit to route optical signal to an optical receiver and related methods
- Storing charge associated with electrical overstress
- Antenna array calibration systems and methods
The present disclosure relates to methods of and apparatus for improving the accuracy of detection of a preamble in a communication system. This is achieved without requiring the duration of the preamble to be increased.
BACKGROUNDThere are many wireless communication systems in use. These frequently employ the use of data packets to transmit data between the transmitter and receiver.
The receiver does not know in advance when a transmitter wishes to initiate transmission of a message. Existing receivers tend to “listen” for potential signals whose energy exceeds a threshold. Once the threshold is exceeded the receiver attempts to perform automatic gain control, AGC, during a period which should encompass a preamble of a data packet if the signal which has exceeded the threshold value turns out to be a data packet. The receiver can be triggered by noise or other interference or temperature or environmental factors that will impact the composite receiver gain. Such interference may occur sufficiently close to the start of a data packet such that it interferes with the automatic gain control function implemented within the receiver.
SUMMARY OF THE DISCLOSUREThe present disclosure relates to an improved method of operating a receiver such that its gain adjustment process is more robust in the presence of interfering signals.
According to a first aspect of this disclosure there is provided a method of operating a receiver to process a preamble of a data packet. The method comprises performing a receiver gain adjustment by using a gain controller to adjust the gain of a radio frequency amplifier of the receiver. The gain control operation starts in advance of the reception of the data packet and runs until such time as the receiver has identified the preamble, or a portion of the preamble, to a sufficient level of confidence. Once the preamble is identified the gain control operation is terminated and the gain can then remain fixed for reception of the remainder of the data packet.
Preferably a receiver frequency offset correction is performed concurrently with the gain adjustment being performed. Performing both operations of gain and frequency adjustments in parallel allows improved accuracy to be achieved in “locking” onto the data packet without requiring the preamble sequence to be extended. This approach also gives each of the automatic gain control and frequency offset correction processes more of the preamble to work with compared to prior art schemes.
According to a further aspect of this disclosure there is provided a radio receiver operating in accordance with a method of the first aspect.
The radio receiver may be provided in association with a transmitter so as to allow bidirectional communication with a remote device.
The method and receiver disclosed herein can be used for data communication in accordance with keying schemes such as Gaussian frequency shift keying, GFSK, transmission schemes. Such schemes may be used for communication between multiple devices to operating in an ad hoc network, for example as part of an “internet of things” IOT, network located around a dwelling or business, as well as on personal devices, including entertainment and fitness trackers, or on medical devices and industrial devices requiring the ability to transmit data over relatively short ranges.
Embodiments of the present disclosure will now be described, by way of non-limiting example only, with reference to the accompanying Figures, in which:
As mentioned before there are several wireless communication schemes that transmit data between transmitter and receiver in the form of data packets.
When the transmitter 1 of
The receiver 10 of
As will be discussed later, the automatic frequency correction process may merely act to estimate the difference or offset between the carrier wave of frequency the transmitter and the nominal receive frequency of the receiver. Completion of the automatic frequency correction process results in an AFC done signal 44 being asserted. Assertion of the AFC done signal initiates the commencement of a procedure to identify the access address encoded in the data packets. This is performed during the time period indicated by block 50 and once the access address signal has been found and decoded an access address found signal 52 is asserted. If the access address 50 corresponds to the address of the receiver, the receiver then proceeds to receive and decode the data payload 26. If the addresses do not match then the receiver knows that the data is not intended for it and if so desired can ignore the remainder of the packet such that it can re-enable the energy and packet detect process for monitoring the receipt of a subsequent packet.
In, for example, the Bluetooth low energy transmission scheme the preamble has a relatively short duration of 8 μs. The scheme shown in the approach of
If the energy detect signal becomes asserted too early, for example due to an impulsive interference signal, then it is likely that the automatic gain controller will cause the gain to be set to an incorrect gain setting. The gain setting is likely to be the most sensitive setting since the gain was set in the absence of a signal for part of the setting time. Once the data packet actually arrives then it is likely that the data packet's power level will cause the analog to digital converter or other items within the signal chain to saturate. Additionally, in the arrangement of
If the energy detect signal gets asserted too late, for example because the energy of the signal being received at the receiver is close to the sensitivity threshold of the receiver, then it is likely that the AGC will have to make no or little gain correction. However, the automatic frequency correction step is likely to fail as it may not complete, or indeed have started, whilst the preamble is being transmitted. If the AFC stage fails or provides its AFC done signal belatedly, then the access address detect step is likely to fail as it would have started the hunt too late to complete successfully.
The present inventors realized, among other things, that an improvement in reliability could be achieved by discarding the energy detect step which initiates the gain correction. Instead, as the receiver has already been listening for signals as this will be required in order to trigger the energy detect process, the AGC process can be left running whilst the receiver is waiting for a packet to arrive.
As shown in
Thus, rather than running a completely serial set of steps, the processing steps can be rearranged such that some of them run in parallel and for longer and such that the gain correction and control and frequency correction processes are not dependent upon accurate timing of an energy detect signal, or indeed to not rely on the presence of an energy detect signal at all.
Outputs of the filters 108 and 110 are provided to analog to digital converters 120 and 122. The analog to digital converters 120 and 122 convert the analog signal into a series of digital codes. The digital outputs from the analog to digital converters 120 and 122 may be provided to an automatic gain controller 140 such that it can examine the output codes to make sure that the analog to digital converters are not being saturated or running close to saturation or alternatively that they are not being operated too close to their noise floor. Typically the automatic gain controller 140 is implemented as a state machine. The digital outputs of the analog to digital converters 120 and 122 may then be provided to interpolators and digital filters 150 and 152 before being provided to a digital front end 160. Alternatively, the digital front end may accept the outputs of the outputs of the analog digital converters directly. The digital front end processes the digitized I and Q channels of the quadrature detector in order to reconstitute the data signal as known to the person skilled in the art.
The demodulated signal (which is representative of the frequency deviation of the GFSK signal) is monitored by a preamble correlator 180 which seeks to identify the preamble to a predetermined degree of accuracy, and also can take over the job of calculating the automatic frequency correction result to provide a correction value which is used to adjust the demodulated signal from the digital front end 160. The adjustment may be made by way of a summer 182. Once the preamble has been located then the receiver may also enable recovery of the data provided in the packet, possibly by way of a bit recovery circuit 190 whose operation may be modified by a timing synchronization circuit which controls the opening of a sampling eye of the bit recovery circuit in order that the receive signal may also act as its own data clock. This will be discussed in greater detail later.
The analog to digital converters and digital front end operate in oversampled manner. Thus the symbol representing a “1” may be oversampled N times. Typically N is an integer number and in this example is chosen to be eight. The symbols are both bandwidth limited and potentially shaped, and hence do not have a square wave form. Typically they follow a half sinusoid or Gaussian-like shape.
If we assume that the demodulated signal does indeed contain a preamble, then the output of the first correlator 202 is represented by
The action of each correlator can be represented by the following equation:
It can be noted that the use of parallel correlators reduces the number of samples required for each correlator to identify the correlation that it is looking for. This has the advantage of giving the designer greater flexibility about the number of minima, or maxima, from the combined output that need to be processed in order to provide an acceptable degree of certainty that the preamble has been located.
The correlation calculation includes an average value of the correlation window. However the average value turns out, as will be described later, to be representative of the frequency correction that needs to be applied and therefore needs to be taken into account to make sure that the correlator output values do not become shifted towards a greater or lesser values in the code space represented in
The output of the digital to analog converters are typically a multi-bit word whose value may, for example, be expressed in 10, 12 or more bit accuracy. Thus the value of codes from the analog to digital converters may range between relatively low values, and values in the range of one or two thousand. The correlator may itself include the multi-valued correlation sequence, or may simply include a sequence of zero and one as appropriate to the bit stream that it is seeking to select. As a result of the variable gain from the input stage and variation of received signal strengths steps must be taken to identify the nulls (or potentially peaks) in the combined output of the correlators.
In the presence of the weaker signal or more noise, given that noise is likely to be additive to the received signal, then consecutive minima may not fall below threshold TH1. However several tests may be applied to determine if the preamble has been identified. Thus, for example, the preamble may also be deemed to have been identified if four minima in a row are located, with the minima being below a threshold. TH2, where the value of TH2 is greater than the value of TH1. This principle can be extended so the preamble could be identified as being detected if five minima in a row are located, where the minima are less than a threshold value TH3 where TH3 is greater than TH2 and TH1. The threshold values TH1, TH2 and TH3 may be fixed or alternatively they may be dynamic, for example as being a function of the dynamic range (peak to trough) of the signal and its average value.
This cascaded approach means that in situations where the incoming signals have a high signal to noise ratio then the troughs/minima in the correlator output will be deep and only a small number of such troughs needs to be detected with a fairly aggressive threshold to identify that the preamble has been located. This provides for faster detection of the preamble once the game has been set, which is advantageous because in the case of high signal to noise ratio signals it is likely that the automatic gain control step has used more time to complete. Hence in engineering terms it is regarded as having used more of the preamble budget. In the case of incoming signals with a low signal to noise ratio, e.g. much closer to receiver sensitivity limits, the minima will be less deep and hence using an aggressive threshold is less likely to offer an indication that preamble has been found. However slow detection looking for more minima but with a less aggressive threshold will work because it allows the detection to take more time as the AGC process will have used less of the preamble budget.
In general the preamble detection method can look for any number of minima or indeed maxima, as appropriate.
As suggested before, there is going to be a frequency mismatch between the carrier frequency of the transmitter and the frequency of the local oscillator used for down conversion. In general, the transmitter and receiver oscillators may be at different temperatures and hence are likely to have a modest mismatch between frequencies. For example, in the IEE 802.11 standard oscillator precision tolerance is specified to be within 20 parts per million. This gives a potential carrier frequency offset error in a range of −40 to +40 parts per million. However, whilst that number is low, it is noted that when applied to a carrier operating at 2.4 GHz this gives rise to a carrier frequency offset of up to 96 kHz. Further offsets may be introduced if either of the receiver and transmitter are moving because of the Doppler effect. However, the offset can be calculated during the correlation process. A circuit for performing this may now be described with respect to
The correlator 204 works in a similar manner thus, the value in register 320-0 is compared with, for example subtracted, from a correlation preamble reference c10(0) stored in the preamble register 330 and the absolute value taken. Similarly each other corresponding pair of values is compared. Thus the content of register 320-15 being x′(k−15) is subtracted from C10(15) of the preamble register 330. For each of these subtractions an absolute value is formed and then a sum of the absolute values is formed to provide an output of the correlator.
The output of the averager 302 is representative of the frequency offset, but also provides the data required to correct for it. Thus the subtraction of the average value at the summers 310-0 to 310-15 provides a signal with automatic frequency correction applied. Typically, for oversampled GFSK signals that are recovered using the receiver described in
The output of the average 302 changes each time a new input value is introduced into the buffer 300. The variation in the output of the averager 302 as a function of sample number could be used as a measure of goodness to further qualify that the preamble has been received.
An advantage of the present disclosure is that the carrier frequency offset correction can be performed in parallel with the preamble detection. In such an arrangement the carrier frequency offset can be calculated by averaging the demodulated signal in the presence of the preamble over a multiple number of two full symbol durations. A symbol is represented by a plurality of ADC output values. Thus, in the case of an eight times over sampled system then one symbol is represented by eight consecutive sample outputs.
Because the operation of the transmitter and receiver are asynchronous, in the sense that there is no common timing reference to time align their clocks, steps should be taken to identify which one of the oversampled values should be taken as being a representative of the data symbol which is being transmitted.
The correlator outputs have minimum values which encode timing information. Specifically, the position of the minima effectively encode the position where the symbol value is optimally extracted.
One of the lines in
To avoid the processing overhead of having to look at a sequence of all the samples and work out where the peaks and troughs are the individual samples can be gated, for example, an electrically controlled switch or a logical gate such as an AND gate, both of which can be regarded as acting as a transmission gate. The switch or gate is represented in
As a consequence, timing synchronization can also be performed in parallel with the preamble identification and carrier frequency offset processes. Thus the receiver can be configured for a section of the data packet within the duration of the preamble.
In experiments performed by the applicant for relatively weak signals or use in noisy environments (in the sense that many potential interfering signals exist) has resulted in packet loss rates being reduced from around 10 to 15% to less than a few percent.
Typically, a receiver may include a phase lock loop for locking the frequency of the local oscillator to the transmitter frequency. Receivers in accordance with this disclosure may include such a phase lock loop. However, the phase lock loop operates over a relatively long timescale, typically 40 to 50 μs as a filter time constant for adjusting the local oscillator frequency whereas the automatic frequency correction based on analysis of the preamble can be done in a timescale of around 3 μs Consequently a fast digital correction may operate concurrently with a slower PLL style correction in order to reduce frequency offset between the carrier wave frequency and the local oscillator frequency.
It is thus possible to provide an improved method for identifying the preamble of a data packet and configuring a receiver so as to enhance the likelihood of it successfully recovering the data contained in the data packet. It is also possible to provide the receiver operating in accordance with the method.
The claims herein have been presented in single dependency format suitable for filing at the USPTO but it is to be understood that any claim may depend on any preceding claim of the same type unless such dependency is clearly technically not feasible.
Claims
1. A method of operating a receiver to process a preamble of a data packet, the method comprising:
- performing a receiver gain adjustment by using a gain controller to adjust a radio frequency amplifier gain based on a magnitude of the preamble, in which the gain adjustment s performed on signals received in advance of the preamble being received and identified, and
- wherein the receiver gain adjustment only completes once the preamble is identified.
2. A method as claimed in claim 1, in which the preamble is identified by locating a portion of the preamble to a predetermined threshold of certainty.
3. A method as claimed in claim 1, further comprising concurrently performing a receiver frequency adjustment whilst the receiver gain adjustment is being performed.
4. A method as claimed in claim 3, in which the automatic frequency adjustment process is operating on data in advance of the data packet arriving at the receiver.
5. A method as claimed in claim 1, in which the preamble is identified using a plurality of correlators, each looking for a respective part of the preamble sequence.
6. A method as claimed in claim 5, in which the correlators process a sequence of N samples received from a demodulator, and sliding average of the N samples is formed.
7. A method as claimed in claim 6, in which each one of the N samples has its value modified based on the sliding average to form a modified sample.
8. A method as claimed in claim 7, in which the modified samples are correlated with a portion of the preamble, and turning points in the correlator output are compared with a threshold to detect the preamble.
9. A method as claimed in claim 8, in which the turning point is a minimum and the magnitude of a plurality of consecutive minima are compared with a threshold or in which the turning point is a maximum and the magnitude of a plurality of consecutive maxima are compared with a threshold.
10. A method as claimed in claim 9, in which the threshold value varies with respect to the number of minima or maxima that must pass a test set by the threshold to determine presence of the preamble.
11. A method as claimed in claim 1, in which the gain controller is operative in advance of a data packet arriving at the receiver.
12. The method of claim 1, comprising performing a frequency offset correction using at least two correlators acting in parallel to identify different bit sequences within the preamble.
13. A method of operating a receiver to process a preamble of a packet of data, the method comprising:
- correlating an output of a demodulator with at least one segment of data representative of a preamble of the packet of data during a period when the receiver is performing automatic gain control; and
- analyzing an output of at least one correlator to locate troughs or peaks in the output of the at least one correlator, wherein the number of troughs or peaks needed to pass a threshold to indicate that a preamble has been identified varies as a function of a magnitude of the troughs or peaks.
14. A method as claimed in claim 13, in which turning points in a correlation function are used to select a subset of the outputs of the demodulator for processing to receive a data payload of a packet of data.
15. The method of claim 13, in which a gain adjustment is performed on signals received in advance of the preamble being received and identified.
16. A receiver, comprising an automatic gain adjustment circuit and a frequency offset correction circuit, wherein the gain adjustment circuit and frequency offset correction circuit operate concurrently on a preamble of a data packet and the gain adjustment circuit operates to perform a receiver gain adjustment by using a gain controller to adjust a radio frequency amplifier gain based on a magnitude of the preamble, wherein the frequency offset circuit comprises at least two correlators acting in parallel to identify different bit sequences within the preamble.
17. A receiver as claimed in claim 16, in which the output of the correlators are used to control a transmission gate used to decimate an output of a demodulator of the receiver.
18. A receiver as claimed in claim 16, in which the correlators act on a block of data comprising N samples, and an average from an average of the N samples, and the value of each sample is modified to form a modified value when it is presented to the correlators.
19. The receiver of claim 16, further comprising a timing synchronization circuit configured to operate concurrently with the gain adjustment circuit and the frequency offset circuit to control samples of the data packet provided to a bit recovery circuit, the bit recovery circuit configured to recover data provided in the data packet.
20. The receiver of claim 19, wherein the timing synchronization circuit comprises a switch controlled by the timing synchronization circuit to provide a selected subset of a plurality of samples of the data packet to the bit recovery circuit.
21. The receiver of claim 19, wherein the tinging synchronization circuit is configured to control the samples of the data packet using input from the at least two correlators.
22. A device arranged to communicate using a short range data communication protocol using data, packets that include a preamble, the device comprising:
- a receiver arranged to operate to process a respective preamble of a data packet; and
- a gain controller that performs a receiver gain adjustment to adjust a radio frequency amplifier gain based on a magnitude of the respective preamble, wherein the gain adjustment is performed on signals received in advance of the respective preamble being received and identified, and wherein the gain adjustment only completes once the respective preamble is identified.
23. The device of claim 22, the device configured for correlating an output of a demodulator with at least one segment of data representative of the respective preamble of the packet of data during a period when the receiver is performing automatic gain control, in which an output of at least one correlator is analyzed to locate troughs or peaks in the output of the at least one correlator, and wherein the number of troughs or peaks needed to pass a threshold to indicate that the respective preamble has been identified varies as a function of the magnitude of the troughs or peaks.
24. The device of claim 22, wherein the receiver receives the data packet via a received radio frequency signal, and wherein the receiver determines an offset between a frequency of the received radio frequency signal and a nominal frequency of the device.
25. The device of claim 24, wherein the receiver determines the offset between the frequency of the received radio frequency signal and the nominal frequency of the device concurrently with performing the receiver gain adjustment.
26. A device configured to receive wireless signals, the device comprising:
- means for receiving a radio frequency signal comprising at least a preamble of a data. packet;
- means for adjusting a radio frequency amplifier gain based on a magnitude of the preamble of the data packet, the adjusting beginning prior to receipt of the preamble of the data packet;
- means for identifying the preamble of the radio frequency signal, wherein the adjusting the radio frequency amplifier gain only completes once the preamble is identified.
27. The device of claim 26, further comprising:
- means for performing a receiver frequency adjustment with respect to the radio frequency signal, the receiver frequency adjustment performed in parallel with the adjusting of the radio frequency amplifier gain.
28. The device of claim 27, further comprising means for performing timing synchronization for the radio frequency signal to control bit recovery from the data packet, the timing synchronization performed in parallel with the receiver frequency adjustment and the adjusting of the radio frequency amplifier gain.
29. The device of claim 26, wherein the means for identifying the preamble comprises correlator means for detecting one or more portions of the preamble.
30. The device of claim 26, wherein the correlator means comprise a first correlator means for detecting a first portion of the preamble and a second correlator means for detecting a second portion of the preamble, the first and the second correlator means operating in parallel.
31. The device of claim 26, further comprising means for performing an energy detect, the energy detect used to verify identification of the preamble.
20030108129 | June 12, 2003 | Voglewede et al. |
20070280362 | December 6, 2007 | Lin |
20080273636 | November 6, 2008 | Zhu |
20110102151 | May 5, 2011 | Shin et al. |
20120231756 | September 13, 2012 | Otaka et al. |
20130195229 | August 1, 2013 | Cheng et al. |
20140293808 | October 2, 2014 | Tsai et al. |
20150103937 | April 16, 2015 | Cudak |
20150349823 | December 3, 2015 | Qiu et al. |
20160146922 | May 26, 2016 | Moshfeghi |
20070060718 | June 2007 | KR |
- “German Application Serial No. 102018105305.3, Office Action dated Nov. 11, 2019”, 10 pgs.
Type: Grant
Filed: Mar 10, 2017
Date of Patent: Jun 2, 2020
Patent Publication Number: 20180263001
Assignee: Analog Devices Global (Hamilton)
Inventors: Michael O'Brien (Munster), Sean Francis Sexton (Cork), Joshua Nekl (County Cork), Dermot G. O'Keeffe (County Cork)
Primary Examiner: David S Huang
Application Number: 15/455,556
International Classification: H04W 52/52 (20090101); H04B 1/00 (20060101); H04B 1/06 (20060101); H04W 4/80 (20180101); H04L 29/06 (20060101);