The technology described in this document relates generally to wireless communication systems and more particularly to systems and methods for DC offset correction in a wireless receiver.
The wireless transmission of an information signal may include formatting the information signal in a transmitter, modulating the formatted information signal over a baseband carrier, receiving the modulated signal at a receiving device, and demodulating the modulated signal. After demodulation, the received signal may be processed further by the receiving device. Orthogonal frequency division multiplexing (OFDM) is a method of encoding digital data on multiple carrier frequencies for high data rate, high performance wireless communication systems. In an OFDM system, bandwidth is divided into closely spaced orthogonal subcarriers (i.e., tones), which are modulated with data symbols. The transmitted data is divided into parallel data streams, one for each subcarrier. A primary advantage of OFDM over single-carrier schemes is OFDM's ability to operate under unfavorable channel conditions (e.g., attenuation of high frequencies in a long copper wire, narrowband interference, and frequency-selective fading, among others) without complex equalization filters. These advantages simplify equalizer design and have resulted in adoption of OFDM in several standards (e.g., IEEE 802.11a/g/n, IEEE 802.16e, and 3G-LTE). Although data is not typically transmitted on a DC subcarrier in OFDM systems, injection of a DC component may occur at the transmitter and the receiver. The injection of the DC component may limit performance of the communication system.
The present disclosure is directed to systems and methods for removing DC offset from a signal. In a method for removing DC offset from a signal, a radio frequency signal is received at a receiver. The radio frequency signal is converted into a digital signal including a periodic component with a period. A carrier frequency offset is removed from the digital signal to generate a frequency-shifted digital signal. The frequency-shifted digital signal is filtered to remove a DC offset in the digital signal. The filtering includes applying a moving average filter matched to the period to remove the periodic component from the frequency-shifted digital signal. The moving average filter generates a set of average values based on the frequency-shifted digital signal. The filtering also includes taking a difference between consecutive values of the set of average values to determine the DC offset, where the DC offset is introduced at the receiver.
In another example, a system of removing DC offset from a signal includes a receiver configured to receive a radio frequency signal. The radio frequency signal is converted into a digital signal including a periodic component with a period. The system also includes a carrier frequency offset correction module configured to remove a carrier frequency offset from the digital signal to generate a frequency-shifted digital signal. The system further includes a filter configured to remove a DC offset in the digital signal. The filter includes a moving average filter matched to the period to remove the periodic component from the frequency-shifted digital signal. The moving average filter generates a set of average values based on the frequency-shifted digital signal. The filter also includes a differentiator configured to take a difference between consecutive values of the set of average values to determine the DC offset. The DC offset is introduced at the receiver.
At the receiver 104, the transmitted signal is received via an antenna 124. A receiver mixer 126 is used to mix the received signal to a baseband signal at a receiver carrier frequency fr 128. The transmitter carrier frequency ft 120 and the receiver carrier frequency fr 128 deviate from a nominal carrier frequency value, thus resulting in a carrier frequency offset (CFO) that is equal to a difference between the transmitter carrier frequency 120 and the receiver carrier frequency 128 (i.e., ft−fr). The CFO reflects the fact that the transmitter 102 and the receiver 104 are two different devices, such that the different devices will have carrier frequencies ft 120 and fr 128 that differ from the nominal carrier frequency value and from each other. At adder 130, a complex-valued DC offset dr 132 may be introduced into the output of the receiver mixer 126. The DC offset dr 132 is introduced by circuitry of the receiver 104 and may be termed “true DC” because the DC offset dr 132 is at a frequency equal to zero (i.e., it has not been shifted in frequency by the CFO). By contrast, in the signal received by the receiver 104, the transmitter DC offset dt′ 116 is shifted by a frequency equal to the CFO, such that the transmitter DC offset dt′ 116 is not at a frequency equal to zero. The output of the receiver mixer 126 with the DC offset dr 132 is received by an analog to digital converter (ADC) 134. An output of the ADC 134 is a signal v[n] 136 that is received by a receiver DSP 138. The signal v[n] 136 output from the ADC 134 may be a digital signal including a periodic component with a particular period, as described in further detail below. The system model 100 may utilize a signaling scheme that uses orthogonal frequency division multiplexing (OFDM) or contains portions of a packet preamble that by construction are periodic with zero mean (e.g., Wi-Fi standards 802.11a/g/n/ac, among others).
The signal v[n] 136 is equivalent to the baseband signal transmitted, s′[n] 110, but shifted in frequency by the CFO and modified by the two DIX offset components (i.e., the transmitter DC offset dt′ 116 and the receiver DC offset dr 132). As noted above, the transmitter DC offset dt′ 116 is also shifted in frequency by the CFO. Thus, the signal v[n] 136 may be expressed as follows:
v[n]=dr+(dt+s[n])exp(jωCFOn)+z[n] (Equation 1)
In Equation 1 above, s[n] is equivalent to the signal s′[n] 110 modified by a channel response of the channel 106. For an LTI channel, a periodicity of certain segments of the signal s′[n] 110 is preserved in s[n]. In Equation 1, dt is equivalent to the transmitter DC offset dt′ 116 modified by the channel response. For an LTI channel, dt is a complex-valued DC signal with magnitude and phase that are potentially different from those of the transmitter DC offset dt′ 116. The term z[n] in Equation 1 represents noise. ωCFO is the CFO normalized by a sampling frequency fs, according to the following equation:
ωCFO=2π(ft−fr)/fs (Equation 2)
In the system model 100 of
As a first step in performing the DC offset correction, CFO correction is performed at the module 140. As described above, the signal received at the antenna 124 is shifted by the CFO, which is equal to the difference between the transmitter carrier frequency 120 and the receiver carrier frequency 128 (i.e., ft−fr). A packet structure in the system model 100 may be designed to facilitate accurate CFO estimation. The CFO correction module 140 removes the CFO from the digital signal v[n] 136 to generate a frequency-shifted digital signal x[n] 142.
Following the CFO correction executed at the module 140, the frequency-shifted digital signal x[n] 142 undergoes filtering as part of the DC offset correction. At a module 144, a moving average filter is applied to the frequency-shifted digital signal x[n] 142. The moving average filter is matched to the particular period of the periodic component of the signal v[n] 136. Because the signal x[n] 142 may be equivalent to the signal v[n], but shifted by the CFO, the moving average filter may also be matched to a particular period of a periodic component of the signal x[n] 142. Thus, the moving average filter may utilize an averaging window matched to the particular period of the periodic components of the signals v[n] 136 and x[n] 142. The moving average filter removes the periodic component of the signal x[n] 142 and generates a set of average values 146 based on the frequency-shifted digital signal x[n] 142 (i.e., the moving average filter takes an average every N samples, where the signal x[n] 142 includes the periodic component with a period of N samples).
The set of average values 146 is received by a module 148, which may include a differentiator filter. In the module 148, a difference is taken between consecutive values of the set of average values 146 to eliminate the transmitter DC offset dt′ 116 from the signal x[n] 142 and to determine the receiver DC offset dr 132. The signal with the receiver DC offset removed 154 is generated as an output of a module 152, which includes a filter or other component configured to remove the determined receiver DC offset dr 132 from the incoming signal (i.e., an adder or subtractor). The signal with the receiver DC offset removed 154 may be received by the receiver DSP 138.
x[n]=v[n]exp(−jωCFOn) (Equation 3)
x[n]=drexp(−jωCFOn)+dt+s[n]+z[n]exp(−jωCFOn) (Equation 4)
z′[n]=z[n]exp(−jωCFOn) (Equation 5)
In the above equations, CFO correction is executed by multiplying the digital signal v[n] by the term exp(−jωCFOn), which shifts the digital signal v[n] in frequency by an amount equal to the CFO in a negative direction. Thus, as illustrated in Equation 4, in the frequency-shifted digital signal x[n], the receiver DC offset dr is shifted by the CFO away from a zero frequency. By contrast, the transmitter DC offset dt and the s[n] periodic component are no longer shifted by the CFO (i.e., as they were in the digital signal v[n]) and are now at their correct, original frequencies. In Equation 5, the noise term z[n] is shifted by the CFO, but z[n] and z′[n] have the same statistics if z[n] is white Gaussian noise.
In OFDM systems, data is carried on frequency tones that are equally spaced in frequency (i.e., equally spaced by a subcarrier spacing Δω). Orthogonality between these tones is assured by the fact that the spacing between the tones is the same (i.e., signals at frequencies that are multiples of the subcarrier spacing Δω are orthogonal). The transmitter DC offset dt is orthogonal to data subcarriers of the signal v[n], and the orthogonality of the transmitter DC offset dt continues to hold in the CFO-corrected signal x[n].
The orthogonality of the transmitter DC offset dt in the signals v[n] and x[n] is illustrated in the example schematic spectrums 200, 250 for signals v[n] and x[n], respectively. In the example schematic spectrum 200 for the signal v[n], an x-axis 202 represents frequency (ω), and data subcarriers 204, 206, 208, 210 are spaced at multiples of the subcarrier spacing Δω, making them orthogonal. The periodic data subcarriers 204, 206, 208, 210 represent a periodic desired signal containing the data intended to be transmitted from the transmitter to the receiver (i.e., signal s[n], which represents the periodic signal s′[n] generated at the transmitter modified by the channel response). The transmitter DC offset dt 214, positioned at the CFO of ωCFO, is also orthogonal to the data subcarriers 204, 206, 208, 210. The receiver DC offset dr 212 is at a frequency of zero (i.e., true DC) and is not orthogonal to the data subcarriers 204, 206, 208, 210.
An effect of the CFO correction performed on the signal v[n] is illustrated in the example schematic spectrum 250 for the signal x[n]. As described above, with reference to
Although the periodic data subcarriers 304 (i.e., s′[n], the desired signal to be transmitted that is modified by the channel response) are filtered our by the moving average filter, the transmitter DC offset dt 308 and the receiver DC offset dr 306 are not. Thus, the transmitter DC offset dt 308 and the receiver DC offset dr 306 appear in the example schematic spectrum at 330, with the transmitter DC offset dt 308 being at a frequency of zero and the receiver DC offset dr 306 being at a frequency that is a negative of the CFO, −ωCFO.
The filtering of the signal x[n] by the moving average filter, as depicted at 300 and 330 of
y
m+k
=d
t
+d
r
q
m+k
+w
m+k (Equation 9)
In Equation 7, the periodic desired signal s[n] is cancelled out (i.e., the term
is equal to zero), since s[n] is zero-mean periodic with period N. Further, in Equation 7, the noise term z′[n] is filtered, though not removed completely. In Equation 8, the receiver DC offset dr is shifted by a time-varying phase, where the shift is caused by a CFO correction. Because the CFO is determined in performing the CFO correction, the term by which the receiver DC offset dt is shifted may be known. With kε{0, . . . , L−1}, the moving average filter generates L average values by producing an average value every N samples.
In Equations 8 and 9, the receiver DC offset dr and the transmitter DC offset dt are unknown values, but the {qm+k} term can be computed, since the {qm+k} term depends on the known CFO and m. In Equation 9, the wm+k term represents filtered noise in the output of the moving average filter. To determine the receiver DC offset dr and the transmitter DC offset dt, a least-squares formulation can be applied:
A solution to the least-squares formulation is as follows:
As described above, the transmitter DC offset value dt 308 is orthogonal to the data subcarriers and does not have an effect in decoding the transmitted signal. An estimate {circumflex over (d)}r for the receiver DC offset dt 306 may be as follows:
The estimate {circumflex over (d)}r for the receiver DC offset dr 306 is a linear combination of differences for all of the sample pairs (i.e., the L values for the variable y, where the variable y is the output of the moving average filter). Thus, to remove the transmitter DC offset dt 308 from the output of the moving average filter, a difference between consecutive values of the L values is taken. A result of taking the differences of the consecutive values of the output of the moving average filter is illustrated in the example schematic spectrum at 360 of
An FIR filter representation for performing the receiver DC offset estimation may be implemented via the example circuit 400 of
An output of the N-sample average filter 412 is received by a differentiator 414. The differentiator 414 is configured to remove a transmitter DC offset dt from the output of the N-sample average filter 412 by taking a difference of consecutive samples in the output of the N-sample average filter 412. The operation of the differentiator is illustrated in
The example circuit 400 of
The example circuit 500 is configured to produce two estimates for the receiver DC offset, {circumflex over (d)}r(1) 506 and {circumflex over (d)}r(2) 508, where the estimates 506, 508 are generated by a DC estimator 1 module 502 and a DC estimator 2 module 504. With reference to
The DC estimator 1 502 of
The first and second receiver DC offset estimates {circumflex over (d)}r(1) 506 and {circumflex over (d)}r(2) 508 are received by the multiplexer 510. The multiplexer 510 uses selection logic 512 to choose one of the two estimates 506, 508 to be output as a selected, final estimate {circumflex over (d)}r 514. The use of the selection logic 512 reflects the fact that in some cases, the output 506 of the DC estimator 1 may be more accurate, and in other cases, the output 508 of the DC estimator 2 may be more accurate. The selected, final estimate {circumflex over (d)}r 514 may be subtracted from the v[n] signal 518 at an adder 520. The v[n] signal 518, now with the estimated receiver DC offset {circumflex over (d)}r 514 removed, may be received by the CFO correction module 522, where the x[n] output 524 of the CFO correction module 522 undergoes further receiver processing (e.g., in a receiver DSP) at 526.
To evaluate the performance of the DC estimator 1 502 and the DC estimator 2 504, an estimate error may be determined, where the estimate error is given by:
err={circumflex over (d)}r−dr, (Equation 14)
where err is the estimate error in an estimated receiver DC offset, {circumflex over (d)}r is the estimated receiver DC offset (e.g., either of the first or the second receiver DC offset estimates {circumflex over (d)}r(1) 506 and {circumflex over (d)}r(2) 508), and dr is an actual receiver DC offset. Equivalently, Equation 14 may describe a residual receiver DC offset after estimation and compensation (e.g., a portion of the actual receiver DC offset that is not removed by the example circuit 500 for removing the receiver DC offset). The estimation error may be quantified by its root mean squared (RMS) value, according to the following equation:
σerr=√{square root over (E[|err|2])} (Equation 15)
To capture an impact of the estimation error on OFDM signal reception, a level of interference that the residual receiver DC offset creates to data subcarriers may be expressed via the following equation:
where Pint represents the level of interference and NDFT is a total number of subcarriers in an OFDM symbol. In judging the performance of the DC estimator 1 502 and the DC estimator 2 504, the Pint metric may be computed and evaluated.
In an example, the DC estimator 1 502 and the DC estimator 2 504 may be compared via a simulation or experimentally. A frequency-shifted digital signal x[n] may include a periodic component with a period of N samples, and there may be P consecutive samples available to estimate the DC offset (P>N), starting with a sample at index m (i.e., x[m], . . . x[m+P−1]). Simulation or experimental parameters may include packet parameters compliant with 802.11g, for example (e.g., NDFT=64; preamble periodicity N=16 samples; sampling frequency fs=20 MHz). The number of consecutive samples P may be equal to 24 (i.e., 1.5 periods), and both estimation methods may use a same number of P consecutive samples. A magnitude of a transmitter DC offset dt may be given with respect to the power of s[n]. In the simulation or experiment a signal to noise (SNR) value represents a ratio between the periodic, desired signal s[n] and noise z[n].
As illustrated in the table 600, by varying CFO, SNR, and transmitter DC offset variables, a better performing algorithm (i.e., DC estimator 1 versus DC estimator 2) may also vary. At high CFO values, the DC estimator 2 may generate an estimate for the receiver DC offset dr with a higher accuracy, as versus an estimate generated by the DC estimator 1. By contrast, at low CFO values, the DC estimator 1 may generate an estimate for the receiver DC offset dr with a higher accuracy, as versus an estimate generated by the DC estimator 2. The DC estimator 2 may perform better at high CFO values because the DC estimator 2 operates on the frequency-shifted digital signal x[n], which has already had the CFO removed from the signal, whereas the DC estimator 1 operates on the digital signal v[n], which still includes the CFO.
At a low SNR, the DC estimator 1 may be more accurate, and at a high SNR, the DC estimator 2 may be more accurate. The table 600 also illustrates that if a transmitter DC offset is high, the DC estimator 2 may perform more accurately than the DC estimator 1. The DC estimator 2 may perform more accurately at high transmitter DC offset values because the DC estimator 2 is configured to take a difference between consecutive samples of the output of the moving average filter to remove the transmitter DC offset (e.g., using a differentiator module).
In selecting an output from one of the DC estimator 1 and the DC estimator 2, simulation data may be plotted as a graph, such that data from the graphs can be read and used in making the selection. For example, interference level (dB) versus CFO (kHz) may be plotted for a transmitter DC offset of −20 dB, where the interference level is plotted for various SNR values (e.g., 25 dB to 40 dB). The interference level is the residual receiver DC offset (e.g., a portion of the actual receiver DC offset that is not removed by the example circuit 500 for removing the receiver DC offset). In another example, the interference level (dB) versus CFO (kHz) may be plotted for a SNR of 30 dB, where the interference level is plotted for various values of transmitter DC offset.
Using simulation data or experimental data, a better performing receiver DC offset estimator can be selected based on one or more of a) CFO value, b) SNR, and c) transmitter DC offset. The CFO value may be accurately estimated. As noted above, the DC estimator 2 requires CFO to be estimated, whereas the DC estimator 1 does not. An approximate value for the SNR may be available in most cases. The transmitter DC offset may be unknown, but a range for the transmitter DC offset may be known. In one example, the selection logic for selecting the DC estimator 1 or the DC estimator 2 (e.g., selection logic 512 of
This written description uses examples to disclose the invention, including the best mode, and also to enable a person skilled in the art to make and use the invention. The patentable scope of the invention may include other examples. Additionally, the methods and systems described herein may be implemented on many different types of processing devices by program code comprising program instructions that are executable by the device processing subsystem. The software program instructions may include source code, object code, machine code, or any other stored data that is operable to cause a processing system to perform the methods and operations described herein. Other implementations may also be used, however, such as firmware or even appropriately designed hardware configured to carry out the methods and systems described herein.
The systems' and methods' data (e.g., associations, mappings, data input, data output, intermediate data results, final data results, etc.) may be stored and implemented in one or more different types of computer-implemented data stores, such as different types of storage devices and programming constructs (e.g., RAM, ROM, Flash memory, flat files, databases, programming data structures, programming variables, IF-THEN (or similar type) statement constructs, etc.). It is noted that data structures describe formats for use in organizing and storing data in databases, programs, memory, or other computer-readable media for use by a computer program.
The computer components, software modules, functions, data stores and data structures described herein may be connected directly or indirectly to each other in order to allow the flow of data needed for their operations. It is also noted that a module or processor includes but is not limited to a unit of code that performs a software operation, and can be implemented for example as a subroutine unit of code, or as a software function unit of code, or as an object (as in an object-oriented paradigm), or as an applet, or in a computer script language, or as another type of computer code. The software components and/or functionality may be located on a single computer or distributed across multiple computers depending upon the situation at hand.
It should be understood that as used in the description herein and throughout the claims that follow, the meaning of “a,” “an,” and “the” includes plural reference unless the context clearly dictates otherwise. Also, as used in the description herein and throughout the claims that follow, the meaning of “in” includes “in” and “on” unless the context clearly dictates otherwise. Further, as used in the description herein and throughout the claims that follow, the meaning of “each” does not require “each and every” unless the context clearly dictates otherwise. Finally, as used in the description herein and throughout the claims that follow, the meanings of “and” and “or” include both the conjunctive and disjunctive and may be used interchangeably unless the context expressly dictates otherwise; the phrase “exclusive of” may be used to indicate situations where only the disjunctive meaning may apply.
This claims priority to U.S. Provisional Patent Application No. 61/678,530, filed on Aug. 1, 2012, which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4764748 | Geen | Aug 1988 | A |
7349469 | Touzni | Mar 2008 | B1 |
8218686 | Timofeev et al. | Jul 2012 | B1 |
20030058961 | Fling | Mar 2003 | A1 |
20030152021 | Wang | Aug 2003 | A1 |
20050047526 | Watanabe et al. | Mar 2005 | A1 |
20080089443 | Sanada | Apr 2008 | A1 |
20100074078 | Cao | Mar 2010 | A1 |
Entry |
---|
Huang, Defeng (David), et al., Carrier Frequency Offset Estimation for OFDM Systems Using Null Subcarriers, IEEE Transactions on Communications, vol. 54, No. 5, May 2006, pp. 813-823. |
Number | Date | Country | |
---|---|---|---|
61678530 | Aug 2012 | US |