I. Field
The present invention relates generally to data communication, and more specifically to techniques for optimizing channel estimation in an orthogonal frequency division multiplexing (OFDM) communication system supporting multiple modes of communication.
II. Background
OFDM is a multi-carrier modulation technique that effectively partitions the overall system bandwidth into multiple (N) orthogonal subbands. These subbands may also be referred to as tones, subcarriers, bins, and frequency channels. With OFDM, each subband is associated with a respective subcarrier that may be modulated with data.
In a wireless communication system, a radio frequency (RF) modulated signal may travel via a number of signal paths from a transmitter to a receiver. If the signal paths have different delays, then the received signal at the receiver would include multiple instances of the transmitted signal with different gains and delays. This time dispersion in the wireless channel causes frequency selective fading, which is characterized by a frequency response that varies across the system bandwidth. For an OFDM system, the N subbands may thus experience different effective channels and may consequently be associated with different complex channel gains.
An accurate estimate of the wireless channel between the transmitter and the receiver is normally needed in order to effectively receive data on the available subbands. Channel estimation is typically performed by sending a pilot from the transmitter and measuring the pilot at the receiver. A pilot is made up of modulation symbols that are known a priori by the receiver. The receiver can estimate the channel response as the ratio of the received pilot symbol over the transmitted pilot symbol, and can determine the ratio for each subband used for pilot transmission.
Pilot transmission represents overhead in the OFDM system. Thus, it is desirable to minimize pilot transmission to the extent possible. This can be achieved by sending pilot symbols on a subset of the N total subbands and using these pilot symbols to derive channel estimates for all subbands of interest. As described below, the computation to derive the channel estimates can be great for certain systems such as, for example, (1) a spectrally shaped system that does not transmit data/pilot near the band edges and (2) a system that cannot transmit data/pilot on certain subbands (e.g., zero or DC subband). There is therefore a need in the art for techniques to efficiently estimate the channel response for these systems.
Techniques to efficiently derive at least one frequency response estimate for a multiple-access wireless channel in an OFDM system with inactive subbands are described herein. These techniques may be used for an OFDM system that transmits pilot on subbands that are not uniformly distributed across N total subbands. An example of such a system is a spectrally shaped OFDM system in which only M subbands, which are centered among the N total subbands, are used for data/pilot transmission and the remaining N−M subbands at the two band edges are not used and served as guard subbands. The inactive subbands may thus be the guard subbands, DC subband, and so on.
For the channel estimation, an initial frequency response estimate is obtained for a first set of P uniformly spaced subbands based on, for example, pilot symbols received on a second set of subbands used for pilot transmission, where P is an integer that is a power of two. The first set includes at least one subband not included in the second set (e.g., pilot subbands among the guard subbands). Moreover, the subbands in the first set are uniformly spaced apart by N/P subbands. Extrapolation and/or interpolation may be used, as necessary, to obtain the initial frequency response estimate.
A time-domain channel impulse response estimate for the wireless channel is then derived based on the initial frequency response estimate, for example, by performing a P-point inverse fast Fourier transform (IFFT). For each mode within each OFDM symbol, a final frequency response estimate for the N total subbands is then derived based on the channel impulse response estimate. This may be achieved, for example, by (1) setting low quality taps in the channel impulse response estimate to zero and retaining the remaining taps, (2) zero-padding the channel impulse response estimate to length N, (3) setting to zero taps in the channel impulse response representing a time delay greater than a predetermined delay spread, and (3) performing an N-point fast Fourier transform (FFT) on the processed channel impulse response estimate to obtain the final frequency response estimate.
The thresholding and truncation of the channel impulse response can be varied depending on a mode of the data subbands for which the channel estimate is generated. Thus, the same channel impulse response can generate different final frequency response estimates that vary based on the mode of the data subbands. The channel impulse response estimates or frequency response estimates for multiple OFDM symbols may be filtered for each mode to obtain a higher quality channel estimate for the wireless channel.
Various aspects and embodiments of the invention are described in further detail below.
The features, nature, and advantages of the present invention will become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout and wherein:
The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any embodiment or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments or designs.
The N subbands of the OFDM system may experience different channel conditions (e.g., different fading and multipath effects) and may be associated with different complex channel gains. An accurate estimate of the channel response is normally needed to process (e.g., demodulate and decode) data at a receiver.
The wireless channel in the OFDM system may be characterized by either a time-domain channel impulse response hN×1 or a corresponding frequency-domain channel frequency response HN×1. As used herein, and which is consistent with conventional terminology, a “channel impulse response” is a time-domain response of the channel, and a “channel frequency response” is a frequency-domain response of the channel. The channel frequency response HN×1 is the discrete Fourier transform (DFT) of the channel impulse response hN×1. This relationship may be expressed in matrix form, as follows:
HN×1=WN×NhN×1 Eq (1)
where hN×1 is an N×1 vector for the impulse response of the wireless channel between a transmitter and a receiver in the OFDM system;
The impulse response of the wireless channel can be characterized by L taps, where L is typically less than the number of total subbands (i.e., L<N). That is, if an impulse is applied to the wireless channel by the transmitter, then L time-domain samples (at the sample rate of BW MHz) would be sufficient to characterize the response of the wireless channel based on this impulse stimulus. The number of taps (L) for the channel impulse response is dependent on the delay spread of the system, which is the time difference between the earliest and latest arriving signal instances of sufficient energy at the receiver. A longer delay spread corresponds to a larger value for L, and vice versa. The vector hN×1 includes one entry for each tap of the channel impulse response. For a delay spread of L, the first L entries of the vector hN×1 may contain non-zero values and the N−L remaining entries are all zeros or are otherwise insignificant values.
Because only L taps are needed for an accurate estimate of the channel impulse response, the channel frequency response HN×1 lies in a subspace of dimension L (instead of N). The frequency response of the wireless channel may thus be fully characterized based on channel gain estimates for as few as L appropriately selected subbands, instead of all N subbands. Even if channel gain estimates for more than L subbands are available, an improved estimate of the frequency response of the wireless channel may be obtained by suppressing the noise components outside this subspace.
In one embodiment, the N−L taps corresponding to the longest delays may be truncated from an N-tap channel impulse response with relatively no degradation of the channel impulse response. The dimension of the channel impulse response can be maintained at N by setting to zero, or some other substantially insignificant value, N−L channel taps. Thus, in the context of channel impulse response, the term truncation refers to the setting an insignificant value the channel taps beyond a predetermined delay spread.
The M−P subbands can be used to support a communication link with a single user or multiple communication links corresponding to multiple users. Additionally, each of the subbands may be multiplexed to support multiple users or multiple data links. In one embodiment, a subset of the M−P subbands can be allocated to a distinct communication link.
The M−P subbands may be allocated in substantially equal subband sets, with subbands within a subband set operating in the same mode. For example, the M−P subbands can be allocated to any one of Q predetermined subband sets, with each of the Q subband sets having substantially the same number of subbands.
The subbands allocated to a particular subband set from the Q subband set can all operate in the same mode. For example, each of the subcarriers corresponding to the subbands in the subband set can be modulated with the same modulation type, have substantially the same data rate, have data encoded with the same encoder types, encoding rate, layered modulation type, or share some other signaling parameter or combination of parameters.
In one embodiment, each mode can refer to a particular combination of encoder rate and modulation type. For example, each of the subband sets can be configured according to one of eleven distinct modes that includes a particular combination of modulation type, encoder type, and encoding rate. The modes include: Quadrature Phase Shift Keying (QPSK), rate ⅓ turbo code; QPSK, rate ½ turbo code; 16 Quadrature Amplitude Modulation (QAM), rate ⅓ turbo code; 16 QAM, rate ½ turbo code; 16 QAM, rate ⅔ turbo code; QPSK, rate ⅕ turbo code; Layered QPSK, energy ratio 4, rate ⅓ turbo code; Layered QPSK, energy ratio 4, rate ½ turbo code; Layered QPSK, energy ratio 4, rate ⅔ turbo code; Layered QPSK, energy ratio 6.25, rate ⅓ turbo code; Layered QPSK, energy ratio 6.25, rate ½ turbo code; and Layered QPSK, energy ratio 6.25, rate ⅔ turbo code. The term “energy ratio” refers, generally, to a ratio determined from the dimensions of the base layer relative to dimensions of the enhancement layer. For example, the energy ratio can be determined as a ratio of the base layer constellation distance squared to the enhancement layer constellation distance squared. Of course, the system is not limited to having eleven modes of operation, and other systems may have greater or fewer operating modes.
The model for the OFDM system may be expressed as:
rN×1=HN×1∘xN×1+nN×1 Eq (3)
where xN×1 is an N×1 vector with N “transmit” symbols sent by the transmitter on the N subbands, with zeros being sent on the unused subbands;
An initial estimate of the frequency response of the wireless channel, ĤP×1init, may be obtained as follows:
ĤP×1init=rP×1p/xP×1p=HP×1p+nP×1p/xP×1p, Eq (4)
where xP×1p, is a P×1 vector with P pilot symbols sent on the P pilot subbands;
A frequency response estimate for the N total subbands may be obtained based on the initial frequency response estimate ĤP×1init using various techniques. For a direct least-squares estimation technique, a least square estimate of the impulse response of the wireless channel is first obtained based on the following optimization:
where hL×1 is an L×1 vector for a hypothesized impulse response of the wireless channel;
The matrix WP×L contains P rows of the matrix WN×N corresponding to the P pilot subbands. Each row of WP×L contains L elements, which are the first L elements of the corresponding row of WN×N. The optimization in equation (5) is over all possible channel impulse responses hL×1. The least square channel impulse response estimate ĥL×1ls is equal to the hypothesized channel impulse response hL×1 that results in minimum mean square error between the initial frequency response estimate ĤP×1init and the frequency response corresponding to hL×1, which is given by WP×LhL×1.
The solution to the optimization problem posed in equation (5) may be expressed as:
ĥL×1ls=(WP×LHWP×L)−1WP×LHĤP×1init. Eq (6)
The frequency response estimate for the wireless channel may then be derived from the least square channel impulse response estimate, as follows:
ĤN×1ls=WN×LĥL×1ls, Eq (7)
where WN×L is an N×L matrix with the first L columns of WN×N; and
The vector ĤN×1ls can be computed in several manners. For example, the vector ĥL×1ls can be computed first as shown in equation (6) and then used to compute the vector ĤN×1ls as shown in equation (7). For equation (6), (WP×LHWP×L)−1WP×LH is an L×P matrix that can be pre-computed. The impulse response estimate ĥL×1ls can then be obtained with L·P complex operations (or multiplications). For equation (7), the frequency response estimate ĤN×ls can be more efficiently computed by (1) extending the L×1 vector ĥL×1ls (with zero padding) to obtain an N×1 vector ĥN×1ls and (2) performing an N-point FFT on ĥN×1ls which requires 0.5 N·log N complex operations. The frequency response estimate ĤN×1ls can thus be obtained with a total of (L·P+0.5 N·log N) complex operations for both equations (6) and (7).
Alternatively, the vector ĤN×1ls can be computed directly from the vector ĤP×1init by combining equations (6) and (7), as follows:
ĤN×1ls=WN×L(WP×LHWP×L)−1WP×LHĤP×1init, Eq (8)
where WN×L(WP×LHWP×L)−1WP×LH is an N×P matrix that can be pre-computed. The frequency response estimate ĤN×1ls can then be obtained with a total of N·P complex operations.
For the two computation methods described above, the minimum number of complex operations needed to obtain ĤN×1ls for one OFDM symbol is Nop=min{(L·P+0.5 N·log N), N·P}. If pilot symbols are transmitted in each OFDM symbol, then the rate of computation is Nop/Tsym million operations per second (Mops), which is Nop·BW/N Mops, where Tsym is the duration of one OFDM symbol and is equal to N/BW μsec with no cyclic prefix (described below). The number of complex operations, Nop, can be very high for an OFDM system with a large number of subbands. As an example, for an OFDM system with an overall bandwidth of BW=6 MHz, N=4096 total subbands, P=512 pilot subbands, and L=512 taps, 420 Mops are needed to compute ĤN×1ls using equations (6) and (7). Since equation (6) requires 384 Mops and equation (7) requires 36 Mops, the computation for the least square channel impulse response estimate in equation (6) is significantly more burdensome than the computation for the N-point FFT in equation (7).
Pilot transmission scheme 200 in
The uniform transmission scheme shown in
In one example, the total number of subbands, N, can be 4096 and the number of subband sets, Q, can be 8. Thus, there are P=512 subbands in each subband set, with the subbands occurring periodically across the band, occurring once every eight subbands.
In this case, WP×P is a P×P DFT matrix, WP×PHWP×P=I where I is the identity matrix, and equation (6) can be simplified as:
ĥP×1ls =WP×PHĤP×1init. Eq (9)
Equation (9) indicates that the channel impulse response estimate ĥP×1ls can be obtained by performing a P-point IFFT on the initial frequency response estimate ĤP×1init. The vector ĥP×1ls can be zero-padded to length N. The zero-padded vector ĥN×1ls can then be transformed with an N-point FFT to obtain the vector ĤN×1ls, as follows:
ĤN×1ls=WN×NĥN×1ls. Eq (10)
An S×1 vector ĤS×1ls for the frequency response estimate for S subbands of interest may also be obtained based on the vector ĥP×1ls, where in general N≧S≧P. If S is a power of two, then an S-point FFT can perform to obtain ĤS×1ls.
With pilot transmission scheme 300, the number of complex operations required to obtain ĤN×1ls for one OFDM symbol is Nop=0.5·(P·log P+N·log N) and the rate of computation is 0.5·BW·(P·log P+N·log N)/N Mops. For the exemplary OFDM system described above, ĤN×1ls can be computed with 39.38 Mops using pilot transmission scheme 300, which is much less than the 420 Mops needed for pilot transmission scheme 200.
The reduced-complexity least square channel impulse response estimation described above in equations (9) and (10) relies on two key assumptions:
Various techniques may be used to overcome the two restrictions described above. First, extrapolation and/or interpolation may be used, as necessary, to obtain channel gain estimates for P uniformly spaced subbands based on the received pilot symbols. This allows the channel impulse response estimate ĥP×1ls to be derived with a P-point IFFT. Second, tap selection may be performed on the P elements of ĥP×1ls to obtain a higher quality channel estimate. Extrapolation/interpolation and tap selection are described in detail below.
A P-point IFFT is then performed on the vector ĤP×1init to obtain the P×1 vector ĥP×1ls for the least square channel impulse response estimate, as shown in equation (9) (block 618). Time-domain filtering may be performed on the channel impulse response estimates ĥP×1ls for multiple OFDM symbols to obtain a higher quality channel estimate (block 620). The time-domain filtering may be omitted or may be performed on frequency response estimates instead of impulse response estimates. The (filtered or unfiltered) vector ĥP×1ls includes P entries for L taps, where L is typically less than P. The vector ĥP×1ls is then processed to select “good” taps and discard or zero out remaining taps, as described below (block 622). For each mode, zero padding is also performed to obtain the corresponding N×1 vector ĥN×1ls for the channel impulse response estimate (block 624). An N-point FFT is then performed on the each vector ĥN×1ls to obtain the vector ĤN×1ls for the final frequency response estimate for each mode for the N total subbands (block 626).
Extrapolation/Interpolation
For block 614 in
In one extrapolation scheme, the channel gain estimate for each inactive pilot subband is set equal to the channel gain estimate for the nearest active pilot subband, as follows:
where Ĥ(si) is the channel gain estimate for subband si, sb is the first active pilot subband, and se is the last active pilot subband, as shown in
In another extrapolation scheme, the channel gain estimate for each inactive pilot subband is obtained based on a weighted sum of the channel gain estimates for the active pilot subbands. If the number of taps L is less than or equal to the number of active pilot subbands (i.e., L≦Pact), then (in the absence of noise) the wireless channel can be completely characterized by the channel gain estimates for the active pilot subbands. For the extrapolation, each inactive pilot subband is associated with a respective set of extrapolation coefficients, one coefficient for each active pilot subband, where each coefficient may be a zero or non-zero value. The extrapolation/interpolation for the inactive pilot subbands may be expressed in matrix form, as follows:
ĤP
where CP
The number of complex operations required for extrapolation in equation (12) is Pext·Pact. The number of inactive pilot subbands is
where G is the number of guard subbands and “┌x┐” is a ceiling operator that provides the next higher integer for x. The number of inactive pilot subbands in the system is typically small if the number of guard subbands is small. For example, the OFDM system described above may have only 10 inactive pilot subbands (i.e., Pext=10) out of 512 pilot subbands (i.e., P=512 ) if there are 80 guard subbands (i.e., G=80). In this case, the computation required for extrapolation does not greatly increase computational complexity. The computational complexity can also be reduced explicitly by restricting the extrapolation to use a subset of the active pilots.
The extrapolation coefficients can be fixed and determined offline (i.e., pre-computed) based on a criterion such as least-squares, minimum mean square error (MMSE), and so on. For least-squares extrapolation, a coefficient matrix CP
CP
where WP
CP
where δ is a small correction factor.
For MMSE extrapolation, a coefficient matrix CP
CP
where γ the signal-to-noise ratio (SNR) of the received pilot symbols; and
In yet another extrapolation scheme, the channel gain estimate for each inactive pilot subband is set equal to zero, i.e., Ĥ(si)=0 for si<sb and si>se. The extrapolation may also be performed in other manners, and this is within the scope of the invention. For example, functional extrapolation techniques such as linear and quadratic extrapolation may be used. Non-linear extrapolation techniques may also be used, which fall within the general framework of equation (12).
A pilot transmission scheme may not distribute the active pilot subbands uniformly across the M usable subbands. In this case, interpolation may also be used to obtain channel gain estimates for uniformly spaced subbands within the M usable subbands. The interpolation may be performed in various manners, similar to that described above for extrapolation. In general, extrapolation and/or interpolation may be performed as necessary based on the available received pilot symbols to obtain channel gain estimates for P subbands uniformly spaced across the N total subbands.
Tap Processing
For block 622 in
Tap Truncation
In one tap processing scheme, the channel impulse response estimate ĥP×1ls is truncated to L values for the L taps of the wireless channel. The vector ĥP×1ls contains P elements, where P≧L. The P elements span a delay spread determined by the number of taps, P, and the original time interval over which the samples are taken. However, the delay spread of the channel impulse response may be truncated to a shorter delay spread without significantly affecting the channel impulse response estimate and the resulting final channel frequency response.
For this deterministic tap selection scheme, the first L elements of ĥP×1ls are considered as good taps and retained, and the last P−L elements are replaced with zeros. When L<P, the least squares channel impulse response estimate with L taps can be obtained (without loss in performance) by assuming a channel with P taps, performing a P-point IFFT, and truncating the last P−L taps. This has some benefits in certain situations. For example, if L<P/2, then the least squares channel impulse response estimate can be derived with the computational benefits of the FFT and not computing the last P/2 taps.
The truncation length, L, can be predetermined, and can be based at least in part on the operating mode. There may be a distinct truncation length, L, for each possible operating mode. In such an embodiment, the receiver can determine in which mode the data subbands are operating and select the truncation length from a plurality of truncation length values stored in memory.
Tap Magnitude Thresholding
In another tap selection scheme, the elements of ĥP×1ls with low energy are replaced with zeros. Alternatively, the elements of ĥP×1ls having low energy can be replaced or otherwise processed to result in substantially negligible values for these taps. These elements of ĥP×1ls correspond to taps with low energy, where the low energy is likely due to noise rather than signal energy. A threshold is used to determine whether a given element/tap has sufficient energy and should be retained or should be zeroed out. This process may be referred to as “thresholding”.
The threshold can be computed based on various factors and in various manners. The threshold can be a relative value (i.e., dependent on the measured channel response) or an absolute value (i.e., not dependent on the measured channel response). A relative threshold can be computed based on the (e.g., total or average) energy of the channel impulse response estimate. The use of the relative threshold ensures that (1) the thresholding is not dependent on variations in the received energy and (2) the elements/taps that are present but with low signal energy are not zeroed out. An absolute threshold can be computed based on the noise variance/noise floor at the receiver, the lowest energy expected for the received pilot symbols, and so on. The use of the absolute threshold forces the elements of ĥP×1ls to meet some minimum value in order to be retained. The threshold can also be computed based on a combination of factors used for relative and absolute thresholds. For example, the threshold can be computed based on the energy of the channel impulse response estimate and further constrained to be equal to or greater than a predetermined minimum value.
The thresholding can be performed in various manners. In one thresholding scheme, the thresholding is performed after the truncation and may be expressed as:
where ĥP×1ls=[ĥ(0)ĥ(1) . . . ĥ(P−1)]T, where the last P−L elements are replaced with zeros by the truncation;
In equation (16), the threshold is defined based on the average energy of the L taps. The coefficient α is selected based on a trade off between noise suppression and signal deletion. A higher value for α provides more noise suppression but also increases the likelihood of a low signal energy element/tap being zeroed out. The coefficient α can be a value within a range of 0 to 1 (e.g., α=0.1). The threshold can also be defined based on the total energy (instead of the average energy) for the channel impulse response estimate ĥP×1ls.
The threshold may be fixed or adapted based on the operating mode of the data subbands for which the channel estimate is to be used. For example, the threshold value can be based on (1) the particular coding and modulation scheme or rate of the data stream being demodulated (2) a bit error rate (BER), packet error rate (PER), block error rate (BLER), or some other error rate performance requirement, and/or (3) some other parameters and considerations.
A receiver that is configured to support one or more modes can be configured to store at least one predetermined threshold value for each mode. The receiver can determine which mode the data subbands are operating and can select the appropriate threshold from a plurality of threshold values stored in memory. The tap values of the impulse response or values derived from the tap values can be compared against the threshold or a value determined based on the threshold value. For example, a receiver can store a plurality of α values, with each cc value corresponding to a distinct mode. The receiver can determine the operating mode and can determine a threshold based on the corresponding α value. The individual tap energy values can be compared against the threshold value, and taps having energy values less than the threshold value can be set to zero.
In another thresholding scheme, the thresholding is performed on all P elements of ĥP×1ls (i.e., without truncation) using a single threshold, similar to that shown in equation (16). In yet another thresholding scheme, the thresholding is performed on all P elements of ĥP×1ls using multiple thresholds. For example, a first threshold may be used for the first L elements of ĥP×1ls, and a second threshold may be used for the last P−L elements of ĥP×1ls. The second threshold may be set lower than the first threshold. In yet another thresholding scheme, the thresholding is performed on only the last P−L elements of ĥP×1ls and not on the first L elements. The thresholding may be performed in other manners.
Thresholding is well suited for a wireless channel that is “sparse”, such as a wireless channel in a macro-cellular broadcast system. A sparse wireless channel has much of the channel energy concentrated in few taps. Each tap corresponds to a resolvable signal path with different time delay. A sparse channel includes few signal paths even though the delay spread (i.e., time difference) between these signal paths may be large. The taps corresponding to weak or non-existing signal paths can be zeroed out or otherwise made insignificant.
Channel Estimate Filtering
For block 518 in
The characteristics (e.g., bandwidth) of the filter may be selected based on the characteristics of the wireless channel. Time-domain filtering may be performed separately for each tap of the channel impulse response estimate across multiple OFDM symbols. The same or different filters may be used for the taps of the channel impulse response estimate. The coefficients for each such filter may be fixed or may be adjustable based on detected channel conditions. Performing the filtering in the time domain has an advantage in that the pilot subbands can be staggered in the frequency domain (i.e., different sets of pilot subbands may be used for different OFDM symbols). The staggering of pilot subbands is useful when the channel has an excess delay spread (i.e., the channel impulse response has a length greater than P taps). A channel impulse response estimate with more than P taps can be obtained with the additional and different pilot subbands provided by staggering. The filtering may also be performed on the initial or final frequency response estimates.
OFDM System
OFDM modulator 720 further transforms each set of N transmit symbols to the time domain using an N-point IFFT to obtain a “transformed” symbol that contains N time-domain chips. OFDM modulator 720 typically repeats a portion of each transformed symbol to obtain a corresponding OFDM symbol. The repeated portion is known as a cyclic prefix and is used to combat delay spread in the wireless channel.
A transmitter unit (TMTR) 722 receives and converts the stream of OFDM symbols into one or more analog signals and further conditions (e.g., amplifies, filters, and frequency upconverts) the analog signals to generate a downlink signal suitable for transmission over the wireless channel. The downlink signal is then transmitted via an antenna 724 to the terminals.
At terminal 750, an antenna 752 receives the downlink signal and provides a received signal to a receiver unit (RCVR) 754. Receiver unit 754 conditions (e.g., filters, amplifies, and frequency downconverts) the received signal and digitizes the conditioned signal to obtain samples. An OFDM demodulator 756 removes the cyclic prefix appended to each OFDM symbol, transforms each received transformed symbol to the frequency domain using an N-point FFT, obtains N received symbols for the N subbands for each OFDM symbol period, and provides received pilot symbols {{circumflex over (P)}dn(si)} to a processor 770 for channel estimation.
OFDM demodulator 756 further receives a frequency response estimate ĤN×1,dnls for the downlink from processor 770, performs data demodulation on the received data symbols to obtain data symbol estimates (which are estimates of the transmitted data symbols), and provides the data symbol estimates to an RX data processor 758. RX data processor 758 demodulates (i.e., symbol demaps), deinterleaves, and decodes the data symbol estimates to recover the transmitted traffic data. The processing by OFDM demodulator 756 and RX data processor 758 is complementary to the processing by OFDM modulator 720 and TX data processor 710, respectively, at access point 700.
Processor 770 obtains the received pilot symbols for the active pilot subbands and performs channel estimation as shown in
On the uplink, a TX data processor 782 processes traffic data and provides data symbols. An OFDM modulator 784 receives and multiplexes the data symbols with pilot symbols, performs OFDM modulation, and provides a stream of OFDM symbols. The pilot symbols may be transmitted on Pup subbands that have been assigned to terminal 750 for pilot transmission, where the number of pilot subbands (Pup) for the uplink may be the same or different from the number of pilot subbands (Pdn) for the downlink. The pilot symbols may also be multiplexed with the data symbols using TDM. A transmitter unit 786 then receives and processes the stream of OFDM symbols to generate an uplink signal, which is transmitted via an antenna 752 to the access point.
At access point 700, the uplink signal from terminal 150 is received by antenna 724 and processed by a receiver unit 742 to obtain samples. An OFDM demodulator 744 then processes the samples and provides received pilot symbols {{circumflex over (P)}up(si)} and data symbol estimates for the uplink. An RX data processor 746 processes the data symbol estimates to recover the traffic data transmitted by terminal 750.
Processor 730 performs channel estimation for each active terminal transmitting on the uplink as shown in
Processors 730 and 770 direct the operation at access point 700 and terminal 750, respectively. Memory units 732 and 772 store program codes and data used by processors 730 and 770, respectively. Processors 730 and 770 also perform the computation described above to derive frequency and impulse response estimates for the uplink and downlink, respectively.
For a multiple-access OFDM system (e.g., an orthogonal frequency division multiple-access (OFDMA) system), multiple terminals may transmit concurrently on the uplink. For such a system, the pilot subbands may be shared among different terminals. The channel estimation techniques may be used in cases where the pilot subbands for each terminal span the entire operating band (possibly except for the band edges). Such a pilot subband structure would be desirable to obtain frequency diversity for each terminal.
OFDM Receiver
The receiver 800 can be implemented in the terminal of a mobile station, for example, in an OFDM system supporting downlink only. In another embodiment, the receiver 800 can be implemented in one or more of the access point or the terminal in an OFDMA system, where the forward link downlink signal as well as the reverse link uplink signals are transmitted using OFDM symbols.
The receiver 800 includes an Analog to Digital Converter (ADC) 802 configured to sample the received OFDM symbol and convert the samples to a digital representation. For example, the conversion rate of the ADC 802 can represent the sample rate.
The output of the ADC 802 is coupled to a buffer 804 that can also be configured to perform serial to parallel conversion. The digital samples of the received OFDM symbol generated by the ADC 802 represent a serial data stream of samples. The buffer 804 can be configured to store a predetermined number of samples for parallel processing. The predetermined number of samples can equal to or greater than the number of subbands in the OFDM system. In some embodiments, the buffer 804 can be configured to store samples for multiple symbols. For example, in an OFDM system having 4096 subbands, the buffer 804 can be configured to store 4096 or more digital samples of the received OFDM symbol for subsequent processing.
The buffer 804 is coupled to an input of an FFT module 806 configured to transform the samples stored in the buffer 804 to a frequency domain representation. In the example presented above, where the buffer 804 stores 4096 samples, the FFT module 806 can be configured to perform an 4096-point FFT on the samples to produce 4096 frequency domain samples.
As previously described, the OFDM symbol can include a number of subband sets, with one or more of the subband sets allocated to pilot and one or more distinct subband sets allocated to data. The receiver 800 can have knowledge of the subband sets allocated to the pilot. Additionally, the receiver 800 can determine or be assigned one or more data subband sets. A data extraction module 808 operates on the output of the FFT module 806 to extract the data subbands assigned to the receiver 800. The data extraction module 808 couples the extracted data subbands to a demodulator 810 that demodulates the subbands using a channel estimate to recover the data.
The demodulator 810 or some other functional block can determine the operating mode of the subband set assigned to the receiver 800 in any of a variety of ways. For example, the receiver 800 can demodulate an overhead message that specifies the mode of one or more frames of OFDM symbols, information in the OFDM symbols can include information that specifies the mode of one or more frames of subsequent OFDM symbols, or some other manner of signaling the receiver 800 of the mode can be used.
The output of the FFT module 806 is also coupled to a pilot extraction module 820. The pilot extraction module 820 can extract the pilot subband samples, for example, by tracking the subbands assigned to the pilot. As described earlier, in an OFDM system having 4096 subbands, 512 subbands can be allocated to the pilot each symbol. The pilot extraction module 820 can determine which of the subbands are assigned to the pilot and can extract those samples to a memory. For example, the pilot extraction module 820 can be configured to extract the 512 samples corresponding to pilot subbands from the 4096 samples output from the FFT module 806.
The pilot extraction module 820 couples the pilot samples to a descrambler 824. Each of the pilot signals corresponding to the pilot subbands can be scrambled according to a predetermined scrambling scheme. The scrambling scheme can be used, for example, to randomize the characteristics of the pilot signals, such that they do not repeatedly generate the same noise and interference, but instead, appear as additional low level noise sources. The pilot scrambling scheme is predetermined, and the descrambler 824 can be configured to perform the complement of the pilot scrambling scheme used at the transmitter.
The descrambled pilot samples represent an initial channel frequency response estimate. However, the channel frequency response estimate can be improved by further processing the initial channel frequency response estimate based on the mode of the data subbands that are to be processed using the channel estimate.
The initial channel frequency response estimate is coupled from the descrambler 824 to an inverse FFT (IFFT) module 830. The IFFT module 830 can have a dimension that is smaller than the dimension of the initial FFT module 806, because the pilot subbands represent only a subset of the entire number of subbands in the OFDM system. In the example described above, there are 512 pilot subbands. Thus, the IFFT module 830 can be configured to perform a 512-point IFFT. Reducing the dimension of the IFFT module 830 can greatly reduce the number of operations performed by the IFFT module 830, and the number of subsequent operations needed to produce the final channel frequency response estimate.
The IFFT module 830 operates on the initial channel frequency response estimate to produce a channel impulse response. Each of the outputs from the IFFT module 830 represents a distinct time tap. The channel impulse response is thus characterized by a plurality of time taps that span an entire delay spread that is determined based on the duration of the sample interval used to capture the initial samples of the received OFDM symbol.
As described earlier, the channel impulse response may be accurately characterized by fewer samples than are output from the IFFT module 830. The output of the IFFT module 830 is coupled to a truncation module 840 that operates to truncate the channel impulse response to a predetermined delay spread based at least in part on a mode of the data subbands that are to be processed using the channel estimate.
The truncation module 840 truncates the channel impulse response by setting taps larger than a predetermined delay spread to zero or some substantially insignificant value. The truncation module 840 can receive a control signal that indicates the predetermined delay spread, after which the taps are truncated or set to zero. for example, the control signal can be a dimension of the channel impulse response vector, corresponding to a number of taps in the channel impulse response.
In the embodiment shown in
A first multiplexer 842 can be coupled to the truncation memory 844 and can select one of the stored delay spread values to couple to the truncation module 840 based on a control signal provided by a mode control module 890. The mode control module 890 controls the first multiplexer to select a delay spread value from the plurality of stored values based on the mode of the data subbands that are to be processed using the channel estimate.
The output of the truncation module 840 is coupled to a threshold module 850 that performs thresholding of the channel impulse response taps based on the mode of the data subbands that are to be processed using the channel estimate. The truncation module 840 can be configured to receive a mode dependent threshold value, and can be configured to set to zero or some other substantially insignificant value those taps that do not exceed a comparison threshold determined based on the mode dependent threshold value.
In one embodiment, the threshold module 850 determines an average energy value of the channel impulse response by summing the squares of all of the tap values and dividing by the number of taps. The number of taps can be the total number of taps in the channel impulse response, or can be the number of taps in the truncated impulse response. By definition, the taps beyond the truncation length do not contribute to the channel estimate. The threshold module 850 determines a comparison threshold by receiving a fractional value, termed α in equation (16) above, and determining the product of the fractional value and the average energy value. The threshold module compares each tap energy value with the comparison threshold and zeros or otherwise makes insignificant those taps whose energy values fall below the comparison threshold.
The threshold module 850 can receive the threshold value from a second multiplexer 852 that selects one of a plurality of threshold values stored in threshold memory 854. The threshold memory 854 can be configured to store a plurality of threshold values, each of which corresponds to one or more distinct modes. One or more threshold values can represent default threshold values. The mode control module 890 controls the second multiplexer 852 to select a threshold value based at least in part on the mode of the data subbands that are to be processed using the channel estimate.
The output of the threshold module 850 is coupled to a time filter 860 that is configured to buffer a plurality of processed channel impulse response estimates and filter the present channel impulse response estimate based on the plurality of processed channel impulse response estimates. The plurality of processed channel impulse response estimates can include processed channel impulse response estimates from past OFDM symbols as well as processed channel impulse response estimates from OFDM symbols occurring after the symbol being currently processed. Thus, the time filter 860 can be configured to perform causal filtering or non-causal filtering of the channel impulse response.
The output of the time filter 860 is coupled to a phase rotator 870 that can be configured to rotate the phases of the impulse response taps such that the resultant final channel frequency response estimate correspond to the data subbands to be processed. In the OFDM system having periodic pilot and data subbands, where the subband spacing between subband sets is fixed, the channel impulse response taps can be rotated by a known value such that the resultant frequency response is coincident with the data subbands.
The output of the phase rotator 870 is coupled to an FFT module 880 that is configured to transform the channel impulse response to a final channel frequency response estimate. The FFT module 880 can be configured to have a dimension equal to the number of pilot subbands. Thus, in the example described above, the FFT module 880 can be configured to perform a 512-point FFT. The output of the FFT module 880 represents the final channel frequency response estimate that is determined based in part on the mode. The final channel frequency response is coupled t the demodulator 810 for use in demodulating the data subbands.
The receiver 800 can also be configured to concurrently process a plurality of subband sets, each of which can be configured to operate in any one of a plurality of modes. In such an embodiment, the receiver 800 can perform concurrent mode based processing on the same initial channel impulse response to concurrently generate a plurality of final channel frequency response estimates.
The portion of the receiver 800 performing mode based channel processing 895 can be duplicated multiple times to enable the receiver 800 to concurrently generate multiple final channel frequency response estimates. The number of mode based channel processing portions 895 can be equal to the total number of possible subband sets that can be allocated to data communication. Thus, for an OFDM system having Q subband sets, one of which is allocated to pilot signals, the receiver 800 can be configured with up to Q−1 channel processing portions 895 to concurrently generate up to Q−1 channel frequency response estimates.
The receiver 800 embodiment includes a particular arrangement of modules. However, many of the modules can be replaced with similar modules or functional equivalents. Additionally, the order and positions of the modules may be modified.
The transforms are described as being performed by FFT or IFFT modules. However, an FFT implementation is not required and the transform can be performed with an FFT, Discrete Fourier Transform (DFT), Hadamard transform, and the like or some other means for transforming time samples to a frequency representation. Similarly, the IFFT can be performed by an inverse Discrete transform, an inverse Hadamard transform, and the like or any suitable means for transforming a frequency domain representation to a time domain representation. Thus, the IFFT module 830 can be any means for generating a channel impulse response. Similarly, the FFT module 880 can be any means for generating the final channel frequency response estimate.
Similarly, the pilot extraction module 820 can be performed by a filter, a sampler, a decimation module, and the like, or some other means for extracting the pilot samples. The descrambler 824 can be performed by any combination of elements or apparatus configured to perform the complement of the scrambling process implemented at the transmitter. As such, the descrambler 824 can be implemented as any suitable means for descrambling the pilot signals.
The truncation module 840 can also be implemented using a variety of different modules. For example, the truncation module 840 can include a decimation module, a sampler, a memory, a buffer, a FIFO, and the like, or any other means for truncating the channel impulse response taps.
The threshold module 850 can be implemented using a variety of different modules. For example, the truncation module 850 can include a comparator, a subtractor, an accumulator with carry out, a DAC, and the like, or some other means for thresholding the channel impulse response taps.
The time filter 860 can be a FIR, IIR, Kalmann filter, analog filter, causal filter, non-causal filter, and the like, or some other means for filtering the channel impulse response. The phase rotator 870 can include a complex multiplier, a CORDIC, and the like, or some means for rotating the samples.
Additionally, the position and order of the various mode-dependent processing can be modified and one or more mode-dependent processing modules may be omitted. For example, some of the modules are shown as functioning in the time domain, but could also be implemented in the frequency domain. Additionally, the order of some of the modules may be changed. For example, the truncation and threshold modules, 840 and 850, may be re-ordered. Some receiver 800 embodiments may not perform all of the processing shown in
The process 900 begins at block 902 where the receiver samples a received OFDM symbol. The receiver proceeds to block 910 and converts the samples of the OFDM symbol to a plurality of frequency domain subbands. The receiver can be configured to perform an FFT operation on the samples to generate a frequency domain response. As described earlier, the OFDM symbol can include a plurality of pilot subbands in a set of subbands within the total number of subbands.
The receiver proceeds to block 920 and extracts the pilot subbands. In one embodiment, the receiver can be configured to extract the pilot subbands by determining which of the subbands are assigned to pilot channels and storing in memory the FFT values corresponding to those subbands. For example, in an OFDM system having Q separate subband sets, one of which is assigned to the pilot, the receiver can extract the one out of every Q FFT output values corresponding to the pilot subband and can store the value in RAM for further processing.
The receiver proceeds to block 930 to descramble each of the pilot subbands. The pilot subbands can be scrambled at the transmitter according to a predetermined algorithm, and the receiver can descramble the pilot subbands by performing the complement of the scrambling algorithm.
The descrambled frequency domain samples represent an initial channel frequency domain estimate. the receiver proceeds to block 940 and performs an IFFT operation on the initial channel frequency domain estimate to generate a channel impulse response.
The receiver can perform mode based processing on the initial channel frequency domain estimate or the channel impulse response, although time domain processing may be simpler to implement. The receiver can use the same channel impulse response to generate multiple mode-dependent final channel frequency response estimates, where the receiver concurrently supports multiple modes in the same OFDM symbol.
The receiver proceeds to block 950 and performs mode-dependent truncation of the channel impulse response. The receiver can truncate the channel impulse response to a length that is shorter than the length defined by the number of pilot subbands. The receiver can store a impulse response length, corresponding to a delay spread, in memory for each of the modes and can retrieve the impulse response length corresponding to the assigned or transmitted mode. At least two modes can have distinct impulse response lengths, such that the impulse response length varies depending on the mode.
The receiver truncates the impulse response by setting to zero those taps that are greater than the impulse response length. That is, those taps that represent the longest delays are truncated from the channel impulse response.
The receiver proceeds to block 960 and performs mode-dependent thresholding on the truncated channel impulse response. The receiver can store one or more threshold values in memory, where each threshold value corresponds to one or more modes. The receiver retrieves the associated threshold value and determines or otherwise generates a comparison threshold based at least in part on the threshold value.
The receiver compares each of the tap values from the truncated channel impulse response to the comparison threshold. If the tap value or a value generated by the tap value is equal to or greater than the comparison threshold the receiver performs no modification of that tap value. If the tap value or value generated by the tap value is less than the comparison threshold, the receiver sets that tap value to zero or some insignificant value. A value is an insignificant value if it has substantially no contribution to the channel impulse response or the corresponding channel frequency response estimate.
In one embodiment, the mode-dependent threshold value is a relative value. For example, the receiver can be configured to determine an average energy value of the truncated channel impulse response. The mode-dependent threshold value can be a fraction. The receiver can scale the average energy value with the mode-dependent threshold value to generate the comparison threshold. The receiver sets to zero the taps having a tap energy value less than the comparison threshold.
The receiver then proceeds to block 970 and performs time filtering of the channel impulse response that has been truncated and subjected to thresholding. The time filter can use channel impulse response values that span multiple symbols.
After time filtering, the receiver has generated a mode-dependent channel impulse response. The receiver can generate a final channel frequency response estimate at the subbands corresponding to the data subbands. The receiver proceeds to block 980 and phase rotates the tap values. The receiver phase rotates the tap values because the channel impulse response was generated from samples of the pilot subbands. The pilot subbands within an OFDM symbol are distinct from the data subbands, but are typically offset by a known and fixed frequency, such as a fixed number of subbands. Thus, by phase rotating the channel impulse response tap values, the receiver can produce a channel frequency response estimate that coincides with the data subbands. The receiver proceeds to block 990 and generates a final channel frequency response estimate by performing an FFT on the truncated, thresholded, time filtered, and phase rotated channel impulse response.
The channel estimation techniques described herein may be implemented by various means. For example, these techniques may be implemented in hardware, software, or a combination thereof. For a hardware implementation, the processing units used for channel estimation may be implemented within one or more application specific integrated circuits (ASICs), digital signal processors (DSPs), digital signal processing devices (DSPDs), programmable logic devices (PLDs), field programmable gate arrays (FPGAs), processors, controllers, micro-controllers, microprocessors, other electronic units designed to perform the functions described herein, or a combination thereof.
For a software implementation, the channel estimation techniques may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein. The software codes may be stored in a memory unit (e.g., memory units 732 and 772 in
The various steps or acts in a method or process may be performed in the order shown, or may be performed in another order. Additionally, one or more process or method steps may be omitted or one or more process or method steps may be added to the methods and processes. An additional step, block, or action may be added in the beginning, end, or intervening existing elements of the methods and processes.
A coupling or connection need not be a direct connection. The various modules can be coupled to one another through a direct connection, direct coupling, or through an indirect coupling where one or more intervening elements may be used to couple the respective modules.
Headings are included herein for reference and to aid in locating certain sections. These headings are not intended to limit the scope of the concepts described therein under, and these concepts may have applicability in other sections throughout the entire specification.
The previous description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the present invention. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from the spirit or scope of the invention. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
The present application claims priority to Provisional Application No. 60/657,835, entitled “CHANNEL ESTIMATION FOR A MULTI-MODE OFDM COMMUNICATION SYSTEM WITH INACTIVE SUBBANDS” filed Mar. 1, 2005, and assigned to the assignee hereof and expressly incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
60657835 | Mar 2005 | US |