In an embodiment, a multi-carrier signal (e.g., an orthogonal-frequency-division-multiplexed (OFDM) signal) is received over a channel. Indicators of interference and the channel response at a carrier frequency of the signal are determined and compared. If the indicator of interference has a particular relationship to the indicator of the channel response, then a data value transmitted at the carrier frequency is recovered from a data value received at the carrier frequency according to a particular data-recovery algorithm.
Because the particular data-recovery algorithm may be faster than a conventional data-recovery algorithm, recovering one or more data values with the particular algorithm may increase the speed at which data is recovered from a multicarrier signal as compared to using a conventional data-recovery algorithm exclusively.
The transmitter of the base 10 modulates each of at least some of the N subcarriers with a respective data value (hereinafter a data subsymbol) for a time period that may be called a symbol period—the transmitter may not use one or more of the subcarriers due to, for example, excessive interference at the frequencies of these subcarriers. Examples of such modulation schemes include binary phase-shift keying (BPSK), quadrature phase-shift keying (QPSK), and quadrature amplitude modulation (QAM); the latter two schemes providing data values that each have multiple bits.
The frequency spacing fs between adjacent ones of the subcarriers is conventionally selected to minimize inter-carrier interference (ICI), which is a phenomenon that occurs if energy from one subcarrier “spills over” to the frequency slot of another subcarrier at the receiver of the client 12. At the transmitter of the base 10, each of the active ones of the N subcarriers has a frequency fk represented by a respective one of the solid lines. But at the receiver of the client 12, the respective frequency fk of each subcarrier may be effectively shifted within a respective frequency slot 20 indicated by the dashed lines. For example, at the receiver of the client 12, the frequency fN-a of the subcarrier N-a may be shifted to another location within the frequency slot 20N-a. Causes for this frequency shifting may include, for example, the existence of multiple transmission paths L and channel conditions (e.g., humidity, temperature) that may effectively shift the respective phase and attenuate the respective amplitude of each modulated subcarrier.
To allow the receiver of the client 12 to recover the data subsymbols in the presence of the ICI, the transmitter of the base 10 transmits a training symbol—a “training symbol” is the combination of all the training subsymbols transmitted during a training-symbol period—shortly before transmitting a data symbol—a “data symbol” is the combination of all of the data subsymbols transmitted during a data-symbol period. That is, the transmitter of the base 10 transmits the training symbol during a first symbol period, and transmits the data symbol during a second, subsequent symbol period. Because the receiver of the client 12 “knows” what the transmitted training symbol is, it characterizes the channel 14 by comparing the received training symbol with the transmitted training symbol. For example, the receiver may characterize the channel 14 by conventionally generating an N×N matrix Ĥ of estimated complex coefficients that respectively represent the effective frequency response (e.g., the imparted amplitude attenuation and phase shift) of the channel at each of the subcarrier frequencies. As discussed in more detail below, the receiver may then use Ĥ to recover transmitted data symbols from respective received data symbols.
At the base 10, the OFDM signal may be similar to the OFDM signal of
But at the receiving client 12, the frequency fk of a subcarrier k may be shifted by one or more times fs as indicated by the frequency slot 22N-(a-4) of the subcarrier N-(a-4) (only one frequency slot shown in
The frequency shifts of the received OFDM subcarriers of
According to the Doppler Effect, the frequency of a signal at a receiver is different from the frequency of the signal at a transmitter if the receiver and transmitter are moving relative to one another. If the receiver and transmitter are moving away from one another, then the frequency of the signal at the receiver is typically lower than the frequency of the signal at the transmitter. Conversely, if the receiver and transmitter are moving toward one another, then the frequency of the signal at the receiver is typically higher than the frequency of the signal at the transmitter. For example, a person (receiver) who is listening to the whistle of an approaching train (transmitter) may experience this phenomenon. While the train is moving toward the person, the person perceives the whistle as having a pitch that is higher than the pitch that one on the train would perceive the whistle as having. But after the train passes the person, and is thus moving away from him, the person perceives the whistle as having a pitch lower than the pitch that one on the train would perceive the whistle as having.
Consequently, the subcarrier frequencies of the OFDM signal of
A measure of the influence that the Doppler Effect has on a single transmitted tone (e.g., an unmodulated subcarrier signal) is the “Doppler Spread”, which is the bandwidth that the tone may occupy at the receiver due to the Doppler Effect. For example, suppose the frequency of the tone is 1,000 Hz at the transmitter, but at the receiver, due to the non-zero velocity of the receiver and transmitter relative to one another, the received tone may have a frequency anywhere from 980 Hz to 1,020 Hz depending on the instantaneous velocity. Therefore, the Doppler Spread=1020 Hz−980 Hz=40 Hz. That is, the Doppler Spread is (40 Hz)/(1000 Hz)=4% of the frequency of the transmitted tone—although expressed here in Hz and as a percentage of the transmitted frequency, the Doppler Spread may be expressed in other quantities as described below.
For mobile OFDM devices, one may characterize the ICI caused by the Doppler Spread of a subcarrier in terms of the highest number of adjacent subcarriers with which the subcarrier may interfere. For example, the total Doppler induced ICI caused by the 50th subcarrier is greater if energy from this subcarrier spills over to the 48th, 49th, 51St, and 52nd subcarriers, and is less if energy from this subcarrier spills over to only the 49th and 51st subcarriers. In actuality, because the Doppler Spread of a subcarrier may cause the subcarrier to spill over energy into many or all of the other N subcarrier slots to some degree, one may set a subcarrier Doppler Spread interference threshold below which another subcarrier is deemed to be unaffected by the Doppler Spread of the subcarrier in question. Therefore, for mobile OFDM devices, the extent of Doppler induced ICI caused by a subcarrier k may be defined in terms of the number of adjacent subcarriers (above and below the subcarrier k in question) that may experience a level of ICI above the Doppler Spread interference threshold. Furthermore, a subcarrier k may experience a different Doppler Spread than other subcarriers.
Consequently, referring to
Still referring to
Consequently, mobile OFDM devices, such as the base 10, may combine training subsymbols and data subsymbols into a single OFDM symbol such that a receiving device, such as the client 12, may characterize the channel for the same time period during which the data symbols where transmitted. Because conventional techniques exist for combining the training and data subsymbols into a single OFDM symbol, such techniques are not further described.
The receiver 30 includes a receive antenna 32, a Fast Fourier Transform (FFT) unit 34, a channel estimator 36, a data-recovery unit 38, and a decoder 40. The FFT unit 34, channel estimator 36, data-recovery unit 38, and decoder 40 may each be implemented in software, hardware, or a combination of software and hardware.
The receive antenna 32 may receive one or more OFDM symbols from a transmitter such as the base 10 of
The FFT unit 34 conventionally converts a received OFDM symbol from a time-domain waveform into an N×1 vector y of complex frequency-domain coefficients (e.g., one complex coefficient for each subcarrier).
The channel estimator 36 estimates the response of the communication channel (e.g., the channel 14 of
The data-recovery unit 38 recovers the OFDM symbol as transmitted by generating an N×1 vector {circumflex over (x)}, which is an estimation of the transmitted OFDM symbol. That is, {circumflex over (x)} includes complex coefficients (one for each subcarrier) that are estimates of the complex coefficients with which the transmitter modulated the transmitted subcarriers. The unit 38 may generally recover {circumflex over (x)} according to the following equations:
y=Ĥ{circumflex over (x)}+n (1)
Ĥ
−1(y−n)=Ĥ−1Ĥ{circumflex over (x)}={circumflex over (x)} (2)
where n is an N×1 vector of average-white-Gaussian-noise complex coefficients at each of the subcarriers. For example, all of the N coefficients of the vector n may be the same. Furthermore, because, as discussed above, some of the y coefficients are for pilot subcarriers that are used only for channel-estimation purposes, the elements of Ĥ, Ĥ, y, and n that correspond to the pilot subcarriers may be discarded prior to calculating Ĥ−1 and solving equation (2) so as to reduce the complexity and increase the speed of the calculation.
The data decoder 40 effectively uses the {circumflex over (x)} coefficients that correspond to the data subcarriers of the OFDM symbol to demodulate the corresponding data subsymbols, and to thus recover the data represented by the subsymbols. For example, if the transmitter modulated a data subcarrier by mapping it to a respective QPSK constellation element, then the data decoder 40 QPSK demodulates the data subcarrier to recover the same constellation element, which represents the bits of data carried by the modulated data subcarrier.
Still referring to
A significant portion of the processing time required by a conventional data-recovery unit may be due to the calculating of the inverted matrix Ĥ−1. For example, if the OFDM symbol includes N=210=1024 subcarriers, then a brute-force solution to equation (2) requires the conventional data-recovery unit to calculate the 1024×1024 inverse Ĥ−1 of the 1024×1024 channel-estimation matrix Ĥ.
To reduce the time required to solve for {circumflex over (x)}, instead of calculating Ĥ−1, the data-recovery unit 38 may calculate only a respective portion of Ĥ−1 for each subcarrier. That is, to obtain each element of {circumflex over (x)}, the data-recovery unit 38 may calculate only a respective submatrix of Ĥ−1, and use this submatrix to calculate the element of {circumflex over (x)} according to an equation that may be derived from equation (2).
But even though calculating only a respective portion of Ĥ−1 for each subcarrier may reduce the time required by the data-recovery unit 38 to solve for {circumflex over (x)}, the data-recovery unit may still consume a significant amount of processing time to solve for {circumflex over (x)}.
The data-recovery unit 38 includes an ICI vector generator 50, an ICImax calculator 52, an ICI-to-channel-response comparator 54, a symbol detector 56, an interference canceller 58, and a channel-estimation updater 60.
The ICI vector generator 50 generates, for each subcarrier k, a 1×i interference vector Ω according to the following equation, where each element of Ω is an indicator of how much energy from an adjacent subcarrier k+|i| may spill over into the frequency fk of the subcarrier k due to the Doppler Spread:
Ωk,i=Ĥ*updated(k,k)Ĥupdated(k,<k++i>) for 1≦|i|≧Q (3)
where Q is the integer number of subcarriers adjacent to either side of the subcarrier k that may spill energy over into the frequency fk of the subcarrier k due to Doppler Spread, and < > indicates k+i mod N, where N is the number of carriers in the OFDM symbol and negative values of k+i are represented in two's complement form (e.g., where N=1024, <1>=1, and <−1>=1023). For example, if subcarriers k−4, k−3, k−2, k−1, k+1, k+2, k+3, and k+4 may spill energy over into the frequency fk of the subcarrier k, then Q=4. In an embodiment, Q may range from approximately 2 to approximately 6, and depends on the application. That is, one may program the ICI vector generator 50 with a Q value that is suitable for the application. For example, if the receiver 30 is installed in an OFDM device to be used in an automobile, the Q value may be lower than if the OFDM device is to be used in an airplane. Alternatively, the device may allow a user to enter information regarding the intended use (e.g., automobile, airplane), and use this information to set Q.
The ICImax calculator 52 calculates a value Imax according to the following equation, where Imax is an indicator of the estimated maximum total energy that may be collectively spilled over into the frequency fk of the subcarrier k by the adjacent subcarriers k+|i| for 1≦|i|≦Q:
for i≠0 (the subcarrier k cannot spill over energy into itself) where σ2 is the variance of each complex sample of the channel background noise, each of these noise samples corresponding to a respective one of the N samples of the time-domain OFDM symbol that the FFT unit 34 takes, and α is selected such that for m % of the noise samples, it is estimated that the real part of the noise sample is less than ασ. α and m are selected according to the following equation:
erf(α/√2)=m (5)
where erf( ) is a probability error function described in Proakis, Digital Communications, McGraw Hill (1995), which is incorporated by reference. For example, where one selects m=92%, then α=√3 satisfies equation (5). As can be seen from equation (4), Imax depends on both the spillage into fk from neighboring subcarriers and on the channel noise. However, the effect of subcarrier spillage on the interference is more predominant than channel noise. One may select a using even lower values of m, for example m=50%. However, to be on the safe side (i.e., to minimize the number of occasions when equation (6) below is true when it should be false) one may choose a relatively high value of m, for example m=92%. Furthermore, because in an embodiment equation (4) is for a QPSK constellation, α is multiplied by 1/√2 in equation (5). For other constellations (e.g., BPSK, QAM), equation (4) and the multiplier of equation (5) may change accordingly.
The ICI-to-channel-response comparator 54 calculates |H(k,k)|2, which is an indicator of the channel response at the frequency fk of the subcarrier k, and calculates √2GImax, which is an indicator of the maximum total energy that may spill over into fk due to the Doppler Spread, and compares these values according to the following equation:
|Ĥupdated(k,k)|2>√2GImax (6)
where G is a real value that may range from approximately 1.0→1.5; for example, G may equal 1.2 or 1.3. Where G is greater than 1.0, it may provide a tolerance to reduce the chance that an error in Imax causes equation (6) to be true when, but for the error, it should be false. If equation (6) is true, then it indicates that the Doppler induced spill-over energy into the frequency fk of the subcarrier k is low enough that the symbol detector 56 may use a reduced-complexity algorithm to estimate the element k of the estimated transmitted symbol {circumflex over (x)} as described below.
The symbol detector 56 may estimate the subsymbol {circumflex over (x)}(k) (the subsymbol carried by the subcarrier k) according to one of at least two algorithms, depending on whether equation (6) is true or false. If equation (6) is true, then the detector 56 calculates {circumflex over (x)}(k) according to the following equation, which represents a “hard decision”:
{circumflex over (x)}(k)=Ĥupdated(k,k)ŷupdated(k) (7)
Because the Doppler induced spillover energy is small enough to render equation (6) true, equation (7) may be used to obtain {circumflex over (x)}(k) instead of a more complicated equation that may include an inverse of Ĥupdated or a portion thereof. In an embodiment, the probability that equation (7) will yield an incorrect value for {circumflex over (x)}(k) (assuming equation (6) is true) is relatively small, for example, 1×10−4 or less. If equation (6) is false, then the detector 56 may calculate {circumflex over (x)}(k) according to a conventional algorithm that may determine the inverse of the channel-response matrix Ĥupdated or a portion thereof. But even if the symbol detector 56 determines only one or a few elements of {circumflex over (x)} according to equation (7), this may still save processing time as compared to solving for every element of {circumflex over (x)} with an inverse-matrix calculating algorithm, because none of equations (3)-(7) require taking an inverse of a matrix such as the estimated channel-response matrix Ĥupdated. And saving processor time may also save power.
If the symbol detector 56 calculates {circumflex over (x)}(k) according to equation (7), then the interference canceller 58 updates the received-symbol vector y according to one of the following equations:
y
updated
=y−Ĥ(:,k){circumflex over (x)}(k) for the initial update (8)
y
updated
=y
updated
−Ĥ
updated(:,k){circumflex over (x)}(k) for subsequent updates (9)
where the “:” operator indicates all rows, such that Ĥ(:,k) indicates the kth column of Ĥ. Equations (8) and (9) effectively remove from the other subcarriers of the received symbol y substantially all energy that may have spilled over from the subcarrier k of the subsymbol just detected by the symbol detector 56 using equation (7). Because the updated vector yupdated is the vector that the detector 56 uses to determine subsequent subsymbols of {circumflex over (x)} (whether or not by using equation (7)), this interference cancellation may reduce the complexity, and thus the processing time, needed to recover the subsequent subsymbols. This interference cancellation may also increase the number of subsymbols of {circumflex over (x)} for which equation (6) is true, and thus may increase the number of subsymbols that may be recovered using the reduced-complexity equation (7).
After the interference canceller 58 updates yupdated, the channel-estimation updater 60 updates the channel-estimation matrix Ĥ according to the following equations:
Ĥ
updated=0N×1 for the initial update (10)
Ĥ
updated(:,k)=0N×1 for subsequent updates (11)
These equations zero the column k of Ĥupdated, which is the column corresponding to the subcarrier of the just-detected subsymbol {circumflex over (x)}(k). Therefore, equations (10) and (11) remove from Ĥupdated substantially all of the influence that the subcarrier k may have on the other subcarriers due to Doppler Spread.
Referring to
Referring to block 62, the data-recovery unit 38 initializes count values NDS and k to zero, where NDS represents the number of subsymbols {circumflex over (x)}(k) detected by the symbol detector 56 according to equation (7), and k is the subcarrier index.
Then, referring to block 64, the unit 38 compares k to N, which is the total number of subcarriers in the received symbol y. If k<N, then the unit 38 proceeds to block 66. Otherwise, the unit 38 proceeds to block 68, which is described further below.
Next, referring to block 66, if k<N, then the unit 38 determines whether the subsymbol {circumflex over (x)}(k) at the subcarrier k has already been detected. If so, then the unit 38 proceeds to block 70 and increments k by 1. If not, the unit proceeds to block 72.
Then, referring to block 72, if the subsymbol {circumflex over (x)}(k) at the subcarrier k has not already been detected, the unit 38 calculates equations (3)-(6) as discussed above, and, determines whether equation (6) is true. If equation (6) is not true, the unit 38 proceeds to block 70 and increments k by 1. But if equation (6) is true, then the unit 38 proceeds to block 74.
Next, referring to block 74, if equation (6) is true, then the unit 38 solves for {circumflex over (x)}(k) according to equation (7) as described above, updates yupdated and Ĥupdated according to equations (8)-(11) as described above, and increments NDS by 1 to indicate that subsymbol {circumflex over (x)}(k) has been detected according to equation (7).
Then, referring to block 70, the unit 38 increments k by 1 and returns to block 64.
The data-recovery unit 38 repeats the above sequence until k=N.
When k=N, the unit 38 proceeds to block 68 and compares NDS to 0.
If NDS does not equal zero, then the unit 38 proceeds to block 62 and repeats the above sequence. Because NDS does not equal 0, the unit 38 detected at least one subsymbol {circumflex over (x)}(k) according to equation (7), and updated yupdated and Ĥupdated according to equations (8)-(11). Because updating yupdated and Ĥupdated may cause equation (6) to be true for a subcarrier k for which equation (6) was not previously true, repeating the above-described sequence until NDS remains at zero may allow the unit 38 to detect more subsymbols {circumflex over (x)}(k) according to equation (7), and thus may further reduce the time that the unit 38 consumes to detect the estimated transmitted symbol {circumflex over (x)}.
Next, referring to block 68, when NDS=0, the above sequence ends, and the unit 38 detects any remaining subsymbols {circumflex over (x)}(k) using another algorithm, e.g., an algorithm that calculates the inverse of Ĥ or portions thereof.
Still referring to
The data-recovery unit 38 includes an ICI variance generator 80, an ICI-to-channel-response comparator 82, a symbol detector 84, and the interference canceller 58 and the channel-estimation updater 60 described above in conjunction of
The variance generator 80 generates, for each subcarrier k, a value
where Q is the integer number of subcarriers adjacent to either side of the subcarrier k that may spill energy over into the frequency fk of the subcarrier k due to Doppler Spread,
The ICI-to-channel-response comparator 82 calculates
which is an indicator of the channel response at the frequency fk of the subcarrier k, and t
t is calculated according to the following equation:
erfc(t)=ER/2 (15)
where erf( ) is a probability error function provided in Proakis, Digital Communications, McGraw Hill (1995), which is incorporated by reference, and ER is the probability that the subsymbol {circumflex over (x)}(k) to be calculated by the symbol detector 84 according to equation (16) below will be erroneous. ER depends on the acceptable error rate for the application. Some applications may only tolerate lower error rates while some may tolerate higher error rates. Therefore, the designer of the data-recovery unit 38 may select a value for ER that is suitable for the application. In an embodiment, ER may approximately equal 1×10−4. In another embodiment, ER may be greater than the probability of error when detecting {circumflex over (x)}(k) according to equation (7) as described above in conjunction with
The symbol detector 84 detects the subsymbol {circumflex over (x)}(k) (the subsymbol carried by the subcarrier k) according to one of at least two algorithms, depending on whether equation (14) is true or false. If equation (14) is true, then the detector 84 determines {circumflex over (x)}(k) according to the following equation, which is based on a linear minimum mean squared error (LMMSE):
Because the Doppler Spread spillover energy is small enough to render equation (14) true, equation (16) may be used to obtain {circumflex over (x)}(k) instead of a more complicated equation that may include an inverse of Ĥupdated or a portion thereof. As discussed above, the probability that equation (16) will yield an incorrect value for {circumflex over (x)}(k) is approximately ER. If equation (14) is false, then the symbol detector 84 may calculate {circumflex over (x)} (k) according to another algorithm that may determine the inverse of the channel-response matrix Ĥupdated or a portion thereof. But even if the symbol detector 84 determines only one or a few elements of {circumflex over (x)} according to equation (16), this may still save processing time as compared to solving for every element of {circumflex over (x)} with an inverse-matrix-calculation algorithm, because none of equations (12)-(14) and (16) involves taking an inverse of a matrix such as the estimated channel-response matrix Ĥupdated.
If the symbol detector 84 calculates {circumflex over (x)}(k) according to equation (16), then the interference canceller 58 updates the received-symbol vector yupdated according to equation (8) or (9) as discussed above in conjunction with
After the interference canceller 58 updates yupdated, the channel-estimation updater 60 updates the channel-estimation matrix Ĥupdated according to equation (10) or (11) as discussed above in conjunction with
Still referring to
Referring to
Referring to block 90, the data-recovery unit 38 initializes count values NDS and k to zero, where NDS represents the number of subsymbols {circumflex over (x)}(k) detected by the symbol detector 84 according to equation (16), and k is the subcarrier index.
Then, referring to block 92, the unit 38 compares k to N, which is the total number of subcarriers in the received symbol y. If k<N, then the unit 38 proceeds to block 94. If not, then the unit 38 proceeds to block 96, which is described further below.
Next, referring to block 94, if k<N, then the unit 38 determines whether the subsymbol {circumflex over (x)}(k) at the subcarrier k has already been detected. If so, then the unit 38 proceeds to block 98 and increments k by 1. If not, the unit proceeds to block 100.
Then, referring to block 100, if the subsymbol {circumflex over (x)}(k) at the subcarrier k has not already been detected, then the unit 38 determines whether the LNC or the RNC is satisfied. If neither the LNC nor the RNC is satisfied, then the unit 38 proceeds to block 98 and increments k by 1. If either the LNC or the RNC is satisfied, then the unit 38 calculates equation (12) or (13) (depending on whether the LNC or the RNC is satisfied) and equation (14) as discussed above in conjunction with
Next, referring to block 102, if equation (14) is true, then the unit 38 solves for {circumflex over (x)}(k) according to equation (16) as described above, updates yupdated and Ĥupdated according to equations (8)-(11) as described above, and increments NDS by 1 to indicate that a subsymbol {circumflex over (x)}(k) has been detected according to equation (16).
Then, referring to block 98, the unit 38 increments k by 1, and returns to block 92.
The data-recovery unit 38 of
When k=N, the unit 38 proceeds to block 96 and compares NDS to 0.
If NDS does not equal zero, then the unit 38 proceeds to block 90 and repeats the above sequence. Because NDS does not equal 0, the unit 38 detected at least one subsymbol {circumflex over (x)}(k) according to equation (16), and updated yupdated and Ĥupdated according to equations (8)-(11). Because updating yupdated and Ĥupdated may cause equation (14) to be true for a subcarrier k for which equation (14) was not previously true, repeating the above-described sequence until NDS remains at zero may allow the unit 38 to detect more subsymbols {circumflex over (x)}(k) according to equation (16), and thus may further reduce the time that the unit 38 consumes to detect the estimated transmitted symbol {circumflex over (x)}.
Next, referring to block 96, when NDS=0, the above sequence ends, and the unit 38 detects any remaining subsymbols {circumflex over (x)}(k) using another algorithm, e.g., an algorithm that calculates the inverse of Ĥ or portions thereof.
Still referring to
Referring to block 110, the data-recovery unit 38 detects as many of the subsymbols {circumflex over (x)}(k) as possible using equation (7) per the sequence of
Next, referring to block 112, the unit 38 detects as many of the remaining subsymbols {circumflex over (x)}(k) as possible using equation (16) per the sequence of
Then, referring to block 114, the unit 38 detects any remaining data subsymbols {circumflex over (x)}(k) per another algorithm, e.g., an algorithm that may calculate the inverse of Ĥ or portions thereof.
The data-recovery unit 38 of
The ICI detector 120 determines a signal-to-ICI ratio (SIR) for each subcarrier k of the received OFDM symbol, and orders the subcarriers from highest SIR to lowest SIR. A technique for determining the SIR for a subcarrier k is disclosed in Low-Complexity ICI Cancellation in Frequency Domain for OFDM Systems in Time-Varying Multipath Channels, Wang et al. (2006) IEICE Trans. Commun.; E89-B:1020, which is incorporated by reference.
The symbol detector 122 detects the subsymbols {circumflex over (x)}(k) in the order provided by the ICI detector 120, that is, from the subsymbol {circumflex over (x)}(k) modulating the subcarrier k having the highest SIR to the subsymbol {circumflex over (x)}(k) modulating the subcarrier k having the lowest SIR. By detecting the subsymbol associated with the highest SIR first, the detector 122 detects the subsymbol having the highest probability of being correctly detected, and, then, via, e.g., interference cancellation, may use one or more of the detected subsymbols to improve the accuracy with which it will detect subsequent subsymbols.
Furthermore, the symbol detector 122 detects each subsybmol {circumflex over (x)}(k) by calculating a respective inverse Ĥ−1updated of a submatrix of Ĥupdated.
Because the inverse submatrix Ĥ−1updated calculated for one subcarrier k may be conventionally used to speed the calculation of an inverse submatrix Ĥ−1updated for another subcarrier k, the symbol detector 122 includes a submatrix buffer 124 for storing calculated inverse submatrices Ĥ−1updated for possible future use. In an embodiment, an inverse submatrix Ĥ−1updated calculated for a subcarrier k may be used to speed the calculation of inverse submatrices Ĥ−1updated for |v| adjacent subcarriers, where v depends on, e.g., the dimensions of the inverse submatrix Ĥ−1updated calculated for the subcarrier k. In an embodiment, v is an integer that ranges from approximately 1→10, although it may be greater than 10. After all of the subsymbols within ±v of the detected subsymbol {circumflex over (x)}(k) have also been detected, the symbol detector 122 may delete from the buffer 124 the inverse submatrix Ĥ−1updated calculated for the subcarrier k. Deleting inverse submatrices Ĥ−1updated in this manner may allow one to reduce the size of the buffer 124 as compared to a buffer that stores all inverse submatrices until the entire estimated symbol {circumflex over (x)} is detected.
Still referring to
Initially, before any subsymbols {circumflex over (x)}(k) have been detected, the ICI detector 120 receives Ĥupdated=Ĥ from the channel-estimation updater 60 (or receives Ĥ directly from the channel estimator 36 of
Next, the symbol detector 122 generates an inverse submatrix Ĥ−1updated corresponding to the subsymbol carried by the subcarrier k having the highest SIR, and, using this inverse submatrix and yupdated=y, calculates the estimation {circumflex over (x)}(k) of the transmitted subsymbol on the subcarrier k. The symbol detector 122 also stores this inverse submatrix Ĥ−1updated for subcarrier k in the buffer 124.
Then, the interference canceller 58 updates yupdated per equation (8) or in another suitable manner, and the channel-estimation updater 60 updates Ĥupdated per equation (10) or in another suitable manner.
Next, the symbol detector 122 generates an inverse submatrix Ĥ−1updated corresponding to the subsymbol carried by the subcarrier k having the second highest SIR. The symbol detector may choose the subcarrier k from the original ordering provided by the ICI detector 120, or the ICI detector may recalculate the SIRs of the subcarriers of the remaining undetected subsymbols {circumflex over (x)}(k) and reorder them as appropriate based on Ĥupdated. Furthermore, if the subcarrier k having the second highest SIR is within ±v subcarriers of the subcarrier of the previously detected subsymbol {circumflex over (x)}(k), then the symbol detector 122 may retrieve the inverse submatrix for the previously detected subsymbol from the buffer 124, and use this retrieved inverse submatrix to calculate another inverse submatrix on Ĥupdated for the present subcarrier k. But if the present subcarrier k is not within ±v subcarriers of the previous subcarrier, then the detector 122 may calculate the inverse submatrix for the present subcarrier k without the benefit of using a previously calculated inverse submatrix.
Then, using the calculated inverse submatrix Ĥ−1updated and yupdated, the detector 122 calculates the estimation {circumflex over (x)}(k) of the subsymbol transmitted on the subcarrier k. The symbol detector 122 also stores this inverse submatrix Ĥ−1updated for the subcarrier k in the buffer 124.
Next, the interference canceller 58 updates yupdated per equation (9) or in another suitable manner, and the channel-estimation updater 60 updates Ĥupdated per equation (11) or in another suitable manner.
Then, the detector 122 detects the remaining subsymbols {circumflex over (x)}(k) in a manner similar to that described above for the subsymbol associated with the subcarrier k having the second highest SIR. If for a subcarrier k there are multiple inverse submatrices stored in the buffer 124 for other subcarriers within ±v subcarriers of k, then the detector 122 may select the inverse submatrix associated with the closest of these subcarriers from which to generate the inverse submatrix for the subcarrier k. For example, if the buffer 124 stores inverse submatrices associated with k+1 and k−5, then the detector 122 may select the inverse submatrix associated with k+1.
It is estimated that, in an embodiment, 50%-90% of the time the buffer 124 stores at least one inverse submatrix that is within ±v subcarriers of the subcarrier k currently undergoing detection. Therefore, the time savings in detection time compared to a symbol detector that does not have the buffer 124 may be significant.
Still referring to
From the foregoing it will be appreciated that, although specific embodiments have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the disclosure. Furthermore, where an alternative is disclosed for a particular embodiment, this alternative may also apply to other embodiments even if not specifically stated.
The present application claims priority to U.S. Provisional Patent Application Nos. 61/105,704, filed Oct. 15, 2008; and 61/158,290, filed Mar. 6, 2009; both of which applications are incorporated herein by reference in their entireties. The present application is related to commonly assigned and copending U.S. patent application Ser. No. 12/579,969 (Attorney Docket No. 2633-003-05), filed on Oct. 15, 2009, which application is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61105704 | Oct 2008 | US | |
61158290 | Mar 2009 | US |