The present disclosure is related to commonly-assigned co-pending U.S. patent application Ser. No. 10/820,440, filed Apr. 5, 2004, entitled “Modified Preamble Structure for IEEE 802.11a Extensions to Allow for Coexistence and Interoperability Between 802.11a Devices and Higher Data Rate, MIMO or Otherwise Extended Devices,” which disclosure is incorporated herein by reference for all purposes.
The present invention relates generally to channel estimation in communication systems and in particular to channel estimation techniques for wireless communication systems using multiple subcarriers, including systems compliant with the IEEE 802.11a standard.
In a typical wireless communication system in use today, a transmitter and a receiver communicate in accordance with a protocol such as the IEEE 802.11a standard. The standard specifies a keying scheme that generally involves grouping. Bits of data to be transmitted are grouped and each group of bits is mapped to a symbol (a particular combination of phase and amplitude) in a signaling constellation. A number of constellations (or keying schemes) are known in the art, including binary phase-shift keying (BPSK), quadrature phase-shift keying (QPSK), and quadrature amplitude modulation (QAM) constellations. The transmitter includes an encoder that transforms an input data stream into a sequence of symbols. The transmitter may also insert additional information-carrying symbols into the input data stream. For example, protocols such as IEEE 802.11a specify a “preamble” to precede transmitted data. The preamble usually includes parameter values related to various features of the signal (e.g., data rate, keying scheme, etc.) as well as a known sequence of bits or symbols (referred to herein as a “training sequence”) that the receiver can use for calibration. The symbols are modulated using an appropriate protocol (e.g., OFDM (orthogonal frequency division multiplexing) in the case of IEEE 802.11a) into a form suitable for transmission over a channel. The receiver receives the signal, demodulates it, and generates an output data stream that ideally is identical to the input data stream.
In practice, the output data stream has a non-zero bit error rate that depends on various factors. For example, channel properties such as fading and delay, as well as noise, are known to affect the received signal. Receivers in use today generally include circuitry for estimating and compensating for channel and noise effects.
In typical communication protocols, channel effects are generally estimated by measuring the receiver's response to a known sequence of input symbols that is inserted into the input data stream. For instance,
The output of the transmitter is a long training symbol at a sample rate of 64 samples/symbol. The samples are obtained by taking a 64-point IFFT (inverse Fast Fourier transform) of the long training sequence L1. As used herein, a sequence in the frequency domain is expressed with uppercase letters (e.g., L[k]), while the corresponding time sequence is expressed with lowercase letters (e.g., l[i]). The transformed samples l[i] are modulated according to the RF channel frequency, converted to analog, and transmitted.
The receiver detects the RF signal, converts it to digital (at standard 20 MHz sampling rate) and demodulates it. Thus, the receiver generates 64 samples during each repetition of the long training symbol, for a total of 128 training samples. These training samples r[i] (where i=0, 1, . . . , 127) are used to compute channel response according to various conventional algorithms. For example, one such algorithm involves averaging the corresponding samples from the two repetitions of the long training symbol:
A Fast Fourier Transform (FFT) is performed on the averaged time-domain samples
Recently, there has been interest in developing multiple input, multiple output (MIMO) wireless systems to provide increased data rates. Such systems generally include a transmitter system having a number (Mt) of transmit antennas (transmitters) communicating with a receiver system having a number (Mr) of receive antennas (receivers), where Mr and Mt may or may not be equal. In a MIMO communication system, each of the Mt transmit antennas transmits, at substantially the same time, a symbol representing a different group of bits from the input data stream. If each symbol represents B bits, the number of bits transmitted per symbol period is B*Mt. Thus, MIMO systems are considered desirable as a way to increase bandwidth of the communication system. For example, a conventional SISO system compliant with IEEE 802.11a can transmit up to 54 Mbps (megabits per second). In a MIMO system with Mt transmit antennas, the data rate can be increased to Mt*54 Mbps.
MIMO systems introduce additional complexity to the channel estimation that the receiver needs to perform. Specifically, each receive antenna receives a signal that is a combination of signals from the transmit antennas, modified by the channel properties and noise. In effect, there is a channel from each transmitter to each receiver, and separate channel estimates must be made for each such channel. Thus, the per-carrier channel estimate h[i] becomes an Mr×Mt matrix [i].
Various techniques for modifying the IEEE 802.11a preamble for use in MIMO systems have been suggested. These techniques generally involve changing or repeating the preamble to allow separate calibration for each transmit antenna. Some of these techniques, such as having each transmit antenna transmit the training sequence while other antennas transmit nothing, can lengthen the training period and reduce the data rate.
It would be desirable to provide improved channel estimation techniques for use in MIMO-extended 802.11a and other wireless communication systems.
Embodiments of the present invention provide channel estimation techniques that can be used in legacy 802.11a and extended systems. In some embodiments, channel impulse response is adaptively truncated in the time domain during channel estimation, based on channel power and noise considerations. In other embodiments, channel response tracking techniques are implemented to correct for variations in channel response over the transmission time of a packet.
According to one aspect of the present invention, a method is provided for determining channel estimates at a receiver for a wireless communication system using orthogonal frequency division multiplexing (OFDM) over a plurality of OFDM subcarriers. Training signals are received from one or more receive antennas. An estimated channel impulse response is computed from the received training signals by reference to a training sequence. The estimated channel impulse response is truncated in the time domain to improve the signal-to-noise ratio of the channel estimates. In some embodiments, adaptively truncating the estimated channel impulse response includes computing a cutoff time that maximizes a sum of channel power and signal-to-noise ratio; truncating the time domain channel impulse response estimate at the cutoff time; and transforming the truncated time domain channel impulse response estimate to a frequency domain channel impulse response estimate.
According to another aspect of the present invention, a method is provided for channel estimation for a receiver of a multiple input, multiple output (MIMO) communication system wherein signals are transmitted using orthogonal frequency division multiplexing (OFDM) over a plurality of OFDM subcarriers. At each of a plurality of receive antennas, signals are received from a plurality of transmit antennas, wherein the signal from each transmit antenna includes a different subset of the plurality of OFDM subcarriers. The received signals at each receive antenna are transformed to a plurality of impulse coefficients for that receive antenna, each impulse coefficient corresponding to a different one of the OFDM subcarriers. For each of the receive antennas, a channel impulse response is computed for one of the transmit antennas using the impulse coefficients for the subset of the OFDM subcarriers transmitted by the one of the transmit antennas. In some embodiments, computing a channel impulse response for one of the transmit antennas includes adaptively truncating a time domain channel impulse response estimate to improve the signal-to-noise ratio of the channel estimates.
According to yet another aspect of the present invention, a method is provided for tracking channel variations during receipt of a packet using one or more receive antennas. An initial channel estimate is determined from training data included in the packet. A received symbol in the packet is identified. An input symbol value is estimated using the received symbol value and the initial channel estimate. A per-symbol channel estimate is derived from the received symbol value and the estimated input symbol value. The initial channel estimate is updated using the per-symbol channel estimate.
The following detailed description together with the accompanying drawings will provide a better understanding of the nature and advantages of the present invention.
Embodiments of the present invention provide improved channel estimation techniques that can be implemented in conventional (“legacy”) IEEE 802.11a communication systems as well as in various extended rate 802.11a-based systems and other wireless communication systems using OFDM.
System Overview
Receiver system 304 includes a demodulator 332 for demodulating a signal received via a number (Mr) of receive antennas 330, a channel estimation block 334 that determines channel effects from the training data, a decoder 336, and a channel update block 338.
Communication system 300 is advantageously implemented as an OFDM (orthogonal frequency division multiplexing) system, in which signals are split into several narrowband channels at different subcarrier frequencies selected to minimize interference between the channels. In some embodiments, communication system 300 is operable in various modes, one of which is compliant with the IEEE 802.11a standard entitled “Part 11: Wireless LAN Medium Access Control (MAC) and Physical Layer (PHY) specifications, High-speed Physical Layer in the 5 GHz Band” incorporated herein by reference. In other modes, system 300 may be compliant with various extensions of the IEEE 802.11a standard, such as extensions described in above-referenced application Ser. No. 10/820,440.
As shown in
After mapping, the symbols are provided to packet formation block 314, which groups the symbols into packets for transmission. Packet formation block 314 may also add additional symbols into the data stream, such as a conventional IEEE 802.11a preamble as illustrated in
Packet formation block 314 provides groups of symbols to IFFT module 316, which uses the group of symbols to modulate a group of OFDM subcarriers. In general, if a group of symbols D[k], k=0, 1, . . . , 63 is provided, IFFT module 316 generates 64 time-domain samples d[i]:
where j=√{square root over (−1)}.
In an IEEE 802.11a-compliant embodiment of systems 300, the DC subcarrier and 11 subcarriers near the edges of the 20 MHz channel are not used for data transmission. In addition, four of the remaining 52 subcarriers are used to transmit pilot tones. As is known in the art, packet formation block 314 may insert appropriate complex values at unused or pilot subcarrier locations in each group of symbols D[k] to comply with these aspects of the standard. In other embodiments, any or all of the subcarriers k may be used to transmit data, thereby increasing the data rate. In still other embodiments, even and odd subcarriers (or other groupings of subcarriers) may be transformed separately for transmission via different transmit antennas 320.
Modulator 318 uses the sample values provided by IFFT block 316 to modulate an RF carrier wave and delivers the resulting signal to the Mt transmit antennas (transmitters) 320 for transmission. In some embodiments, each transmit antenna 320 transmits different data in parallel, possibly with a cyclic shift in the data from different antennas. In other embodiments, each antenna transmits a full set of subcarriers in a different RF channel band.
At receiver system 304, the transmitted signal is received, and the reverse of the transmitter process occurs to reconstruct the input data stream. Thus, demodulator 332 receives the signals via Mr receive antennas 330 (receivers), removes the RF modulation, and provides a sequence of samples to the remaining components. In one embodiment, groups of samples are provided as an Mr-component vector r[i] (with complex components) representing the signal sample from each receive antenna 330 at a given time. Each component of r[i] is a linear combination of signals from all of the Mt transmitters, with each signal being affected by (generally different) channel properties.
Channel estimation block 334 is configured to detect a sample stream r[i] corresponding to the long training sequence and to use the detected training samples to generate channel estimates. Recognition of the training sequence may be accomplished using a variety of techniques, including mode-sensing techniques described in above-referenced application Ser. No. 10/820,440. The channel estimates are advantageously provided as a set of MrMt matrices H[k] with complex valued components that represent the channel effect for a particular transmit-receive pair for a given subcarrier k. Channel estimation block 334 advantageously implements an improved algorithm for generating channel-estimate matrices H[k], such as any of the algorithms described below. In some embodiments, channel estimation block 334 may also include additional components adapted to estimate other error corrections from the training data, e.g., clock and carrier frequency offsets, noise power, and the like. Such aspects of error correction are not critical to the present invention and a detailed description is omitted.
Symbol decoder block 336 applies the channel estimates (as well as any other corrections) to the samples r[i] and generates a reconstructed symbol stream {circumflex over (x)} that ideally corresponds to the sequence of symbols provided to IFFT block 316. This symbol stream is provided to bit stream block 340, which reverses the keying, interleaving, and encoding processes of encoder block 312 to generate an output bit stream. Symbol decoder block 336 and bit stream block 340 may be implemented using a variety of techniques, and a detailed description is omitted as not being critical to understanding the present invention.
In some embodiments, the channel estimates , the decoded symbols {circumflex over (x)}, and the received samples r are provided to a channel update module 338. Channel update module 338 uses the received samples r and the decoded symbols {circumflex over (x)} to detect changes in the channel properties that may occur during transmission of a packet. Channel properties may be affected by various environmental changes, such as motion of a mobile transmitter system 302 and/or receiver system 304, operation of other devices in the area, and so on. Channel estimation block 334 can be expected to update the channel estimates to reflect such changes when the next training sequence is received, but in this embodiment, channel estimation block 334 does not detect changes that may occur while the data portion of a packet is being transmitted. Thus, channel update module 338 advantageously employs adaptive feedback mechanisms (described further below) to compensate for motion or other environmental changes.
It is to be understood that the MIMO communication system described herein is illustrative and that variations and modifications are possible. Any number of transmit antennas Mt and any number of receive antennas Mr may be provided, and it is not required that Mt and Mr be equal. In addition, some or all components may be replaced with components having a single transmit antenna and/or a single receive antenna. The design of various system components, as well as methods used for forward error correction, interleaving, and modulation can be varied. The components described herein may be implemented using hardware, software, or any combination of hardware and/or software elements.
Preamble Generation
As described above, packet formation block 314 advantageously prepends a preamble to each transmitted packet. In one embodiment, a conventional IEEE 802.11a preamble may be used. In other embodiments, a preamble suitable for extended-rate 802.11a communication systems may be used. For example, in a MIMO implementation with two transmit antennas (transmitters), each transmitter may transmit a conventional 802.11a preamble while the other transmits nothing. Another option is for each transmitter to transmit a subset of the subcarriers (e.g., in a two-transmitter system, one transmitter might transmit even subcarriers while the other transmits odd subcarriers).
Another option, described in above-referenced application Ser. No. 10/820,440, is to apply a cyclic delay shift on the long training symbol and Signal field IFFT outputs prior to applying the guard time extension. For example, assume L[k] and D[k] are the 64 subcarrier values for the long training symbol and Signal field symbol, respectively. For a conventional 802.11a single transmitter transmission, the time samples for the long training symbol are derived by taking the 64-point IFFT of L[k] to obtain l[i] and transmitting the samples of l[i]. Thus, with the guard time, the long training symbol and guard time are constructed as {l[33:64] l[1:64] l[1:64]}, i.e., the IFFT output is repeated twice and the last 32 samples are prepended to form the long training guard interval. As with the conventional timing, the long training guard interval (32 samples) is twice as long as the guard interval for 802.11a data symbols (16 samples). The signal field is formed by {d[49:64] d[1:64]}, where d[1:64] are the 64 samples of the IFFT of D[k].
In the case of a two transmitter MIMO device, the first transmitter would transmit the long training symbol and signal field as in conventional 802.11a. The second transmitter would apply a cyclic shift such that instead of the IFFT output l[1:64], it uses the cyclically shifted samples ls={l[33:64] l[1:32]} to construct the long training symbol samples as {ls[33:64] ls[1:64] ls[1:64]}. For the signal field, the second transmitter uses the shifted samples ds={d[33:64] d[1:32]} to construct the signal field as {ds[49:64] ds[1:64]}.
In a legacy 802.11a packet, one 3.2 microsecond repetition of the long training symbol L is expressed in the time domain as the IFFT of L1[k], where L1[k] contains 64 subcarrier values, of which 52 are non-zero (as shown in
In an extended mode long training sequence, L1 [k] may be modified. For example, a modified L[k] can contain more than 52 non-zero subcarriers. Examples of suitable long training sequences with additional non-zero subcarriers are shown as sequences L2 and L3 in
Second, in the case of MIMO transmission, l[i] can have a cyclic shift that may be different for each transmitter m. The shifted signal lm[i] can be derived from l[i] as lm[i]=l[(i+64−δm)%64], where “%” denotes the modulo operator and δm is the cyclic delay of transmitter m in 20 MHz samples. This expression assumes a 20 MHz sampling rate, such that there are 64 samples in a 3.2 microsecond interval. An alternative method of generating the cyclic shift is to apply a phase ramp rotation to all subcarrier values of L(k) prior to calculating the IFFT, e.g.:
A MIMO transmitter system can have two or more transmit antennas (or antenna arrays, as the case may be). For a MIMO system with two transmit antennas and two different transmit data streams, preferred values for the cyclic delay values δm are 0 and 32 samples, respectively. This corresponds to a cyclic delay of 1.6 microseconds between the two transmitters. For three transmitters, δm can be 0, 22, and 43 samples, respectively. For four transmitters, δm can be 0, 16, 32, and 48 samples, respectively.
Overview of Channel Estimation in a MIMO System
At the receiver side, the channel estimates for each transmitter signal can be estimated by a process such as process 500 shown in
In one embodiment of a MIMO transmission, these 64 samples contain the cyclic shifted impulse responses for all Mt transmitters. With that, the receiver can isolate the impulse responses for each MIMO transmitter (step 505). For MIMO with two transmit streams, this can be done by separating the first 32 samples and last 32 samples. For four transmit streams, groups of 16 samples can be extracted.
From the extracted impulse responses per transmitter, channel estimates can be derived (step 506) for all subcarriers by taking a 64-point FFT of each impulse response, where zero values are appended to the sample values to provide 64 input values. Where the receiver system has multiple receive antennas (or antenna arrays), process 500 may be performed for each receive antenna, resulting in a complete matrix of channel estimates.
Channel Estimation in a SIMO System
Some extended rate systems are single input, multiple output (SIMO) systems, in which one transmit antenna sends data to a number of receive antennas. Channel estimates are generated for each receive antenna. In some embodiments, channel impulse response time is generally shorter than the symbol period. For example, in IEEE 802.11a systems, the symbol period is 4 μs, while the channel impulse response time might be much shorter. Channel estimation block 334 can make use of this fact to adaptively truncate the impulse response, thereby improving the signal-to-noise ratio of the channel estimates.
At step 602, samples for the long training symbol are received. In an 802.11a-compliant system, samples are received at 20 MHz, and each sample is provided as a complex number representing amplitude and phase. Since the symbol is transmitted twice, with a duration of 3.2 μs each time, 128 samples rn[i] are received for each receive antenna n (n=0, . . . , Mr−1).
At step 604, corresponding samples from the first and second transmission of the long training symbol are averaged:
Here, τ is an estimated starting sample for the channel estimation, which may be, e.g., about 16 to 32 samples after the start of the long training symbol.
At step 606, a 64-point FFT of s[i] is computed to provide 64 subcarrier coefficients Sn[k], k=0, 1, . . . , 63:
At step 608, the subcarrier coefficients S[k] are multiplied by the respective long training sequence values L[k] (for the long training sequence in use for a given embodiment, e.g., conventional sequence L1 of
Sn0[k]=L[k]Sn[k], k=0, . . . , 63. (Eq. 7)
Because L[0] is zero, the impulse coefficient at DC is “missing.” At step 610, an impulse coefficient at DC is interpolated from the other impulse coefficients:
At step 612, a 64-point IFFT is computed for the spectral coefficients Sn0[k], resulting in a channel impulse response estimate:
To increase the signal-to-noise ratio (SNR) of the channel estimates, the impulse response of Eq. 9 is advantageously cut off (truncated) in time at a point that optimizes a tradeoff between channel power and noise. More specifically, in this embodiment, at step 613, a channel power function P[t] is defined for a time index t=0, . . . , 63 as:
where mod is the modulo operator. This function approximates the channel power received during a relatively short time interval beginning at time t (measured in samples). In other embodiments, the sum over 8 samples may be replaced with a sum over a different number of samples, and the modulo operator may be replaced with a cutoff at i+t=64.
At step 614, a channel noise power estimate σ2 that represents the amount of noise included in the channel power loss function Ph[t] is generated. A variety of techniques can be used to generate this estimate; in one embodiment,
Eq. 11 is a reliable noise estimate to the extent that Ph[t] reflects a channel impulse response superimposed on a substantially constant background of noise, and to the extent that at some time index t, the channel response is dominated by the noise. It will be appreciated that other estimates of channel noise may also be used.
At step 615, a cutoff time tc is computed as:
where Ph[t] is given by Eq. 10, σ2 is the channel noise power estimate from step 614, and “arg min” indicates that tc is the value of t for which the sum is minimized. A minimum cutoff time t0 is advantageously predefined based on a minimum impulse response length determined by all filters at both transmit and receive ends of the channel. In one embodiment, t0=12. More generally, a variety of methods for determining a minimum impulse response length are known in the art and may be used to define to.
It should be noted that Eq. 12 represents a tradeoff between keeping more or fewer of the time samples for the channel impulse response. As fewer samples are kept, the noise is reduced but more of the useful channel response information is lost. Other algorithms for evaluating this tradeoff to select a cutoff time may be substituted for that described herein.
At step 616, the 64-point FFT of the truncated impulse responses is computed as:
where:
is the truncated channel impulse response estimate.
The FFT outputs of Eq. 13 are channel estimates Ĥ0[k] that may be used for channel correction of received data signals. Various channel correction techniques are known in the art and may be employed in conjunction with channel estimation process 600.
More specifically, steps 902, 904, 906, and 908 correspond to steps 602, 604, 606, and 608 of process 600 described above and result in impulse coefficients Sn0[k] in accordance with Eqs. 5-7 given above. At step 910, a 64-point IFFT of the impulse coefficients is computed to obtain channel impulse response estimates as:
It should be noted that Eq. 15 differs from Eq. 9 above in that the DC coefficient S00[k] has not been interpolated to a nonzero value. Instead, in process 900, the DC offset is corrected in the time domain. Specifically, at step 912, the DC offset for each receiver is estimated by averaging the tail of the channel impulse response of that receiver over 16 samples:
where the sample window (40 to 55 in Eq. 16) may be optimized for a particular embodiment as desired. The sample window is advantageously chosen to be near the end of the sampling interval but may be shifted away from the end somewhat, e.g., to avoid effects of any timing inaccuracy in choosing the starting sample. In addition, the size of the sample window may be varied as desired.
At step 914, the channel impulse response estimates ĥn[i] are corrected for the DC offset:
ĥn0[i]=ĥn[i]−{circumflex over (x)}n. (Eq. 17)
Next, the timing estimate τ that was used to select the sample window (see Eq. 5) is refined based on the channel impulse response. At step 916, a channel power function is computed as:
similarly to step 613 of process 600. At step 918, the timing correction τ′ is estimated as:
that is, τ′ is the value of t for which Ph[t] is maximized. This timing correction is used to adjust the initial sample time from τ to τ′. Accordingly, at step 920, the impulse responses and the power estimate are cyclically shifted by −τ′ samples:
ĥnτ[i]=ĥn0[(i+τ′)mod 64], (Eq. 20)
and
Phτ[i]=Ph[(i+τ′)mod 64]. (Eq. 21)
Next, at step 922, a cutoff time tc for the impulse response is determined. The cutoff time can be determined according to Eq. 12 above. In an alternative embodiment, the noise power estimate is obtained as:
and the cutoff time tc is given by:
that is, the smallest time index i for which Phτ[i] is less than twice the noise power estimate. The minimum cutoff time (8 in Eq. 23) is selected to prevent unrealistically small cutoff values from being used in channels with large noise or interference levels. As in process 600, this minimum time may be selected based on the known filtering properties of the transmit and/or receive antennas.
At step 924, the time-corrected channel impulse responses ĥnτ(i) are truncated. In some embodiments (e.g., where the transmitter is a legacy transmitter or other type of transmitter that does not use all subcarriers), abrupt truncation in the time domain can give rise to Gibbs' phenomena in the frequency domain. To mitigate this effect, the truncation may be done using a windowing function w(i) defined as:
The channel impulse response is then given by:
ĥnF[i]=hnτ[i]w(i). (Eq. 25)
It will be appreciated that other windowing functions may be substituted. For instance, in embodiments where all subcarriers are used, the windowing function w(i)=1 for all i may be used.
At step 926, final channel estimates (in the frequency domain) are computed as a 64-point FFT of the truncated channel impulse responses of Eq. 25:
In some embodiments, at step 928, the channel estimates for subcarriers near the channel edges may be replaced by untruncated channel estimates. For example:
may be used.
It will be appreciated that the channel estimation processes described herein are illustrative and that variations and modifications are possible. Steps described as sequential may be executed in parallel, order of steps may be varied, and steps may be modified or combined. Process 600 or 900 may also be implemented in a conventional (legacy) 802.11a system including single receiver systems. In addition, various steps or equations of process 600 may be combined with or substituted for corresponding steps or equations of process 900, or vice versa. For example, the windowing function of Eq. 24 may be used to truncate channel estimates in a process generally conforming to process 600. These processes may also be extended to MIMO systems, e.g., where different transmit antennas transmit the training sequence at different times.
Any desired training sequence L[k] may be used, including L2 or L3 shown in
Channel Estimates for MIMO OFDM Systems
For MIMO systems with multiple independent transmitters, a channel estimate is advantageously computed for each transmitter-receiver pair. For example, in an embodiment of system 300 (
More specifically, at step 702 (which may be generally similar to step 602 of process 600 described above), samples for the long training symbol are received for each receive antenna. At step 704, for each receive antenna n, samples from the first and second half of the long training period are averaged, similarly to step 604:
At step 706, a 64-point FFT of sn is computed for each receive antenna:
At step 708, the 64 subcarrier coefficients Sn[k] for each receive antenna n are split into two subsets Snm (where m=0, 1 denotes the transmit antenna), each including 32 coefficients In one embodiment, the even subcarriers (k=2p for integer p) are associated with transmit antenna 0 and odd subcarriers (k=2p+1 for integer p) are associated with transmit antenna 1.
At step 710, the subcarrier coefficients are multiplied with the known long training sequence values L[k] to determine impulse coefficients Snm0[p]:
for p=0, 1, . . . , 31. In embodiments where L[0] is zero, Sn00[0] becomes a “missing” impulse coefficient. At step 712, the missing impulse coefficient is supplied by interpolation, using:
Thus, 32 impulse coefficients are available for each transmit-receive pair.
At step 714, a 32-point IFFT of each set of impulse coefficients Snm0[p] is computed according to:
This provides a channel impulse response estimate for each receiver-transmitter pair nm.
To increase the SNR of the channel estimates, the impulse responses are advantageously cut off (truncated) in time at a point that optimizes a tradeoff between channel power and noise. Specifically, at step 715, a channel power loss function Ph[t] is defined for a time index t=0, . . . , 63 as:
where Mr is the number of receive antennas and Mt is the number of transmit antennas. This function approximates the channel power received (from all transmitters) during a relatively short time interval beginning at time t (measured in samples). In other embodiments, the sum over 8 samples may be replaced with a sum over a different number of samples, and the modulo operator may be replaced with a cutoff at i+t=32.
At step 716, similarly to step 614, a channel noise power estimate σ2 that represents the amount of noise included in the channel power function Ph[t] is generated. A variety of techniques can be used to generate this estimate; in one embodiment,
Like Eq. 11 above, Eq. 34 is a reliable noise estimate to the extent that Ph[t] reflects a channel impulse response superimposed on a substantially constant background of noise, and to the extent that at some time index t, the channel response is dominated by the noise. Other estimates of channel noise may also be used.
At step 717, a cutoff time tc is computed as:
where Ph[t] is given by Eq. 33 and σ2 is the channel noise power estimate from step 716. As in process 600, a minimum cutoff time t0 is advantageously predefined based on a minimum impulse response length determined by all filters at both transmit and receive ends of the channel. In one embodiment, t0=12. More generally, a variety of methods for determining a minimum impulse response length are known in the art and may be used to define to.
At step 718, zeros are appended to the truncated channel impulse response to provide a total of 64 samples, and the (64-point) FFT is computed as:
where
The FFT outputs of Eq. 36 are the channel estimates Ĥnm0[k] for transmitter m, receiver n, and subcarrier k; these channel estimates may be used for channel correction of received data signals. Various channel correction techniques for MIMO systems are known in the art and may be employed in conjunction with channel estimation process 700.
It should be noted that process 700 results in channel estimates for all 64 subcarriers k for each receive-transmit pair nm. Thus, during transmission of the data portion of a packet, each transmit antennas may use all of the subcarriers, or any subset thereof, including overlapping subsets, and appropriate channel corrections may be applied.
More specifically, steps 1002, 1004, 1006, 1008 and 1010 correspond to steps 702, 704, 706, 708 and 710 of process 700 described above and result in impulse coefficients Snm0[k] in accordance with Eqs. 15-17 given above. At step 1012, a 32-point IFFT of the impulse coefficients for each transmit-receive pair is computed to obtain channel impulse response estimates as:
Alternatively, a 64-point IFFT may be used; in that case, Snm0[k] is set to zero for odd subcarriers for transmit antenna m=0 and for even subcarriers for transmit antenna m=1.
It should be noted that Eq. 38 differs from Eq. 32 above in that the DC coefficient Sn00[k] has not been interpolated to a nonzero value. Instead, in process 1000, the DC offset is corrected in the time domain. Specifically, at step 1014, the DC offset for each receiver is estimated by averaging the tail of the channel impulse response of that receiver over 4 samples:
where the sample window (25 to 28 in Eq. 39) may be optimized for a particular embodiment as desired. The sample window is advantageously chosen to be near the end of the sampling interval but may be shifted away from the end somewhat, e.g., to avoid effects of any timing inaccuracy in choosing the starting sample. In addition, the size of the sample window may be varied as desired.
At step 1016, the channel impulse response estimates ĥn0[i] are corrected for the DC offset:
ĥn00[i]=ĥn0[i]−{circumflex over (x)}n0 (Eq. 40)
It should be noted that DC offset correction is applied only for a transmit antenna whose spectral coefficients include a DC term, in this case transmit antenna m=0. Thus, in this example, ĥn10[i]=ĥn1[i].
Next, the timing estimate τ that was used to select the sample window (see Eq. 28) is refined based on the channel impulse response. At step 1018, a channel power function is computed as:
similarly to Eq. 33 above. At step 1020, the timing correction τ′ is estimated as:
similarly to Eq. 19 above. This timing correction is used to adjust the initial sample time from τ to τ′. Accordingly, at step 1022, the impulse responses and the power estimate are cyclically shifted by −τ′ samples:
ĥnmτ[i]=ĥnm0[(i+τ′)mod 32], (Eq. 43)
and
Phτ[i]=Ph[(i+τ′)mod 32]. (Eq. 44)
Next, at step 1024, a cutoff time tc is determined. The cutoff time can be determined according to Eq. 34 above. In an alternative embodiment, the noise power estimate is obtained as:
and the cutoff time tc is given by:
that is, the smallest time index i for which Phτ[i] is less than twice the noise power estimate. The minimum cutoff time (8 in Eq. 46) is selected to prevent unrealistically small cutoff values from being used in channels with large noise or interference levels. As in process 700, this minimum time may be selected based on the known filtering properties of the transmit and/or receive antennas.
At step 1026, the final channel estimates (in the frequency domain) are computed as a 64-point FFT of the truncated channel impulse responses, after appending 32 zeroes:
where
In this embodiment, all subcarriers are used to transmit data (including training data of a sequence such as L3 or L2 of
In some embodiments, the signal field of the packet (see, e.g.,
Ĥn[k]=Ĥn00[k]+ejδkθĤn10[k], (Eq. 49)
where θ=(2π/64), k is the OFDM subcarrier index, and δ is the delay (in samples) applied to the OFDM symbol transmitted by the second (m=1) transmitter to achieve transmitter diversity.
It will be appreciated that processes 700 and 1000 are illustrative and that variations and modifications are possible. Steps described as sequential may be executed in parallel, order of steps may be varied, and steps may be modified or combined. The computations may be performed sequentially or in parallel for each receive antenna n. Any desired training sequence may be used, including sequence L2 or L3 shown in
Process 700 or 1000 may also be adapted to a larger number of transmit antennas m by dividing the 64 available subcarriers (or other number of subcarriers) as equally as possible among the transmit antennas during the training period. It will be appreciated that for a sufficiently large number Mt of transmit antennas, 64/Mt subcarriers might not provide enough information for a reliable channel estimation. In such embodiments, the training period may be extended by repeating the long training symbol (e.g., using different subsets of the transmit antennas for each repetition), or different antennas may transmit uncorrelated training sequences using the same subcarriers, or other techniques may be employed to improve reliability of the channel estimates.
Channel Variation Tracking
In some embodiments, channel tracking may be implemented to improve the robustness to channel variations during a packet caused by motion of the user or other changes in the environment as mentioned above. For example, as mentioned above, channel update module 338 of receiver system 304 (
At step 802, during the training period, an initial channel estimate Ĥ0[k] is computed for each subcarrier k. Step 802 may include executing process 600 or 700 described above, or another channel estimation process.
At step 804, during receipt of the data portion of the packet, a sequence of samples r[i] corresponding to a symbol period is received. At step 806, this sequence of samples r[i] is used to estimate a transmitted symbol {circumflex over (X)}[k] for each subcarrier k. Step 806 may be implemented using conventional decoding technologies and advantageously includes correcting for channel effects using initial channel estimate Ĥ0[k].
At step 808, the samples r[i] for the symbol period are transformed to a set of received subcarrier coefficients R[k]; these coefficients will generally reflect the transmitted symbols as modified by channel effects. At step 810, a “current” channel estimate Ĥe[k] is computed as:
Ĥe[k]=R[k]{circumflex over (X)}−1[k]. (Eq. 50)
At step 812, the current channel estimate can be used to update the initial channel estimate Ĥ0[k], thereby providing an updated channel estimate Ĥ′[k]. Various filters may be used to generate the updated channel estimate. For example, a first order filter:
Ĥ′[k]=(1−α)Ĥ0[k]+αĤe[k], 0≦α≦1 (Eq. 51)
may be applied. Since Ĥ0[k] and Ĥe[k] will be similar to the extent that the channel properties have not changed since the training period, Eq. 51 may change the channel estimate only slightly (or not at all). The averaging constant α may be varied as desired; in one embodiment a value of α=0.125 is advantageously used. More generally, the value of α may be optimized for a particular embodiment based on tradeoffs between sensitivity to actual changes in the channel properties and undesired responsiveness to transient fluctuations.
In other embodiments, updated channel estimate Ĥ′[k] may be computed using other finite or infinite impulse response filters, e.g., filters that average Ĥe[k] over a number of symbols to further reduce sensitivity to transient fluctuations in channel response.
At step 814, the updated channel estimate Ĥ′[k] is used to decode subsequent packets. Steps 804 to 812 may be performed again using updated channel estimate Ĥ′[k] in place of initial channel estimate Ĥ0[k], thereby allowing the receiver to respond to further changes in channel properties.
For systems with multiple receive antennas, process 800 may be performed (sequentially or in parallel) for each receive antenna.
For extended rate systems implemented using MIMO, where different data symbols are transmitted simultaneously from different transmit antennas, the above technique can be used for every group of Mt symbols, where Mt is the number of transmit antennas. In one such embodiment, 0[k] is an Mr×Mt matrix with the channel coefficients for subcarrier k, [k] is an Mt×Mr matrix where each of the Mr columns contains the Mt estimated symbols (one per transmit antenna) transmitted for subcarrier k, and [k] is a vector with Mr complex values for all receivers for subcarrier k. Corresponding matrix operations can be substituted for the scalar operations in Eqs. 50 and 51.
While the invention has been described with respect to specific embodiments, one skilled in the art will recognize that numerous modifications are possible. For instance, the techniques described herein may be adapted to various OFDM communication systems and protocols and are not limited to any particular number or spacing of subcarriers. For example, FFTs and IFFTs with different numbers of points could be used, or time/frequency transform algorithms other than FFT, such as discrete cosine transforms or the like, could be substituted. The techniques may be implemented for use in systems with any number of transmit antennas and any number of receive antennas, some or all of which might be mobile. Devices implementing the channel estimation techniques described herein may also be configured for use in legacy 802.11a networks as well as extended rate networks and may be components of a “mixed” network in which legacy and extended rate devices coexist or interoperate.
The various functional blocks described herein may be implemented using hardware (e.g., suitable integrated circuit components), software (e.g., program instructions) executing on appropriate processing devices, or any combination thereof. In some embodiments, a single device may be implemented as a transceiver including both transmitter system and receiver system elements. In such devices, hardware and/or software components may be configured to perform both transmit and receive functions.
Thus, although the invention has been described with respect to specific embodiments, it will be appreciated that the invention is intended to cover all modifications and equivalents within the scope of the following claims.
This application claims the benefit of U.S. Provisional Application No. 60/462,286, filed Apr. 10, 2003, entitled “Channel Estimation for IEEE 802.11a and Extended Rates,” which disclosure is incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
20020065047 | Moose | May 2002 | A1 |
20020111142 | Klimovitch | Aug 2002 | A1 |
20030076777 | Stuber et al. | Apr 2003 | A1 |
20040105512 | Priotti | Jun 2004 | A1 |
20040120428 | Maltsev et al. | Jun 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
60462286 | Apr 2003 | US |