Estimating channel frequency responses corresponding to orthogonal frequency division multiplexed (OFDM) signals may include estimating channel frequency responses corresponding to scattered pilots within the OFDM signal, interpolating the scattered pilot channel frequency responses over multiple symbols of the OFDM signal to obtain channel frequency responses corresponding to non-pilot positions of scattered pilot frequencies, and frequency interpolating the estimated channel frequency responses corresponding to the scattered pilot frequencies of a symbol, to obtain channel frequency responses corresponding to non-scattered pilot frequencies of the symbol.
Under noisy channel conditions, such as in a digital terrestrial television broadcast environment, OFDM pilots may be impacted with additive noise. In mobile applications, pilots may also be impacted by inter-carrier interference (ICI). Such impacts may degrade a signal-to-noise ratio (SNR) of channel frequency response estimates.
For stationary applications, noise may be filtered during the initial interpolation using a relatively narrow bandwidth filter, but at relatively substantial cost in terms of memory and hardware complexity. For mobile applications, using a relatively narrow bandwidth filter in the initial interpolation may result in loss of Doppler spectrum.
For low delay spread signals, noise may be filtered during the subsequent frequency interpolation by using relatively narrowband filter. However, for single frequency networks (SFN) with large multipath delays, a narrowband filter may result in loss of multipath profile.
In the drawings, the leftmost digit(s) of a reference number identifies the drawing in which the reference number first appears.
At 102, an OFDM signal having pilot signals or pilots is received. The pilots may include a tone and/or information, which may modulate a corresponding pilot carrier, such as with binary phase shift keying (BPSK) modulation. Pilot locations may have a repeating pattern, referred to herein as scattered pilots.
A single instance of the OFDM signal may be received from a single transmitter. Alternatively, a plurality of instances of the OFDM signal may be received from a plurality of corresponding transmitters, such as in a single-frequency network (SFN).
In the example of
In the example of
In the example of
Frequencies of pilot carriers are referred to herein as pilot frequencies. In the example of
Symbols 202 through 210 occur at a symbol period Ts=Tu+Tg, where Tu is the useful or effective symbol duration and Tg is the guard duration The ratio Tg/Tu is defined as the guard ratio. Carrier frequencies F0 through Fy may be separated by 1/Tu, and the pilots within a symbol may be spaced by 12/Tu.
Returning to
The channel frequency responses corresponding to the pilots, such as illustrated in
The estimating of channel frequency responses at 104 in
The combination of interpolating and low-pass filtering is referred to herein as time-filtering.
Pilots may include noise, which may degrade the signal-to-noise ratio (SNR) of a channel frequency response estimate. As described below with respect to 106, noise may be reduced by filtering or masking noise from the channel frequency response estimates in the time domain, which may be implemented relatively inexpensively in terms of memory and complexity. Time filtering at 104 may thus be performed with a relatively wide band filter, which may be suitable for both mobile and stationary or relatively stationary applications.
At 106, the estimated channel frequency responses corresponding to the pilot frequencies are band-pass filtered or masked in a time domain. The filtering or masking may include filtering or masking on a symbol-by-symbol basis, and may take advantage of a relatively sparse property of time domain representations of the channel frequency responses, described below with respect to
Transmitted signals may be dispersed by local reflections, which may result in delay spreads or dispersal regions, illustrated in
The example of
Guard interval 508 may be relatively large compared to delay spreads 510, 512, and 514. For a multi-frequency network (MFN), a shorter guard interval may be implemented. For example, consider a 2K OFDM signal with a guard ratio of 1/32 and a guard interval of 7 μs. A mobile application may be configured with this in accordance with a 6-path Typical Urban (TU6) channel profile, and to accommodate delay spreads of approximately 6 μs.
Signal clusters 502, 504, and 506 may be spread relatively far from one another within guard interval 508, and spaces between signal clusters 502, 504, and 506 may be relatively sparse, even when additional signal clusters are present.
The noise filtering or masking at 106 may include masking relatively sparse portions of channel impulse responses, and may include adaptively masking relatively sparse portions of channel impulse responses. The masking may improve a signal-to-noise ratio (SNR) of the channel estimates generated at 104. The SNR gain may be a function of the sparseness guard interval, wherein greater sparseness may result in higher SNR gain.
At 602, channel frequency responses corresponding to a symbol of the OFDM signal are converted to a sequence of samples in the time domain. This may include performing an Inverse Fast Fourier transform (IFFT) on the channel frequency responses. The IFFT may be performed once per symbol, along a frequency axis in
The conversion to the time domain at 602 may represent a channel impulse response of the symbol, such as illustrated in
At 604, a mask is generated corresponding to relatively significant parts of the channel impulse response, such as signal clusters or dispersal regions 502, 504, and 506 in
At 702, absolute values or magnitudes of time domain samples are determined.
At 704, the magnitudes values are averaged or low-pass filtered. The averaging or the low pass filtering may be performed over a plurality of symbols, for each magnitude value, in symbol time direction. The averaging may reduce a noise floor of the time domain samples.
A threshold may be applied to the averaged magnitude values, which may reduce the noise floor. This may include setting averaged magnitude values that are below the threshold to zero. The threshold may be set to a fraction of a peak value of the time domain samples, or a fraction of a peak value of the averaged magnitudes. The threshold may be, for example, a factor of 32 less than the peak value. This may be substantially equivalent to setting echoes that are less than 30 dB of the peak value to zero. An exemplary method of reducing the noise floor using thresholding is described below with respect to 706 through 710 of
At 706, a mean value of the noise floor is determined. This may include determining the mean value of all or substantially all averaged magnitude values that are less than a fraction, such as ⅛ of the peak value.
At 708, a portion of the mean value of the noise floor is subtracted from the averaged magnitude values. Resultant values that are less than zero may be set to zero.
At 710, thresholding is applied to the results of the subtraction at 708. A threshold factor may be a fraction of the peak value, such as 1/32. Results that are less than the threshold value may be set to zero. Results above the threshold value may be set to a non-zero value. Where, as in the example above, the IFFT is a 4096-point IFFT, samples above the threshold value may be set to 1024, which results in a binary mask having values of 0 and 1024.
At 712, mask edges may be extended in time, illustrated in
At 714, mask portions or pulses that fall relatively close to one another may be merged.
At 716, edges of the binary mask may be tapered, to generate a non-binary mask, illustrated in
Returning to
At 608, the masked sequence of time domain samples is converted to the frequency domain. This may include performing a Fast Fourier Transform (FFT) on the masked sequence of time domain samples, for each symbol, along the frequency axis of
Method 600 or portions thereof may be repeated successively for additional symbols or symbol periods, and a mask may be generated and/or updated each symbol period. Such a masking process is referred to herein as a self-adapting masking process, which may track variations of a channel impulse response over time, which may occur, for example, in mobile applications.
The time domain filtering or masking at 106 may serve as band-pass filtering, and may remove a relatively significant amount of noise in the channel frequency response. As a result, time filtering at 104 may be performed with a relatively wideband filter, which does not require as much memory or hardware complexity as a narrow band filter, and which may improve Doppler recovery in mobile applications. An implementation may thus be suitable for both stationary and mobile applications.
Returning to
Where the time domain noise filtering or masking at 606 includes point-wise multiplication of the IFFT sequence, the multiplication may be viewed as cyclic convolution in channel frequency response domain.
The cyclic convolution may result in changes to edges of the channel frequency responses. Such changes may include corruption of edge carriers, such as carriers that fall near edges of the frequency responses at 212, 402, 404, 406, and 230 in
The number of affected edge carriers may be a function of the tapering, or the amount of tapering introduced to the mask at 716 in
Affected edge carriers may be restored or replaced with original carriers after the filtered symbols are converted to the frequency domain at 608 in
A channel frequency response determined or estimated as disclosed herein may be used for one or more subsequent operations including, without limitation, equalization, symbol timing recovery, such as positioning of an FFT window for transforming a received time domain signal to the frequency domain, and inter-carrier-interference (ICI) cancellation. ICI cancellation may be performed with respect to a derivative of the channel frequency response with respect to time. Noise filtering or masking in a time domain, as disclosed herein, may improve a signal-to-noise ratio (SNR) of a channel frequency response estimate, which may improve a SNR of data carriers obtained through equalization, ICI cancellation, and an overall SNR performance of a demodulator.
Methods of determining channel frequency responses, and portions thereof, including methods of masking noise in a time domain, may be implemented as part of a signal receiver system, and may be implemented in hardware, software, firmware, and combinations thereof, including discrete and integrated circuit logic, application specific integrated circuit (ASIC) logic, and microcontrollers, and may be implemented as part of a domain-specific integrated circuit package, or a combination of integrated circuit packages. The term software, as used herein, refers to a computer program product including a computer readable medium having computer program logic stored therein to cause a computer system to perform one or more features and/or combinations of features disclosed herein.
Signal processor 1204 includes a channel frequency response system 1206 to determine or estimate a channel frequency response 1208 corresponding to an OFDM signal 1210.
Signal processor 1204 may include one or more of a demodulator 1212, an equalizer 1213, a symbol timing recovery system 1214, and an inter-carrier cancellation (ICC) system 1214, to process OFDM signal 1210 in response to channel frequency response 1208, and to output demodulated data 1216.
Channel frequency response system 1206 may include a pilot channel frequency estimator 1218 to determine channel frequency responses corresponding to pilots of OFDM signal 1210, as described above with respect to 104 in
Channel frequency response system 1206 may include a time filter 1219 to interpolate and low-pass filter the channel frequency responses corresponding to the pilots, as described above with respect to 104 in
Pilot channel frequency estimator 1218 and time filter 1219, together, determine channel frequency responses corresponding to scattered pilot frequencies, and may be referred to together as a scattered pilot frequency, channel frequency response system 1230.
Channel frequency response system 1206 may include an Inverse Fast Fourier Transform (IFFT) system 1220 to convert channel frequency responses of pilot frequencies to a sequence of time domain samples 1221, as described above with respect to 602 in
Channel frequency response system 1206 may include a mask generator 1222 to generate and/or update a mask 1225 corresponding to dispersal regions of time domain samples 1221, as described above with respect to 604 in
Channel frequency response system 1206 may include a mask applicator 1224 to mask portions of sequences of time domain samples that are outside of one or more portions of corresponding masks 1225, as described above with respect to 606 in
Channel frequency response system 1206 may include a Fast Fourier Transform (FFT) system 1226 to convert a masked sequence of time domain symbols to the frequency domain, as described above with respect to 608 in
Channel frequency response system 1206 may include a frequency interpolator 1228 to frequency interpolate the frequency domain representation of the masked sequence of time domain symbols, or band-pass filtered channel frequency responses, as described above with respect to 108 in
Binary mask generator 1302 may include an absolute value module 1306 to determine absolute values or magnitudes of the time domain samples of a symbol, as described above with respect to 702 in
Binary mask generator 1302 may include an average system 1308 to average or low-pass filter the magnitude values, as described above with respect to 704 in
Binary mask generator 1302 may include a mean noise module 1310 to determine a noise floor of the averaged magnitude values, as described above with respect to 706 in
Mean noise module 1310 may be configured to determine a mean value of the averaged magnitude values that are below a threshold 1313, and binary mask generator 1302 may a threshold generator 1312 to determine threshold 1313 relative to the time domain samples. Binary mask generator 1302 may include a peak value detector 1314 to determine a peak value of the time domain samples of the symbol, or a peak value of the averaged magnitude values, and threshold generator 1312 may be configured to determine threshold 1313 relative to the peak value.
Binary mask generator 1302 may include a subtractor 1316 to subtract a portion of the mean value from the averaged magnitude values, as described above with respect to 708 in
Binary mask generator 1302 may include a comparator 1318 to set results from subtractor 1316 that are below a second threshold 1319 to zero, to set results from subtractor 1316 that are above second threshold 1319 to a non-zero value, and to output the corresponding zero and non-zero values as a binary mask 1320, as described above with respect to 710 in
Mask adjustment module 1304 may include an extension module 1320 to extend binary mask 1320 in the time domain, as described above with respect to 712 in
Mask adjustment module 1304 may include a merge module 1322 to merge portions or pulses of a mask that are proximate to one another, as described above with respect to 714 in
Mask adjustment module 1304 may include a taper module 1324 to taper edges of binary mask 1320 and to output a non-binary mask 1326 as mask 1225 in
Methods and systems disclosed herein may be implemented in conjunction with one or more of stationary, portable, and mobile applications, including, without limitation, a 6-path Typical Urban channel profile. The value of K may be higher for mobile applications, which may enable faster tracking of channel variations with time.
Methods and systems disclosed herein may be implemented in conjunction with one or more OFDM-based digital TV standards including, without limitation, DVB-T, DVB-H, and ISDB-T standards, and a pending DVB-T2 standard.
Methods and systems are disclosed herein with the aid of functional building blocks illustrating the functions, features, and relationships thereof. At least some of the boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries may be defined so long as the specified functions and relationships thereof are appropriately performed.