Systems and methods for detecting data in a received multiple-input-multiple-output (MIMO) signal
09979449 ยท 2018-05-22
Assignee
Inventors
- B Hari Ram (Chennai, IN)
- Lokesh Sundaramurthy Satrasala (Bangalore, IN)
- Sri Varsha Rottela (Andhra Pradesh, IN)
- Sudhir Srinivasa (Campbell, CA)
- Hongyuan Zhang (Fremont, CA)
- Chusong Xiao (Union City, CA)
- Mao Yu (San Jose, CA)
- Yanni Chen (Sunnyvale, CA, US)
- Yong Ma (San Jose, CA, US)
Cpc classification
H04B7/0456
ELECTRICITY
H04L1/0054
ELECTRICITY
International classification
H04Q1/20
ELECTRICITY
Abstract
Systems and methods for detecting data in a received multiple-input-multiple-output signal are provided. N signals are received from N respective antennas, where the received signals are associated with (i) M sets of data values, (ii) a set of symbols, and (iii) a set of carrier frequencies. The N signals are formed into a received signal vector y, and one or more transformations are performed on the received signal vector y to obtain a transformed vector. A plurality of samples are formed from the transformed vector. For samples of the plurality of samples, a data detection technique of a plurality of data detection techniques is selected. The selecting is based on at least one of a spatial stream, a symbol, and a carrier frequency associated with the given sample. The selected data detection, technique is used to detect data of the given sample.
Claims
1. A method of detecting data in a received multiple-input-multiple-output (MIMO) signal, the method comprising: receiving, via a transmission channel, N signals from N respective antennas, the received signals being associated with (i) M sets of data values, (ii) a set of symbols, and (iii) a set of carrier frequencies, wherein N and M are non-zero positive integers; forming the N signals into a received signal vector y and performing one or more transformations on the received signal vector y to obtain a transformed vector, forming a plurality of samples from the transformed vector, each sample of the plurality of samples being associated with (i) a spatial stream of a set of spatial streams, (ii) a symbol of the set of symbols, and (iii) a carrier frequency of the set of carrier frequencies; selecting, for samples of the plurality of samples, a data detection technique of a plurality of data detection techniques to be used in detecting data of a given sample, the selecting being based on at least one of the spatial stream, the symbol, and the carrier frequency associated with the given sample; and using the selected data detection technique to detect data of the given sample; the selecting and using the selected data detection technique further comprising, based on a first data detection technique being selected, using a set of equalizer modules of a communication device to implement the first data detection technique, and based on a second data detection technique being selected, (a) disabling one or more equalizer modules of the set of equalizer modules to implement the second data detection technique, or (b) modifying one or more operations performed in an equalizer module of the set of equalizer modules, and modifying one or more inputs to the set of equalizer modules to implement the second data detection technique.
2. The method of claim 1, wherein the selecting comprises: selecting the first data detection technique of the plurality of data detection techniques for processing samples associated with a first spatial stream of the set of spatial streams; and selecting the second data detection technique of the plurality of data detection techniques for processing samples associated with a second spatial stream of the set of spatial streams, wherein the first data detection technique is different than the second data detection technique.
3. The method of claim 1, wherein the selecting comprises: selecting the first data detection technique of the plurality of data detection techniques for processing samples associated with a first symbol of the set of symbols; and selecting the second data detection technique of the plurality of data detection techniques for processing samples associated with a second symbol of the set of symbols, wherein the first data detection technique is different than the second data detection technique.
4. The method of claim 1, wherein the selecting comprises: selecting the first data detection technique of the plurality of data detection techniques for processing samples associated with a first carrier frequency of the set of carrier frequencies; and selecting the second data detection technique of the plurality of data detection techniques for processing samples associated with a second carrier frequency of the set of carrier frequencies, wherein the first data detection technique is different than the second data detection technique.
5. The method of claim 1, wherein the selecting of the data detection technique for the given sample comprises: computing a signal-to-interference ratio (SIR) or a signal-to-noise ratio (SNR) associated with the given sample; and comparing the computed SIR or SNR or both to a threshold, wherein the selecting of the data detection technique for the given sample is based on the comparison.
6. The method of claim 1, wherein the plurality of data detection techniques includes (i) maximum likelihood (ML) techniques, (ii) a zero-forcing (ZF) technique, and (iii) a technique that includes operations of both the ML techniques and the ZF technique.
7. The method of claim 1, wherein the selecting is based on (i) the symbol associated with the given sample, and (ii) the spatial stream associated with the given sample.
8. The method of claim 1, wherein the selecting is based on (i) the symbol associated with the given sample, and (ii) the carrier frequency associated with the given sample.
9. The method of claim 1, wherein the selecting is based on (i) the carrier frequency associated with the given sample, and (ii) the spatial stream associated with the given sample.
10. The method of claim 1, wherein the selecting is based on (i) the symbol associated with the given sample, (ii) the carrier frequency associated with the given sample, and (iii) the spatial stream associated with the given sample.
11. A communication device for detecting data in a received multiple-input-multiple-output (MIMO) signal, the communication device comprising: N antennas configured to receive, via a transmission channel, N respective signals, the received signals being associated with (i) M sets of data values, (ii) a set of symbols, and (iii) a set of carrier frequencies, wherein N and M are non-zero positive integers; one or more integrated circuit (IC) devices configured to implement a plurality of data detection techniques, form the N signals into a received signal vector y and perform one or more transformations on the received signal vector y to obtain a transformed vector, form a plurality of samples from the transformed vector, each sample of the plurality of samples being associated with (i) a spatial stream of a set of spatial streams, (ii) a symbol of the set of symbols, and (iii) a carrier frequency of the set of carrier frequencies, and select, for samples of the plurality of samples, a data detection technique of the plurality of data detection techniques to be used in detecting data of a given sample, the selecting being based on at least one of the spatial stream, the symbol, and the carrier frequency associated with the given sample, based on a first data detection technique being selected, use a set of equalizer modules of the one or more IC devices to implement the first data detection technique, and based on a second data detection technique being selected, (a) disable one or more equalizer modules of the set of equalizer modules to implement the second data detection technique, or (b) modify one or more operations performed in an equalizer module of the set of equalizer modules, and modify one or more inputs to the set of equalizer modules to implement the second data detection technique.
12. The communication device of claim 11, wherein the one or more IC devices are configured to use the selected data detection technique to detect data of the given sample.
13. The communication device of claim 11, wherein the one or more IC devices are configured to compute a signal-to-interference ratio (SIR) or a signal-to-noise ratio (SNR) associated with the given sample; and compare the computed SIR or SNR or both to a threshold, wherein the one or more IC devices are configured to select the data detection technique for the given sample based on the comparison.
14. The communication device of claim 11, wherein the plurality of data detection techniques includes (i) maximum likelihood (ML) techniques, (ii) a zero-forcing (ZF) technique, and (iii) a technique that includes operations of both the ML techniques and the ZF technique.
15. A method of detecting data in a received multiple-input-multiple-output (MIMO) signal, the method comprising: receiving, via a transmission channel, N signals from N respective antennas, the received signals being associated with (i) M sets of data values, (ii) a set of symbols, and (iii) a set of carrier frequencies, wherein N and M are non-zero positive integers; forming the N signals into a received signal vector y and performing one or more transformations on the received signal vector y to obtain a transformed vector; forming a plurality of samples from the transformed vector, each sample of the plurality of samples being associated with (i) a spatial stream of a set of spatial streams, (ii) a symbol of the set of symbols, and (iii) a carrier frequency of the set of carrier frequencies; selecting, for samples of the plurality of samples, a data detection technique of a plurality of data detection techniques to be used in detecting data of a given sample, the selecting being based on at least one of the spatial stream, the symbol, and the carrier frequency associated with the given sample; and using the selected data detection technique to detect data of the given sample, wherein the selecting comprises, selecting a first data detection technique of the plurality of data detection techniques for processing samples associated with a first symbol of the set of symbols, and selecting a second data detection technique of the plurality of data detection techniques for processing samples associated with a second symbol of the set of symbols, wherein the first data detection technique is different than the second data detection technique.
Description
BRIEF DESCRIPTION OF THE FIGURES
(1)
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
(11)
(12)
(13)
DETAILED DESCRIPTION
(14)
(15) In the example illustrated in
(16) The MIMO equalizer 116 utilizes a matrix decoder 126 to perform distance and LLR calculations. As described below, in some embodiments, the MIMO equalizer 116 is configured to advantageously employ multiple different data detection techniques to detect data in received signals. The use of the multiple different detection schemes enables the MIMO equalizer 116 to balance computational complexity and performance (e.g., detection accuracy), as described in further detail below. In some embodiments, in detecting data of received signals, the MIMO equalizer 116 is configured to select two or more data detection techniques from a plurality of data detection techniques.
(17) The plurality of data detection techniques include, in some embodiments, a 3ML (maximum-likelihood) data detection technique, a 2ML data detection technique, a zero-forcing, maximum-likelihood (ZF-ML) data detection technique, and a zero-forcing (ZF) data detection technique. As described below, in some embodiments, the 2ML and ZF-ML data detection techniques are implemented using a subset of the equalizer modules of the 3ML data detection technique. The 3ML data detection technique is described below with reference to
(18) The 3ML data detection technique generally provides a highest performance (e.g., a highest detection accuracy) but has a relatively high computational complexity. Rather than only utilizing the 3ML data detection technique, the techniques of the present disclosure enable dynamic switching between multiple different data detection techniques (e.g., 3ML, ZF-ML, 2ML, and ZF data detection techniques, etc.). By utilizing the multiple different data detection algorithms, the techniques of the present disclosure enable a lower power consumption as compared to techniques that only use the 3ML algorithm.
(19) In embodiments, the lower power consumption provided by the techniques of the present disclosure comes at a cost of reduced performance (e.g., reduced detection accuracy, etc.). Specifically, although the ZF-ML, 2ML, and ZF techniques offer a lower power consumption than the 3ML technique, these techniques also have a lower performance than the 3ML technique in some instances. Thus, for example, an accuracy of data detection provided by the ZF-ML, 2ML, and ZF techniques may be lower than that of the 3ML technique in some instances. As an example, when a signal-to-interference ratio (SIR) or signal-to-noise ratio (SNR) of a signal is relatively low the signal is relatively weak), the 3ML technique may provide more accurate data detection than the ZF-ML, 2ML, and ZF techniques. Accordingly, the use of the multiple different data detection techniques described herein provides a balance between computational complexity and performance in some embodiments.
(20) As an example of the techniques described herein, consider a communication device that receives signals via multiple different spatial streams. The communication device is configured, in some embodiments, to detect data of the multiple Spatial streams in parallel (e.g., simultaneously). According to an embodiment of the present disclosure, the communication device (i) detects data of a first spatial stream using the 3ML data detection technique, (ii) detects data of a second spatial stream using the 2ML data detection technique, and (iii) detects data of a third spatial stream using the ZF-ML data detection technique. Through the use of the multiple different data detection techniques, this embodiment enables a lower power consumption as compared to techniques that use the 3ML algorithm for all three spatial streams. In other embodiments described below, selection of data detection techniques based on other resources OFDM symbols in a time domain, carrier frequencies, etc.) is utilized. Further, in other embodiments described below, a data detection technique is selected based on a metric computed by the communication device, such as an SIR, an SNR, or an interference-to-noise ratio (INR).
(21) With reference again to
(22)
and n is a 31 vector ([n.sub.1, n.sub.2, n.sub.3].sup.T). Thus, a 33 MIMO system with the three spatial streams may be described by the following equation:
(23)
Assuming an additive white Gaussian noise (AWGN) model and perfect channel estimation, the equalizer 124 seeks optimal estimates of symbols x.sub.1, x.sub.2, and x.sub.3 so as to minimize a Euclidian distance:
(24)
The selection of optimal estimates of the symbols to minimize the Euclidian distance is described below and is performed using multiple different data detection techniques (e.g., 3ML, ZF-ML, 2ML, and ZF techniques, etc.).
(25) The techniques of the present disclosure enable a communication device to switch between multiple different data detection techniques, thus providing a balance between computational complexity power consumed) and performance. In MIMO-OFDM systems, a communication device (e.g., a receiver, a transceiver, etc.) is configured to receive, via a transmission system, N signals from N respective antennas. The received signals are associated with (i) M sets of data values, (ii) a set of symbols, and (iii) a set of carrier frequencies. In some embodiments, M is equal to a number of spatial streams used in the MIMO-OFDM system. For instance, in a MIMO-OFDM system utilizing three spatial streams, the received signals are associated with M=3 sets of data values. In some embodiments, the N signals are formed into a received signal vector y, and the M sets of data values are formed into a vector x. Examples of the vector y and the vector x are described above and in further detail below.
(26) In some embodiments, the communication device is configured to estimate a channel matrix H representing effects of the transmission channel on the M sets of data values. Further, the communication device is configured to perform a QR decomposition of the channel matrix H, in some embodiments, such that H=QR, where Q matrix is a unitary matrix and R matrix is an upper triangular matrix. The communication device is also configured to perform one or more transformations on the received signal vector y to obtain a transformed vector. The QR decomposition and the transforming of the received signal vector y are explained in further detail below. In some embodiments described below, the transforming comprises transforming the received signal vector y into a rotated signal vector z according to z=Q.sup.Hy. The communication device is also configured to form a plurality of samples from the transformed vector, where each sample of the plurality of samples is associated with (i) a spatial stream of a set of spatial streams, (ii) a symbol of the set of symbols, and (iii) a carrier frequency of the set of carrier frequencies.
(27) The communication device is configured to select, for samples of the plurality of samples, a data detection technique of a plurality of data detection techniques to be used in detecting data of a given sample. In some embodiments of the present disclosure, the selecting is based on at least one of the spatial stream, the symbol, and the carrier frequency associated with the given sample. For instance, in an embodiment, the communication device selects a first data detection technique (e.g., the 3ML data detection technique) for detecting data, of samples associated with a first spatial stream, a second data detection technique (e.g., the 2ML data detection technique) for detecting data of samples associated with a second spatial stream, and a third data detection technique (e.g., the ZF-ML data detection technique or the ZF data detection technique, etc.) for detecting data of samples associated with a third spatial stream.
(28) Likewise, in another embodiment, the communication device selects a first data detection technique for detecting data of samples associated with a first OFDM symbol (e.g., samples associated with a first OFDM symbol index), a second data detection technique for detecting data of samples associated with a second OFDM symbol samples associated with a second OFDM symbol index), and a third data detection technique for detecting data of samples associated with a third OFDM symbol (e.g., samples associated with a third OFDM symbol index). Similarly, in another embodiment, the communication device selects a first data detection technique for detecting data of samples associated with a first carrier frequency (e.g., samples associated with a first earner index), a second data detection technique for detecting data of samples associated with a second carrier frequency (e.g., samples associated with a second carrier index), and a third data detection technique for detecting data of samples associated with a third earner frequency (e.g., samples associated with a third earner index).
(29) In some embodiments of the present disclosure, the communication device is configured to switch data detection techniques utilized for different streams, symbols, or earner frequencies in a cyclical manner. Consider an embodiment in which the communication device selects (i) the 3ML data detection technique for detecting date of a first spatial stream, (ii) the 2ML data detection technique for detecting data of a second spatial stream, and (iii) the ZF-ML data detection technique for detecting data of a third spatial stream. If this scheme is utilized at all times (e.g., for all symbols, for all carrier frequencies, etc.), data detection of the first spatial stream may have a higher accuracy than data detection of the second and third spatial streams as a result of the higher performance of the 3ML algorithm as compared to the 2ML and ZF-ML algorithms. This may be undesirable. Accordingly, in embodiments of tire present disclosure, the above-mentioned cyclical switching techniques are used to eliminate or mitigate this undesirable condition.
(30) In the above example, for instance, during a first stage (e.g., a first time period, a first iteration, a first OFDM symbol, a first carrier frequency, etc.), the communication device selects (i) the 3ML data detection technique for detecting data of a first spatial stream, (ii) the 2ML data detection technique for detecting data of a second spatial stream, and (iii) the ZF-ML data detection technique for detecting data of a third spatial stream. In a second stage (e.g., a second time period, a second iteration, a second OFDM symbol, a second carrier frequency, etc.), the communication device selects (i) the ZF-ML data detection technique for detecting data of a first spatial stream, (ii) the 3ML data detection technique for detecting data of a second spatial stream, and (iii) the 2ML data detection technique for detecting data of a third spatial stream. In a third stage (e.g., a third time period, a third iteration, a third OFDM symbol, a third carrier frequency, etc.), the communication device selects (i) the 2ML data detection technique for detecting data of a first spatial stream, (ii) the ZF-ML data detection technique for detecting data of a second spatial stream, and (iii) the 3ML data detection technique for detecting data of a third spatial stream. Thus, in this example, use of the 3ML data detection technique is balanced across the three spatial streams, which may help to ensure that data detection accuracy is approximately equal for the three spatial streams. In embodiments where data detection techniques are selected on the basis of an OFDM symbol index or a carrier frequency index, cyclical switching techniques can be used in a similar manner to ensure that data detection accuracy is approximately equal across multiple OFDM symbols or multiple earner frequencies.
(31) In the embodiments described above, the communication device selects a data detection technique based on a single resource (e.g., the data detection technique for a sample is selected based on a spatial stream, OFDM symbol, or carrier frequency associated with the sample). In other embodiments, the communication device selects a data detection technique for a given sample based on two or more resources associated with the given sample. To illustrate these other embodiments, reference is made to
(32)
(33)
(34) It is noted that the schemes illustrated in
(35) Similarly, although the example of
(36) In the embodiments described above, the communication device selects a data detection technique for a given sample based on one or two resources. In other embodiments, the communication device selects a data detection technique for a given sample based on three resources associated with the given sample (e.g., spatial stream, OFDM symbol, and carrier frequency associated with the given sample). It is thus noted that according to the techniques of the present disclosure, selection of data detection techniques can be performed across one resource or multiple resources, i.e., one or more of the resources OFDM symbol (e.g., time), carrier frequency (e.g., tone), and spatial stream.
(37) In some embodiments, the selection of a data detection technique for a given sample is based on an SIR, SNR, INR, and/or other metric. Specifically, in some embodiments, the communication device is configured to compute the SIR, SNR, INR, or other metric associated with a given sample. The communication device is further configured to compare the computed SIR, SNR, INR, or other metric to one or more thresholds and select a data detection technique for the given sample based on the comparisons). For instance, in some embodiments, based on a determination that the computed SIR or SNR is greater than or equal to the threshold, the communication device is configured to select a first data detection technique (e.g., one of the 2ML, ZF-ML, or ZF data detection techniques, for instance) that has a relatively low computational complexity and/or a relatively low performance. When the SIR or SNR is greater than or equal to the threshold, this indicates a relatively strong signal, and the first data detection technique may be adequate to detect data of the signal, despite its relatively low performance.
(38) By contrast, based on a determination that the computed SIR or SNR is less than the threshold, the communication device is configured to select a second data detection technique (e.g., the 3ML data detection technique, for instance) that has a relatively high computational complexity and/or a relatively high performance. When the SIR or SNR is less than the threshold, this indicates a relatively weak signal. Accordingly, use of the first data detection technique having the relatively low performance may be inadequate for detecting data of the weak signal, such that the second data detection technique is selected by the communication device.
(39)
(40) At 142, a symbol index S is set equal to zero, and a carrier index K is set equal to zero. The symbol index S for a sample corresponds to an OFDM symbol associated with the sample, and the carrier index K for the sample corresponds to a carrier frequency associated with the sample. As described above, in the techniques of the present disclosure, the communication device is configured to perform, the following steps, among others: (i) receiving N signals from N respective antennas, (ii) forming the N signals into a received signal vector y, (iii) performing one or more transformations on the received signal vector y to obtain a transformed vector, and (iv) forming a plurality of samples from the transformed vector, where each sample of the plurality of samples is associated with a spatial stream, an OFDM symbol of a set of OFDM symbols, and a carrier frequency of a set of carrier frequencies. Accordingly, the symbol index S for a sample denotes the OFDM symbol of the set of OFDM symbol s associated with the sample, and the symbol index K for the sample denotes the carrier frequency of the set of carrier frequencies associated with the sample.
(41) After the step 142, the flowchart includes branches for respective tones, i.e., carrier frequencies. Thus, after setting K=0 in the step 142, a first branch corresponds to the Kth tone (i.e., carrier frequency index K=0), a second branch corresponds to the (K+1)th tone (i.e., carrier frequency index K=1), and so on. The example of
(42) To illustrate operations of the data detection blocks 144, reference is made to
(43) At 153, the data detection block 144 determines which condition of a plurality of conditions is true, and at 154, 155, 156, a data detection technique is selected based on the condition determined to be true. The selected data detection technique is used at 157 to extract data 158 from the sample. The determination made at the step 153 varies in different embodiments. In some embodiments, the determination at 153 is made based on the SIR, SNR, or INR of the sample under consideration. For instance, the SIR or SNR of the sample is compared to one or more thresholds, and based on these comparisons), a condition is determined to be true, and a corresponding data detection scheme is selected at 154, 155, or 156.
(44) As described above, for example, if the SIR or SNR is determined to be relatively low, this may indicate that a relatively high complexity, high performance data detection technique (e.g., the 3ML data detection technique, etc.) is best-suited for performing data detection. Accordingly, the determination at 153 and detection technique selection at 154, 155, or 156 may result in the selection of the high complexity, high performance data detection technique, in embodiments. By contrast, if the SIR or SNR is determined to be relatively high, this may indicate that a relatively low complexity, low performance data detection technique (e.g., the ZF-ML, 2ML, or ZF data detection technique, etc.) is well-suited for performing data detection. Accordingly, the determination at 153 and detection technique selection at 154, 155, or 156 may result in the selection of the low complexity, low performance data detection technique, in embodiments. Although embodiments described above reference the use of a single threshold. In some embodiments, multiple thresholds are used to enable selection among the different 3ML, ZF-ML, 2ML, and ZF data detection techniques.
(45) In some embodiments, the determination made at the step 153 is made based on one or more of the variables symbol index S, carrier index K, and spatial stream iSS. For instance, in some embodiments, the determination is made based on a single variable (e.g., samples received via spatial stream iSS=1 cause a condition corresponding to the 3ML data detection technique to be true, samples received via spatial stream iSS=2 cause a condition corresponding to the ZF-ML data detection technique to be true, and samples received via spatial stream iSS=3 cause a condition corresponding to the 2ML data detection technique to be true, etc.). In other embodiments, the determination is made based on two or three of the variables S, K, and iSS.
(46) In some embodiments, the determination made at the step 153 is based on a switching sequence that is repeated every third OFDM symbol. To illustrate an example of this, reference is made to
(47) To illustrate this, at 133, the binary numbers are placed in a table, with each row of the table corresponding to a group of OFDM symbols, and each column of the table corresponding to a spatial stream. Thus, in this example, for OFDM symbols 1, 4, 7, . . . , the number in the first column indicates that a first data detection technique (e.g., the 3ML data detection technique) should be selected for detecting data of the first spatial stream, and the number 0 in the second and third columns indicates that a second data detection technique (e.g., the ZF-ML, 2ML, or ZF data detection technique, etc.) should be selected for detecting data of the second and third spatial streams. For OFDM symbols 2, 5, 8, . . . , the number 1 in the second column indicates that the first data detection technique should be selected for detecting data of the second spatial stream, and the number 0 in the first and third columns indicates that the second data detection technique should be selected for detecting data of the first and third spatial streams. For OFDM symbols 3, 6, 9, . . . the number 1 in the third column indicates that the first data detection technique should be selected for detecting data of the third spatial stream, and tire number 0 in the first and second columns indicates that the second data detection technique should be selected for detecting data of the first and second spatial streams.
(48) In examples, the switching sequences are chosen to provide a balance between computational complexity (e.g., power consumption) and performance. For instance, in the context of
(49) It is noted that the embodiment of
(50) With reference again to
(51) With reference again to
(52) The embodiments described above are used in multiple-earner systems, i.e., MIMO-OFDM symbols using multiple carrier frequencies. It is noted, however, that some embodiments of the present disclosure are used in the context of a single-carrier system. In the single carrier system, a single carrier frequency is used. In such embodiments, a communication device is configured to receive, via a transmission channel, N signals from N respective antennas, where the received signals are associated with M sets of data values and a set of symbols. The communication device is further configured to form the N signals into a received signal vector y and perform, one or more transformations on the received signal vector y to obtain a transformed vector. The communication device is configured to form a plurality of samples from the transformed vector, where each sample of the plurality of samples is associated with (i) a spatial stream of a set of spatial streams, and (ii) a symbol of the set of symbols. Accordingly, in the single-carrier system, it can be seen that the samples are associated with variables (symbols, stream). The communication device is configured to select, for samples of the plurality of samples, a data detection technique of a plurality of data detection techniques to be used in detecting data of a given sample. The selecting is based on at least one of the spatial stream and the symbol associated with the given sample. The selected data detection technique is used to detect data of the given sample.
(53) The 3ML data detection technique is described below with reference to
(54)
(55)
A similar QR decomposition procedure is performed at 170, 196 using a permutated channel matrix, as described in greater detail below. At 168 and 194, the channel matrix H 164 is multiplied by a permutation matrix. In the current example including three spatial streams, the permutation matrices used at 168 and 194 may be, for example,
(56)
such that the columns of the channel matrix H are swapped when multiplied by the permutation matrix. In a modified version of the block diagram 160 of
(57) The matrix decoder 162 executes over three paths 172, 174, 192 that may operate in series or in parallel. The first path 172 calculates LLR values 176 for data value associated with a third stream, the second path 174 calculates LLR values 178 for data value associated with a second stream, and the third path 192 calculates LLR values 204 for data value associated with a first stream. These LLR values 176, 178, 204 may be combined and decoded as described above with reference to
(58) The first path 172 begins at a matrix transformer 180. In the three spatial stream case, the matrix transformer 180 receives the first, second, and third signals as a 31 vector ([y.sub.1, y.sub.2, y.sub.3].sup.T). The matrix transformer 180 transforms the y vector according to the relationship z=Q.sup.Hy, resulting in a 31 z vector ([z.sub.1, z.sub.2, z.sub.3].sup.T). Specifically, in the matrix transformer 180, the relationship y=Hx+n may be multiplied by Q.sup.H to obtain z=Q.sup.Hy=Rx+Q.sup.Hn, which s expanded to
(59)
In the three spatial stream system, each data symbol transmitted, (where i=1 corresponds to data transmitted on a first spatial stream, i=2 corresponds to data transmitted on a second spatial stream, and i=3 corresponds to data transmitted on a third spatial stream) maps to n bits {b.sub.1.sup.(i), b.sub.2.sup.(i), . . . , b.sub.n.sup.(i)}. K=2.sup.n is the alphabet size of the underlying modulation, such as binary phase shift keying (BPSK), quadrature amplitude modulation (QAM), etc.
(60) Following the z transformation at 180, a minimum distance value is calculated at 182 for each of the K possible values of x.sub.3. In a system using n=6 bits, the alphabet size K is equal to 64. The minimum distance calculated at 182 is calculated according to a formula:
(61)
for each possible x.sub.3 value. Specifically, x.sub.1 and x.sub.1 values that minimize the distance T.sub.1+T.sub.2+T.sub.3 are determined for each possible x.sub.2 value. It should be noted that the QR decomposition and z transformation procedure are of low computational complexities and do not change the statistical properties of the system. Thus, instead of minimizing the yHx.sup.2 distance value, the less complex zRx.sup.2 distance value can be minimized according to a sequential, term-by-term process described below. The term-by-term process is an algorithm that considers approximate versions of all three terms T.sub.1, T.sub.2, and T.sub.3 attempts to minimize the sum T.sub.1+T.sub.2+T.sub.3 with low computational complexity. The result is an approximate maximum likelihood solution that offers similar performance as compared to an exact maximum likelihood algorithm, while offering the lower computation complexity.
(62) In determining the x.sub.1 and x.sub.2 values that minimize the distance T.sub.1+T.sub.2+T.sub.3 for each possible x.sub.3 value, a sequential, term-by-term process is employed. The term-by-term process for minimizing the distance is used instead of a process that attempts to minimize an entirety of the T.sub.1+T.sub.2+T.sub.3 equation. In the term-by-term process, a first x.sub.3 value is selected. For the first selected x.sub.3 value, an x.sub.2 value is calculated that minimizes the T.sub.2 term of Equation 1. In other words, an x.sub.2 value that minimizes the term |z.sub.2r.sub.22x.sub.2r.sub.23x.sub.3|.sup.2 is calculated for the first selected x.sub.3 value. The T.sub.2 term can be isolated and minimized in this manner because it is a function of only x.sub.2 and x.sub.3, where x.sub.3 has been fixed to the first selected x.sub.3 value. The x.sub.2 value that minimizes the T.sub.2 term may be determined via a slicing procedure, as described below.
(63) Next, for the first selected x.sub.3 value and the sliced x.sub.2 value, an x.sub.1 value is calculated that minimizes the T.sub.1 term of Equation 1. In other words, an x.sub.1 value that minimizes the term |z.sub.1r.sub.11x.sub.1r.sub.12x.sub.2r.sub.13x.sub.3|.sup.2 is calculated for the first selected x.sub.3 value and the sliced x.sub.2 value. The T.sub.1 term can be isolated and minimized, in this manner because it is a function of x.sub.1, x.sub.2, and x.sub.3, where x.sub.3 is fixed and x.sub.2 is the sliced x.sub.2 value previously determined. The x.sub.1 value that minimizes the T.sub.1 term may be determined via a slicing procedure. In one example of the slicing procedures used to determine the x.sub.2 and x.sub.1 values that minimize the T.sub.2 and T.sub.1 terms, respectively, a coordinate value F is calculated, where F is a complex number. Following calculation of F, the distance calculator 182 quantizes F to a nearest constellation point. The nearest constellation point may be used to select the x.sub.2 value that minimizes the T.sub.2 term and the x.sub.1 value that minimizes the T.sub.1 term.
(64) The term-by-term process for minimizing die distance T.sub.1+T.sub.2+T.sub.3 is repeated for all possible x.sub.3 values. In the system using n=6 bits, the alphabet size K is equal to 64, such that there are 64 possible x.sub.3 values. Thus, in such a system with n=6 bits, the minimal distance for T.sub.1+T.sub.2+T.sub.3 is repeated 64 times for each of the possible x.sub.3 values. For each iteration, x.sub.2 and x.sub.1 values that minimize the T.sub.2 and T.sub.1 terms, respectively, are calculated, ultimately resulting in the calculation of T.sub.1+T.sub.2+T.sub.3 distance values. When distance values for all possible values of are calculated, LLR values are calculated at 184 for the data associated with the third spatial stream, x.sub.3. The calculated LLR values are output as shown at 176. The LLR value for a bit b.sub.k.sup.(i) given a received vector y and a known channel matrix H may be represented as:
(65)
where x.sub.k,i is the set of all possible x vectors with b.sub.k.sup.(i)=1, and
(66)
(67) A similar process is followed along the second and first paths 174, 192 to calculate LLR values for data, associated with the second spatial stream (x.sub.2) and the first spatial stream (x.sub.1), respectively. At 168, the channel matrix H 164 is permutated to swap the second and third columns of the channel matrix H 164 prior to QR decomposition. Swapping the columns of H in this manner causes the value x.sub.2 to be pushed down to the bottom of the x vector ([x.sub.1 x.sub.2 x.sub.3].sup.T). Similarly, at 194, the channel matrix H 164 is permutated to swap the first and third columns of the channel matrix H 164 prior to QR decomposition. Swapping the columns of H in this manner causes the value x.sub.1 to be pushed down to the bottom of the x vector ([x.sub.1 x.sub.2 x.sub.3].sup.T). Following permutation of the channel matrix H 164 at 168 and 194, QR decompositions are performed at 170 and 196 on the permutated channel matrices. Mote that similar permutations can also be performed on the columns of R matrix from the QR at 170 or 196 and then perform QR of this permuted R matrix to obtain the LLR values of data associated with second and first spatial streams.
(68) The second path 174 begins at a second matrix transformer 186. In the three spatial stream case, the matrix transformer 186 receives the first, second, and third spatial stream signals as a 31 vector ([y.sub.1 y.sub.2 y.sub.3].sup.T). The second matrix transformer 186 transforms the received y vector according to the relationship z=Q.sup.Hy, resulting in a 31 z vector ([z.sub.1 z.sub.2 z.sub.3].sup.T). Following the z transformation, at 186, a minimum distance value is calculated at 188 for each of the K possible values of x.sub.2 in a similar manner as was described with respect to x.sub.3 at 182. The minimum distance value calculated at 188 is calculated according to the formula:
(69)
(70) The term-by-term process for minimizing the distance T.sub.1+T.sub.2+T.sub.3 of Equation 2 is utilized, and a first x.sub.2 value is selected. For the first selected x.sub.2 value, x.sub.3 and x.sub.1 values that minimize the T.sub.2 and T.sub.1 terms, respectively, are calculated, where the x.sub.3 and x.sub.1 values are calculated in the sequential, term-by-term process described above. The x.sub.3 and x.sub.1 values that minimize the T.sub.2 and T.sub.1 terms may be determined via a slicing procedure. The term-by-term process for minimizing the distance T.sub.1+T.sub.2+T.sub.3 is repeated for all possible x.sub.2 values, thus producing K T.sub.1+T.sub.2+T.sub.3 distance values. When distance values for all possible values of x.sub.2 are calculated, LLR values are calculated at 190 for the data associated with the second spatial stream, x.sub.2. The calculated LLR values are output as shown at 178.
(71) The third path 192 begins at a third matrix transformer 198. In the three spatial stream case, the matrix transformer 198 receives the first, second, and third spatial stream signals as a 31 vector ([y.sub.1 y.sub.2 y.sub.3].sup.T). The third matrix transformer 198 transforms the received y vector according to the relationship z=Q.sup.Hy, resulting in a 31 z vector ([z.sub.1 z.sub.2 z.sub.3].sup.T). Following the z transformation at 198, a minimum distance value is calculated at 200 for each of the K possible values of x.sub.1 in a similar manner as was described with respect to x.sub.3 and x.sub.2. The minimum distance value calculated at 200 is calculated according to the formula:
(72)
(73) The term-by-term process for minimizing the distance T.sub.1+T.sub.2+T.sub.3 of Equation 3 is utilized, and a first x.sub.1 value is selected. For the first selected x.sub.1 value, x.sub.2 and x.sub.3 values that minimize the T.sub.1 and T.sub.2 terms, respectively, are calculated, where the x.sub.2 and x.sub.3 values are calculated in the sequential, term-by-term process described above. The x.sub.2 and x.sub.3 values that minimize the T.sub.1 and T.sub.2 terms may be determined via a slicing procedure. The term-by-term process for minimizing the distance T.sub.1+T.sub.2+T.sub.3 is repeated for all possible x.sub.1 values, thus producing M T.sub.1+T.sub.2+T.sub.3 distance values. When distance values for all possible values of x.sub.1 are calculated, LLR values are calculated at 202 for the data associated with the first spatial stream, x.sub.1. The calculated LLR values are output as shown at 204. The calculated LLR values 176, 178, 204 for the x.sub.3, x.sub.2, and x.sub.1 spatial streams are passed to a decoder as soft information.
(74) Certain approximations for metric computation may be used in the example of
(75)
(76) The term-by-term process and slicing procedure utilized in the matrix decoder 162 of
(77) Although the 3ML algorithm is described in terms of an example using three spatial streams, the techniques described above can be extended to systems having a number of spatial streams that is greater than three and offer such systems improved performance. Further, the approximation may be used to reduce a number of receiving antennas on a device, such that the performance of a conventional system having four receiving antennas may be provided with three receiving antennas when utilizing the above-described approximations. Additionally, as described above, the system may be carried out in a parallel form for reduced latency.
(78) Variations of the above-described 3ML algorithm may be implemented. Such variants may modify the system of
(79) As another example, a 3ML_2PT variant may be used. In the 3ML_2PT variant, for each possible value of x.sub.3 in the constellation, the two nearest sliced x.sub.2 points are stored and used to determine two nearest sliced x.sub.1 points. For example, for a given x.sub.3 value, a sliced, x.sub.21 value that minimizes the T.sub.2 term may be used to determine a sliced x.sub.11 value that attempts to minimize T.sub.1, and a sliced x.sub.22 value that minimizes the T.sub.2 may be used to determine a sliced x.sub.12 value that also attempts to minimize T.sub.1. In this manner, the use of the multiple sliced x.sub.2 points and the multiple sliced x.sub.1 points may be used to better optimize the distance value T.sub.1+T.sub.2+T.sub.3. With the two x.sub.2 values and the two x.sub.1 values, two sets of T.sub.1+T.sub.2+T.sub.3 distance values are computed, and a lower of the two distance values can be used for further processing. The 3ML_2PT variant requires storage of the two sets of T.sub.1+T.sub.2+T.sub.3 distance values and requires additional computations to obtain the additional x.sub.2 and x.sub.1 values.
(80) As another example, a 3ML_4PT variant is an extension of the 3ML_2PT variant. In the 3ML_4PT variant, for each possible value of x.sub.1 in the constellation, the four nearest sliced x.sub.2 points are stored and used to determine four nearest sliced x.sub.1 points. The use of the four sliced x.sub.2 points and the four sliced x.sub.1 points may be used to better optimize the distance value T.sub.1+T.sub.2+T.sub.3. With the lour x.sub.1 values and the four x.sub.1 values, four sets of T.sub.1+T.sub.2+T.sub.3 distance values are computed, and a lowest of the four distance values can be used for further processing. The 3ML_4PT variant requires storage of the four sets of T.sub.1+T.sub.2+T.sub.3 values.
(81) As yet another example, a Mod_3ML variant may be used. In the Mod_3ML variant, the procedures described above with reference to
(82)
(83) In
(84)
where the value z results from the relationship z=Q.sup.Hy and r.sub.11 is a value from an upper triangular matrix
(85)
and where a QR decomposition of a channel matrix H is performed according to the relationship H=QR. The {square root over (N)} value is a constellation-specific scaling factor. The received signal y of block 1 is received at a block. 2 that is used to determine a T.sub.3 value equal to
(86)
In determining the T.sub.3 value in block 2, the x.sub.3 value is fixed, as described above in
(87) For the fixed x.sub.3 value, a term
(88)
of block 3 is sliced to determine the x.sub.2 value that minimizes the T.sub.2 term. The sliced x.sub.2 value is stored in block 4. For the fixed x.sub.3 value and the sliced x.sub.2 value, a term
(89)
of block 5 is sliced to determine the x.sub.1 value that minimizes the T.sub.1 term. As illustrated in
(90) In block 7, a distance value equal to T.sub.1+T.sub.2+T.sub.3 is calculated based on the fixed x.sub.3 value, the sliced x.sub.2 value, and the sliced x.sub.1 value. The T.sub.1+T.sub.2+T.sub.3 distance value may be calculated according to Equation 1, above, for example. The steps described above are repeated in blocks 1-7 for all possible values of x.sub.3 to generate K distance values. The K distance values may be received at a block 8, where the K distance values are further compared and selected to obtain LLRs for the bits corresponding to x.sub.3.
(91) In a hardware implementation, three identical 3ML systems may be used to compute LLRs corresponding to bits in x.sub.3, x.sub.2, and x.sub.1 (e.g., one 3ML system for each spatial stream). The three identical 3ML systems may be configured to operate in parallel, or the 3ML systems may be configured to operate in series. Each of the 3ML systems may include blocks equalizer modules) similar to blocks 1-3 of
(92) The 2ML data detection scheme, which implements a 22 MIMO system, is derived from the 3ML data detection scheme. Specifically, by removing or disabling (e.g., turning off) blocks 5 and 6, the system of
(93)
Thus, r.sub.11 is replaced by R.sub.11, r.sub.33 is replaced by R.sub.22, r.sub.23 is replaced R.sub.12, and r.sub.22 is replaced by a value of 1 in blocks 1, 2, and 3. In block 7, T.sub.1 is set to 0.
(94) Although computation of LLRs corresponding to bits in x.sub.3 is illustrated in
(95) Specifically, the block diagram of
(96)
For every possible value of x.sub.3, a term
(97)
is sliced to determine an optimal x.sub.2 value. Using the fixed x.sub.3 value and the sliced x.sub.2 value, a term
(98)
is sliced to determine an optimal x.sub.1 value. For each bit position j of x.sub.3, a soft metric LLR value is computed as |r.sub.11|D(0)D(1)), where
(99)
(100) In processing data for a second spatial stream x.sub.2, the QR decomposition of a permutated channel, matrix H is performed using a unitary matrix Q.sub.2.sup.H, and the y vector is transformed to obtain a w vector according to
(101)
In the preceding relationship, s.sub.11, s.sub.22, and s.sub.33 are real values. For every possible value of x.sub.2, a term
(102)
is sliced to determine an optimal x.sub.3 value. Using the fixed x.sub.2 value and the sliced x.sub.3 value, a term
(103)
is sliced to determine an optimal x.sub.1 value. For each bit position j of x.sub.2, a soft metric LLR value is computed as |s.sub.11|D(0)D(1)), where
(104)
(105) In processing data for a first spatial stream x.sub.1, the QR decomposition of a permutated channel matrix H is performed using a unitary matrix Q.sub.3.sup.H, and the y vector is transformed to obtain a v vector according to
(106)
In the preceding relationship, and in are real values. For every possible value of x.sub.1, a term
(107)
is sliced to determine an optimal x.sub.3 value. Using the fixed x.sub.1 value and the sliced x.sub.3 value, a term
(108)
is sliced to determine an optimal x.sub.2 value. For each bit position j of x.sub.1, a soft metric LLR value is computed as |t.sub.11|D(0)D(1)) where
(109)
The above-described QR decompositions and matrix transformations to obtain LLR values for x.sub.1, x.sub.2, and x.sub.3 may be performed in parallel or in series.
(110)
(111)
A similar QR decomposition procedure is performed at 370, 396 using a permutated channel matrix, as described in greater detail below. At 368 and 394, the channel matrix H 364 is multiplied by a permutation matrix. In the current example including three spatial streams, the permutation matrices used at 368 and 394 may be, for example,
(112)
such that the columns of the channel matrix H are swapped when multiplied by the permutation matrix, in a modified version of the block diagram 360 of
(113) The matrix decoder 362 executes over three paths 372, 374, 392 that may operate in series or in parallel. The first path 372 calculates LLR values 376 for data values associated with third stream, the second path 374 calculates LLR values 378 for data values associated with a second stream, and the third path 392 calculates LLR values 404 for data values associated with a first stream. These LLR values 376, 378, 404 may be combined and decoded as described above with reference to
(114) The first path 372 begins at a matrix transformer 380. In the three spatial stream case, the matrix transformer 380 receives the first, second, and third signals as a 31 vector ([y.sub.1, y.sub.2, y.sub.3].sup.T). The matrix transformer 380 transforms the y vector according to the relationship z=Q.sup.Hy, resulting in a 31 z vector ([z.sub.1, z.sub.2, z.sub.3].sup.T). Specifically, in the matrix transformer 380, the relationship y=Hx+n may be multiplied by Q.sup.H to obtain z=Q.sup.Hy=Rx+Q.sup.Hn, which is expanded to
(115)
In the three spatial stream system, each data symbol transmitted, x.sub.i (where i1 corresponds to data transmitted on a first spatial stream, i2 corresponds to data transmitted on a second spatial stream, and i3 corresponds to data transmitted on a third spatial stream) maps to n bits {b.sub.1.sup.(i), b.sub.2.sup.(i), . . . , b.sub.3.sup.(i)}, K=2.sup.n is the alphabet size of the underlying modulation, such as binary phase shift keying (BPSK), quadrature amplitude modulation (QAM), etc.
(116) In 3ML approaches, after performing the QR decomposition at 366 and after transforming the received signal vector y into a rotated signal vector z at 380, a Minimum distance value is calculated for each of the K possible values of x3, in a system using n=6 bits, the alphabet size K is equal to 64. In the ML approaches, the minimum distance is calculated according to Equation 1, above, for each possible value. Specifically, x.sub.1 and x.sub.2 values that minimize the distance T.sub.1+T.sub.2+T.sub.3 are determined for each possible x.sub.3 value. However, the complexity of computing the T.sub.1 term is relatively high in the 3ML algorithm, and the computation may require a sliced value x.sub.2, thus increasing the complexity of the calculation.
(117) In the ZF-ML algorithm, a complexity of the distance calculation is reduced by transforming the R matrix and the rotated signal vector z such that one or more elements of the R matrix having complex number values are set equal to zero. Specifically, in the ZF-ML algorithm, to decrease the computational complexity and to avoid having to wait for the sliced value of x.sub.2, the R matrix and the rotated signal vector z are transformed such that an r.sub.12 element of the R matrix is set equal to zero (i.e., r.sub.12=0). Prior to the transformation, the r.sub.12 element is a complex number value, which results in increased complexity in calculating the T.sub.1 terra in Equation 1. Thus, by transforming the R matrix and the rotated signal vector z in a manner that eliminates the complex number value r.sub.12 term from the distance calculation, as described below, a complexity of the distance calculation is reduced.
(118) The transforming of the R matrix and the vector z are shown in a block 381 of
(119)
and the totaled signal sector z is [z.sub.1, z.sub.2, z.sub.3]. In embodiments, after the transforming of the R matrix and the rotated signal vector z, the transformed R matrix is
(120)
and the transformed vector z is [z.sub.1, z.sub.2, z.sub.3]. As can be seen in the transformed R matrix, r.sub.12 is set equal to zero as a result of the transforming. To achieve this, multiplication operations are performed as follows, to calculate z.sub.1, r.sub.11, and r.sub.13, respectively:
(121)
(122) In embodiments, the above multiplication operations are performed using one or more coordinate rotational digital computer (CORDIC) computations. To illustrate the use of such CORDIC computations, reference is made to
(123)
If
(124)
can be treated as cos(), then
(125)
Now, Equation 4 is Row.sub.1(cos()Row.sub.1=sin()e.sup.jRow.sub.2), where =r.sub.12. Accordingly, in embodiments, two angles are extracted and applied as per Equation 4 on the other elements.
(126) In embodiments, the extraction of the two angles and the application of the two angles on other elements is performed using CORDIC computations, as shown in
(127) With reference again to
(128)
and the transformed vector z [z.sub.1, z.sub.2, z.sub.3], a minimum distance value is calculated at 382 for each of the K possible values of x.sub.3. The minimum distance calculated at 382 is computed according to the following formula, where R represents the transformed R matrix and z represents the transformed vector z:
zRx=T.sub.1+T.sub.2+T.sub.3=|z.sub.1r.sub.11x.sub.1r.sub.13x.sub.3|.sup.2+|z.sub.2r.sub.22x.sub.2r.sub.23x.sub.3|.sup.2+|z.sub.3r.sub.33x.sub.3|.sup.2.(Equation 5)
for each possible x.sub.2 value. As seen above, the complexity of calculating the T.sub.1 term is decreased due to the elimination of the complex number value r.sub.12 (i.e., the T.sub.1 term is not dependent on x.sub.2).
(129) It is noted that in the distance metric calculated according to Equation 5 above, the T.sub.1 and T.sub.2 terms have the same complexity, and in embodiments where the terms of the distance metric are divided by r.sub.11 (e.g., as illustrated in
(130) When distance values for all possible values of x.sub.3 are calculated, LLR values are calculated at 384 for the data associated with the third spatial stream, x.sub.3. The calculated LLR values are output as shown at 376. A similar process is followed along the second and first paths 374, 392 to calculate LLR values for data associated with the second spatial stream (x.sub.2) and the first spatial stream (x.sub.1), respectively. At 368, the channel matrix H 364 is permutated to swap the second and third columns of the channel matrix H 364 prior to QR decomposition. Swapping the columns of H in this manner causes the value x.sub.1 to be pushed down to the bottom of the x vector ([x.sub.1 x.sub.2 x.sub.3].sup.T). Similarly, at 394, the channel matrix H 364 is permutated to swap the first and third columns of the channel matrix H 364 prior to QR decomposition. Swapping the columns of H in this manner causes the value x.sub.1 to be pushed down to the bottom of the x vector ([x.sub.1 x.sub.2 x.sub.3].sup.T). Following permutation of the channel matrix H 364 at 368 and 394, QR decompositions are performed at 370 and 396 on the permutated channel matrices. Note that similar permutations can also be performed on the columns of R matrix from the QR at 370 or 396 and then perform QR of this permuted R matrix to obtain the LLR values of data associated with second and first spatial streams
(131) The second path 374 begins at a second matrix transformer 386. In the three spatial stream case, the matrix transformer 386 receives the first, second, and third spatial stream signals as a 31 vector ([y.sub.1, y.sub.2, y.sub.3].sup.T). The second matrix transformer 386 transforms the received y vector according to the relationship z=Q.sup.Hy, resulting in a 31 z vector ([z.sub.1, z.sub.2, z.sub.3].sup.T). Following the z transformation, at 387, the R matrix and z vector are transformed in a similar manner as was described above with reference to step 381. Following these transformations, a minimum distance value is calculated at 388 for each of the K possible values of x.sub.2 in a similar manner as was described with respect to x.sub.3 at 382. The minimum distance value calculated at 388 is calculated according to the formula:
zRx=T.sub.1+T.sub.2+T.sub.3=|z.sub.1r.sub.11x.sub.1r.sub.13x.sub.2|.sup.2+|z.sub.2r.sub.22x.sub.3r.sub.23x.sub.2|.sup.2+|z.sub.3r.sub.33x.sub.2|.sup.2.
When distance values for all possible values of x.sub.2 are calculated, LLR values are calculated at 390 for the data associated with the second spatial stream, x.sub.2. The calculated LLR values are output as shown at 378.
(132) The third path 392 begins at a third matrix transformer 398. In the three spatial stream case, the matrix transformer 398 receives the first, second, and third spatial stream signals as a 31 vector ([y.sub.1, y.sub.2, y.sub.3].sup.T). The third matrix transformer 398 transforms the received y vector according to the relationship z=Q.sup.Hy, resulting in a 31 z vector ([z.sub.1, z.sub.2, z.sub.3].sup.T). Following the z transformation, at 399, the R matrix and z vector are transformed in a similar manner as was described above with reference to steps 381 and 387. Following these transformations, a minimum distance value is calculated at 400 for each of the K possible values of x.sub.1 in a similar manner as was described with respect to x.sub.3 and x.sub.2. The minimum distance value calculated at 400 is calculated, according to the formula:
zRx=T.sub.1+T.sub.2+T.sub.3=|z.sub.1r.sub.11x.sub.2r.sub.13x.sub.1|.sup.2+|z.sub.2r.sub.22x.sub.3r.sub.23x.sub.1|.sup.2+|z.sub.3r.sub.33x.sub.1|.sup.2.
When distance values for all possible values of x.sub.1 are calculated, LLR values are calculated at 402 for the data associated with the first spatial stream, x.sub.1. The calculated LLR values are output as shown at 404. The calculated LLR values 376, 378, 404 for the x.sub.3, x.sub.2, and x.sub.1 spatial, streams are passed to a decoder as soft information, in some embodiments.
(133) Although the ZF-ML algorithm is described above in terms of an example using three spatial streams, this algorithm is applicable to systems having a number of spatial streams that is greater than or equal to three. To illustrate this, consider an example utilizing M spatial streams, where M is greater than or equal to three. In this example, a received signal model is as follows:
(134)
To obtain LLR for x.sub.M, a QR decomposition is applied on [h.sub.1 h.sub.2 . . . h.sub.M], resulting in
(135)
(136) According to the ZF-ML algorithm, to reduce the complexity of the computation, any of the non-diagonal element r.sub.ij,j>i are set equal to zero. The r.sub.ij,j>i can be set equal to zero using an operation
(137)
which can be implemented using CORDIC computations similar to those described above with reference to
(138) The ZF-ML data detection technique is implemented, in embodiments, by (i) modifying operations performed by one or more of the 3ML equalizer modules (e.g., the 3ML equalizer modules illustrated in
(139) In
(140)
where the value z results from the relationship z=Q.sup.Hy and r.sub.11 is a value from the transformed matrix
(141)
and where a QR decomposition of a channel matrix B is performed according to the relationship H=QR. The value is a constellation-specific scaling factor. The received signal y of block 1 is received at a block 2 that is used to determine a T.sub.3 value equal to
(142)
In embodiments, in determining the T.sub.3 value in block 2, the x.sub.3 value is fixed. For example, the x.sub.3 value is initially fixed to a first possible value of x.sub.3, and rising the fixed first possible value of x.sub.3, x.sub.2 and x.sub.1 values that minimize the T.sub.2 and T.sub.1 terms, respectively, are determined.
(143) Continuing in
(144)
of block 3 is used to determine the x.sub.2 value that minimizes the T.sub.2 term. The x.sub.2 value is stored in block 4. For the fixed x.sub.3 value, a term
(145)
of block 5 is used to determine the x.sub.1 value that minimizes the T.sub.1 term. The x.sub.1 value is stored in block 6. As can be seen in the figure, the term
(146)
of block 5 does not include the r.sub.12 term. As described above, using the ZF-ML algorithm, the r.sub.12 term is eliminated from the distance calculation, thus resulting in reduced complexity. To achieve the r.sub.12=0, a pre-processing block 902 is utilized in some embodiments. The R matrix and the z vector may be considered inputs to the system of
(147) It is noted that according to the ZF-ML algorithm, the output of block 4 (i.e., the x.sub.2 value) is not required for block 5. Thus the ZF-ML algorithm relaxes a time constraint because blocks 3 and 4, and blocks 5 and 6 can be computed in parallel along with block 2. Thus, block 7 receives x.sub.1, x.sub.2, and x.sub.3 at a same tune (or approximately the same time), in some embodiments.
(148) In block 7, a distance value equal to T.sub.1+T.sub.2+T.sub.3 is calculated based on the x.sub.3, x.sub.2, and x.sub.1 values. The T.sub.1+T.sub.2+T.sub.3 distance value may be calculated according to Equation 5, above, for example. In embodiments, the steps described above are repeated in blocks 1-7 for all possible values of x.sub.3 to generate K distance values. The K distance values may be received at a block 8, where the K distance values are further compared and selected to obtain LLRs for the bits corresponding to x.sub.3. Although computation of LLRs corresponding to bits in x.sub.2 is illustrated in
(149)
(150)
(151) The device 1102 may communicate with mass data storage 1190 that stores data in a nonvolatile manner. Mass data storage 1190 may include optical or magnetic storage devices, for example hard disk drives HDD or DVD drives. The device 1102 may be connected to memory 1194 such as RAM, ROM, low latency nonvolatile memory such as Sash memory, or other suitable electronic data storage. The device 1102 may also support connections with a WLAN via the WLAN network, interface 1196.
(152) This written description uses examples to disclose the invention, including the best mode, and also to enable a person skilled in the art to make and use the invention. It should be noted that the systems and methods described herein may be equally applicable to other frequency modulation encoding schemes. The patentable scope of the invention may include other examples.
(153) It should be understood that as used in the description herein and throughout the claims that follow, the meaning of a, an, and the includes plural reference unless the context clearly dictates otherwise. Also, as used in the description herein and throughout the claims that follow, the meaning of in includes in and on unless the context clearly dictates otherwise. Further, as used in the description herein and throughout the claims that follow, the meaning of each does not require each and every unless the context clearly dictates otherwise. Finally, as used in the description herein and throughout the claims that follow, the meanings of and and or include both the conjunctive and disjunctive and may be used interchangeably unless the context expressly dictates otherwise; the phrase exclusive of may be used to indicate situations where only the disjunctive meaning may apply.