Conventional single-carrier communication systems, such as digital television (DTV) receivers, use time-domain decision feedback equalizers (DFE) to compensate for signal distortions caused by inter-symbol interference in a wireless channel.
Time-domain decision feedback equalizers are relatively complex, and become more complex for a channel having a relatively long impulse response, as may be encountered with DTV wireless channels.
A frequency domain equalizer may be implemented with less complexity than a time domain DFE.
Where a received signal lacks a cyclic prefix, iterative or turbo equalization may be utilized to achieve a more-satisfactory error rate.
A conventional turbo equalizer may use a pre-defined number of iterations in the equalization of each input block. At low signal-to-noise ratio (SNR), too much iteration may decrease equalizer error rate. At high SNR, too much iteration may cause numerical instability.
In the drawings, the leftmost digit(s) of a reference number identifies the drawing in which the reference number first appears.
Signal 102 may represent a single-carrier signal, such as a digital television broadcast signal, which may be formatted in accordance with a digital television (DTV) standard promulgated by the Advanced Television Systems Committee (ATSC), based in Washington, D.C. System 100 is not, however, limited to these examples.
Channel 104 which may include a wireless channel, characteristics of which may impact symbols of signal 102, such as to rotate constellations of the symbols.
System 100 may include a front end system 106 to frequency down-convert and sample signal 102. System 100 may further include a decision system 107 to evaluate signal 102 and estimate symbols of signal 102 based on the evaluation.
Decision system 107 may be implemented to perform one or more of adaptive multi-mode pre-decoding linear equalization, adaptive channel estimation, turbo equalization, turbo equalization iteration control, and noise variance estimation, one or more of which may be performed in the frequency domain.
Decision system 107 may include a fast Fourier transform (FFT) module 110 to transform time domain samples 108 of signal 102 to a frequency domain representation or frequency tones Y 112.
Decision system 107 may include a linear equalizer 114 to equalize frequency tones 112. Linear equalizer 114 may be implemented as a multi-mode adaptive linear equalizer to equalize frequency domain tones 112 based one or more of multiple selectable equalization techniques.
Decision system 107 may include an inverse fast Fourier transform (IFFT) module 132 to transform equalized frequency tones 116 to time domain bits or samples 134, also referred to herein as a time domain output of linear equalizer 114.
Decision system 107 may include a channel estimator 118 to generate a channel estimate 120, such as a channel frequency response and/or a channel impulse response.
Channel estimator 118 may be implemented to generate channel estimate 120 from pilots or pilot signals of signal 102.
Alternatively, or additionally, channel estimator 118 may include an adaptive decision-directed channel estimator to generate channel estimate 120 based on prior decisions and an adaptive variable step size (VSS) algorithm. An adaptive decision-directed channel estimator may be useful for a relatively long channel response where a pilot sequence may be too short to estimate the channel, and/or for a time-varying channel response where an interval between pilot sequences may be too long to estimate the channel.
Decision system 107 may include a frequency domain turbo equalizer 122 to generate estimated symbol decisions 124 from frequency domain tones 112 based on time domain output 134 of linear equalizer 114, channel estimate 120, and prior decisions.
Decision system 107 may include a hard decision system 128 to generate hard decisions 130 regarding symbols of signal 102. Hard decision system 128 may include, for example, a Viterbi decoder.
Decision system 107, or portions thereof, may be implemented as described in one or more examples below.
Turbo equalizer 122 further includes a soft decision module 206 to generate soft decisions 208. Soft decisions 208 may include estimated bit values and corresponding probabilities of correctness.
Soft decision module 206 may include a Maximum a Posteriori (MAP) decoder to provide a set of posterior probabilities for a symbol of signal 102 based on a time-domain output z(0) 134 of linear equalizer 114 or results z(m) 228 of prior iterations.
A set of posterior probabilities may be represented as:
{p(xi=s|z)}sεS EQ. (1)
A soft decision 208 may be represented as:
An estimated mean square error (MSE) of a soft decision 208 may be computed as in EQ. (3). An average MSE may be computed as in EQ. (4).
Turbo equalizer 122 may further include an FFT module 210 to transform soft decisions
Turbo equalizer 122 may further include an equalizer 214 to transform frequency domain tones Y 112 to blocks of frequency domain elements 216 corresponding to estimated symbols of signal 102 (
For disambiguation purposes, equalizer 214 may be referred to as an a priori equalizer, and linear equalizer 114 may be referred to as a pre-decoder equalizer.
Equalizer 214 may be implemented to determine elements Zk of a frequency domain output block Z 216 as:
In EQS. (5) and (6):
Turbo equalizer 122 may include noise variance estimator 226 to determine noise variance σ2 such as described further below with reference to
Turbo equalizer 122 may further include an IFFF module 218 to transform blocks of frequency domain elements 216 to time domain decision blocks 124.
Soft decision system 206 and a priori equalizer 214 may be implemented to iteratively process blocks of time domain samples 204 and preliminary decisions 228 for each symbol of signal 102.
Turbo equalizer 122 may be implemented to perform a pre-defined and/or fixed number of iterations for each block or symbol before outputting a final decision estimate z 124.
Alternatively, turbo equalizer 122 may include iteration controller 224 to dynamically control a number of turbo equalization iterations performed with respect to a each block or symbol.
A dynamic termination criterion may include a noise-based threshold, which may be based on the average MSE of soft decisions 208. Turbo equalization iterations may be halted, for example, when MSE
A dynamic termination criterion may be combined with other one or more additional termination criteria, which may be dynamic or static. For example, a maximum number of iterations per block or per symbol may be defined, which may reduce equalizer complexity.
In
Linear equalizer 114 may include a frequency domain filter 318 to filter frequency domain elements Y 112, and may further include a filter coefficient generator 320 to generate filter coefficients or weights 322.
Coefficient generator 320 may be implemented to compute coefficients 322 based on one or more linear frequency domain equalization techniques, and to adapt coefficients 322 to time-varying properties of channel 104 in
Coefficient generator 320 may be implemented to adapt coefficients 322 based on an adaptive variable step size (VSS) algorithm. Step size may be varied to control a rate of convergence, and may represent an estimated subcarrier step size.
Coefficient generator 320 may be implemented to compute coefficients 322 based on one or more blind equalization techniques and/or decision-directed techniques such as described in examples below. Coefficient generator 320 is not, however, limited to the examples herein.
Filter coefficient generator 320 may include multiple equalizer modules 326, each to generate filter coefficients 322 based on a corresponding equalization technique.
As an example, filter coefficient generator 320 may include a blind equalizer module 320-1 and a decision-directed equalizer module 320-2.
Blind equalizer module 320-1 may be implemented to adjust filter coefficients 322 to minimize a cost function, which may be based on known or determinable signal statistics, such as a mean energy, and may be implemented to determine filter coefficients 322 without pilot signals or other channel-specific information or statistics.
Blind equalization may be viewed as estimating an equalization filter corresponding to an inverse of a channel impulse response, rather than an estimation of the channel impulse response, and convolving the estimated filter with a received signal to yield an estimation of a corresponding transmitted signal.
Blind equalizer module 320-1 may be implemented based on, for example, a constant modulus (i.e., higher-order statistics) algorithm (CMA), a Sato algorithm, and/or a multi-modulus algorithm (MMA). An example CMA based equalization coefficient generator is described below with reference to
Decision-directed equalizer module 320-2 may be implemented based on a least means squared (LMS) technique to adapt coefficients 322 to reduce mean squares of an error at output 116. An LMS technique may be viewed as a stochastic gradient descent technique, in that filter coefficients are adapted based on an error at a present or current time.
An example LMS equalization coefficient generator is described below with reference to
Filter coefficient generator 320 may include a selector 324 to select one of multiple equalizer modules 326 to generate filter coefficients 322 based on one or more criteria.
For example, a conventional LMS equalizer may initially use pilot data to adjust equalizer weights. Thereafter, the LMS equalizer may use decoder decisions to track time varying channels. Where initial pilot data is missed or too short, the output of the LMS equalizer may not be correctly decoded. This may impede the LMS equalizer from converging on a set of filter weights.
A blind coefficient generator may operate without pilot-based adjustments, while a decision-directed coefficient generator may provide a lower output error.
Selector 324 may be implemented to use blind equalizer 326-1 to generate initial filter coefficients or weights, and decision-directed equalizer 326-2 to refine the initial filter coefficients. In this way, decision-directed equalizer 326-2 may provide a relatively low output error without pilot signals.
Selector 324 may be implemented, for example, to select blind equalizer module 320-1 when the MSE of time domain output 134 of linear equalizer 114 is above a threshold, and to select decision-directed equalizer module 320-2 when the MSE is below the threshold. The MSE of time domain output 134 of linear equalizer 114 may be computed using known pilot symbols.
CMA module 400 includes a gradient module 402 to generate a gradient Δ 404 based on a time domain output z 134 of linear equalizer 114, frequency domain tones Y 112, a shaping function 406, and a constant 408.
CMA module 400 further includes a VSS module 410 to estimate a step size λ 412 based on frequency domain tones Y 112 and gradient Δ 404.
CMA module 400 may be implemented to generate a filter coefficient W(i+1) 416 based on a previous filter coefficient W(i) 414, step size λ 412, and gradient Δ 404 as:
W
(i+1)
=W
(i)−(λ*Δ) EQ. (9)
Coefficients 414 and 416 may correspond to coefficients 322 in
LMS module 500 includes a gradient module 502 to generate a frequency domain gradient Δ 504 based on a time domain output z 134 of linear equalizer 114, hard decisions {circumflex over (x)} 130, frequency domain tones Y 112, and a shaping function 506.
LMS module 500 further includes a variable step size (VSS) module 510 to estimate a step size λ 512 based on frequency domain tones Y 112 and gradient Δ 504.
LMS module 500 may be implemented to generate a filter coefficient W(i+1) 516 based on a previous filter coefficient W(i) 514, step size λ 512 and gradient Δ 504 in accordance with EQ. (9) above.
Coefficients 514 and 516 may correspond to coefficients 322 in
As illustrated in EQS. (5) and (6), channel estimate Ĥ 120 may need to be determined prior to generating a decision estimate 124. In addition, and as described above, channel estimate 120 may need to be determined without reliance on pilot signals.
Channel estimator 600 includes a gradient module 602 to generate a gradient Δ 604 based on a previous channel estimate H(i) 614, frequency domain tones Y 112, and a frequency domain transform of a hard decision {circumflex over (x)} 130.
Channel estimator 600 further includes a VSS module 610 to estimate a step size λ 612 based on gradient Δ 604 and the frequency domain transform of hard decision {circumflex over (x)} 130.
Channel estimator 600 may be implemented to generate channel estimate H(i+1) 616 based on previous channel estimate H(i) 614, gradient Δ 604, and step size λ 612, in accordance with EQ. (8).
Ĥ
k(t+1)=Ĥk(t)−λk({circumflex over (X)}kĤk(t)−Yk){circumflex over (X)}k EQ. (10)
In EQ. (10):
In
Estimated step size 702 may correspond to one or more of estimated step sizes 412, 512, and 612 in corresponding
Similarly, gradient 706 may correspond one or more of gradients 404, 504, and 604 in corresponding
Noise variance estimator 800 may be implemented to compute a noise variance {circumflex over (σ)}2block 802 for a block undergoing turbo equalization as a function of a channel estimate H(i) 120, a frequency domain transform {circumflex over (X)} of a hard decision {circumflex over (x)} 130, and frequency domain tones Y 112, in accordance with EQ. (11):
Adaptive noise variance estimator 800 may be further implemented to maintain a moving average 804 of the estimated noise variance as:
{circumflex over (σ)}2={circumflex over (σ)}2β+(1−β){circumflex over (σ)}block2 EQ. (12)
In EQ. (10), β is smoothing factor, also referred to herein as a forgetting factor, where 0≦β≦1.
At 902, samples of a received single-carrier signal are converted to a frequency domain representation.
At 904, the frequency domain representation of the signal is equalized with a linear filter and adaptive filter coefficients. The equalization at 904 may include selectively equalizing with one of multiple equalization techniques, such as described in one or more examples above.
At 906, a frequency response is estimated for a channel of the received signal using an adaptive decision-directed technique, such as described above with reference to
At 908, the frequency domain representation of the signal is turbo equalized based on results of the linear equalization at 904 and the estimated channel response.
At 910, hard decisions are generated regarding symbols of the received signal.
At 1002, samples of a received single-carrier signal are converted to a frequency domain representation.
At 1004, the frequency domain representation of the signal is equalized with an adaptive blind equalization technique, such as a CMA technique.
At 1006, where the MSE of results of the equalization at 904 are below a threshold, processing may proceed to 1008 where the frequency domain representation of the signal is equalized with an adaptive decision-directed equalization technique, such as a LMS technique.
At 1010, a frequency response is estimated for a channel of the received signal using an adaptive decision-directed technique.
At 1012, the frequency domain representation of the signal is turbo equalized based on results of the linear equalization at 1004 and/or 1008, and the estimated channel response.
At 1014, hard decisions are generated regarding symbols of the received signal.
At 1102, samples of a received single-carrier signal are converted to a frequency domain representation.
At 1104, the frequency domain representation of the signal is equalized with a linear filter and adaptive filter coefficients such as described above with respect to 904 and/or 1004 through 1008.
At 1106, a frequency response is estimated for a channel of the received signal using an adaptive decision-directed technique.
At 1108, a noise variance is estimated, such as described above with reference to
At 1110, the frequency domain representation of the signal is turbo equalized based on results of the linear equalization at 1104, the estimated channel response, and the estimated noise variance, such as described above with reference to EQS. (5) and (6).
At 1112, an MSE of a soft decoder output may be compared to a threshold. When the MSE is below the threshold, turbo equalization iteration may be halted and a decision estimate for a symbol may be output for hard decision processing at 1116.
At 1114, the number of iterations of a block being turbo equalized may be compared to a maximum iteration threshold. Where the maximum iteration threshold is reached, turbo equalization iteration may be halted and a decision estimate for a symbol may be output for hard decision processing at 1116.
One or more of methods 900, 1000, and 1100 may include computing variable step sizes for one or more adaptive linear frequency domain equalization techniques and/or channel estimation, such as described in one or more examples above.
Methods and systems disclosed herein 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, and/or a combination of integrated circuit packages. Software may include a computer readable medium encoded with a computer program including instructions to cause a processor to perform one or more functions in response thereto. The computer readable medium may include a transitory and/or non-transitory medium. The processor may include a general purpose instruction processor, a controller, a microcontroller, and/or other instruction-based processor.
Methods and systems disclosed herein may be implemented with respect to one or more of a variety of systems including one or more consumer systems, such as described below with reference to
System 100, digital processor system 1204, and/or portions thereof, may be implemented within one or more integrated circuit dies, and may be implemented as a system-on-a-chip (SoC).
User interface system 1202 may include a monitor or display 1232 to display information from digital processor system 1230.
User interface system 1202 may include a human interface device (HID) 1234 to provide user input to digital processor system 1230. HID 1234 may include, for example and without limitation, one or more of a key board, a cursor device, a touch-sensitive device, and or a motion and/or image sensor. HID 1234 may include a physical device and/or a virtual device, such as a monitor-displayed or virtual keyboard.
User interface system 1202 may include an audio system 1236 to receive and/or output audible sound.
System 1200 may further include a transmitter system to transmit signals from system 1200.
System 1200 may correspond to, for example, a computer system, a personal communication device, and/or a television set-top box.
System 1200 may include a housing to receive one or more of system 100, digital processor system 1204, user interface system 1202, or portions thereof. The housing may include, without limitation, a rack-mountable housing, a desk-top housing, a lap-top housing, a notebook housing, a net-book housing, a set-top box housing, a portable housing, and/or other conventional electronic housing and/or future-developed housing. For example, system 100 may be implemented to receive a digital television broadcast signal, and system 1200 may include a set-top box housing or a portable housing, such as a mobile telephone housing.
Methods and systems are disclosed herein with the aid of functional building blocks illustrating 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.
While various embodiments are disclosed herein, it should be understood that they have been presented by way of example only, and not limitation. It will be apparent to persons skilled in the relevant art that various changes in form and detail may be made therein without departing from the spirit and scope of the methods and systems disclosed herein. Thus, the breadth and scope of the claims should not be limited by any of the example embodiments disclosed herein.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/RU2011/001047 | 12/29/2011 | WO | 00 | 6/5/2014 |