Certain embodiments of the invention relate to wireless communications. More specifically, certain embodiments of the invention relate to a method and system for subspace beamforming for near capacity multiple input multiple output (MIMO) performance.
In multiple input multiple output (MIMO) wireless systems, multiple data streams may be transmitted simultaneously using a plurality of transmitting antennas. A MIMO receiver may utilize a plurality of receiving antennas to decouple, and detect individual data streams. Two predominant methods for MIMO transmission include singular value decomposition (SVD), and layered space-time (LST) processing, also known as successive interference cancellation (SIC).
SVD may use beamforming in conjunction with a transmitter antenna array and receiver antenna array to create virtual channels, or eigen-channels, through which multiple data streams may be sent without interfering with one another. LST/SIC may use receiver antennal array processing to detect the multiple data streams, one stream at a time. For each detection “layer,” the interference from yet undetected streams may be nulled out, while the interference from already detected streams may be cancelled, or subtracted, out.
The eigen-channels in SVD may have highly unequal signal to noise ratios (SNR), depending on the eigen-spread of the MIMO channel matrix. SVD may also rely upon adaptive modulation, or adaptive bit loading, to achieve greater data transfer rates for eigen-channels associated with higher SNR values, while simultaneously supporting lower data transfer rates for eigen-channels associated with lower SNR values. SVD may also suffer performance loss, by not achieving the peak theoretical data transfer rate aggregated among the eigen-channels when a broad range of modulation types are not available. For example, if a maximum data transfer rate associated with an eigen-channel requires a 1024 QAM modulation type, the maximum data transfer rate may not be achievable if the required modulation type is not available to be utilized.
LST/SIC approaches may suffer performance losses as a result of error propagation. For example, if a current layer is detected in error, the error may propagate to other layers increasing the probability that subsequent layers may also be detected in error. LST/SIC may require stream re-ordering to detect data streams with higher SNR values first to minimize error propagation. Some methods, such as vertical LST (VLST) may provide error protection through coding of each data stream. Based on the coding, decisions may be made subsequent to decoding to subtract out interference.
Alternatively, preceding based on dirty paper theory, for example Tomlinson-Harashima precoding (THP), may be utilized to pre-cancel interference at the transmitter without requiring the signals to be transmitted with greater levels of transmitted radiated power. The THP approach may require channel knowledge at the transmitter.
Geometric mean decomposition (GMD) may be based on beamforming and LST/SIC at a transmitter, by utilizing THP for example, or based on LST/SIC at a receiver, by utilizing VLST for example. SNRs for each of a transmitted plurality of data streams may be about equal when utilizing GMD. Consequently, adaptive bit loading may not be required as may be the case with SVD. GMD may also not require reordering of data streams as may be the case with LST/SIC.
While a combination of GMD beamforming at a MIMO transmitter and VLST at a MIMO receiver may be utilized to achieve desirable performance levels within theoretical limitations, the latency and/or complexity associated with implementation of successive interference cancellation (SIC) methods may impose limitations on the design of MIMO receivers. IEEE 802.11 specifications may comprise requirements for structures utilized for coding data transmitted via a wireless communication channel, and for packet detection delay limits that establish a time duration between a time instant when one or more signals are received by a MIMO receiver, and a subsequent time instant when data transmitted via the one or more signals is detected at the MIMO receiver.
A MIMO transmitter may concurrently transmit a plurality of NTX signals, xi, from a plurality of NTX transmitting antennas. The plurality of transmitted signals (xi) may propagate across a communication medium, which is characterized by a channel estimate matrix (H), and be received at a MIMO receiver as a plurality of NRX signals, (yi) via a plurality of NRX receiving antennas. Each signal xi may be generated based on data from a corresponding spatial stream or space-time stream. Each of the transmitted signals xi may comprise a sequence of symbols from the corresponding spatial stream (or space-time stream), each of which represents one or more data bits (the data may be encoded by utilizing an error detection and/or correction coding technique such as binary convolutional coding (BCC)). The number of bits represented by each symbol is determined based on a modulation type. The symbol may be generated by selecting a constellation point within a constellation map. The number of constellation points in the constellation map is also determined based on the constellation map. Typically the number of constellation points in the constellation map is equal to 2b(sym), where b(sym) represents the number of bits represented by each symbol. For example, in a 64-QAM (quadrature amplitude modulation) constellation map, there are 64 constellation points, where each constellation point represents a distinct combination of 6 bit values (with binary values ranging from 000000 to 111111). The variable xi may represent the value of each signal transmitted from the ith transmitting antenna at a given time instant. Each transmitting antenna may utilize a distinct modulation type when transmitting signals xi or one or more transmitting antenna may utilize the same modulation type. Symbol values xi transmitted by each transmitting antenna may be determined independently from symbol values concurrently transmitted by other transmitting antennas.
The received signals yi may also include noise components (ni) which reflects signal noise induced during signal propagation across the communication medium. The relationship between the vector of signals xi transmitted by the MIMO transmitter (X) and the vector of signals yi received by the MIMO receiver (Y) may be represented as follows:
Y=H X+N [1]
The MIMO receiver computes the channel estimate matrix H, either based on preamble information received in conjunction with the received signals xi or based on information received from the MIMO transmitter. The MIMO receiver then attempts to determine estimated values ({circumflex over (x)}i), which likely reflect the values xi transmitted by the MIMO transmitter. A detector in a MIMO receiver determines the estimated values {circumflex over (x)}i by selecting constellation points from among the 2b(sym) constellation points in the constellation map for xi (CM), which provide the greatest probability that xi={circumflex over (x)}i. The relationship may be represented as follows:
A detector at a MIMO receiver, which determines values {circumflex over (x)}i that satisfy equation [2], is referred to as a maximum likelihood (ML) detector.
The computational complexity of ML detection may grow exponentially with the number of spatial streams (NSS) and may be represented as
where
represents the multiplicative product of values j(i) for values of i from 1 to NSS and b(symi) represents the number of bits represented by symbols in the ith spatial stream. Due to computational complexity, it may be impractical to implement ML detection in some conventional systems for values NSS>2 for 64-QAM. Furthermore, the computational task of computing beamforming factors at a MIMO transmitter to be utilized with ML detection at a MIMO receiver may be non-deterministic polynomial-time hard (NP-hard).
Further limitations and disadvantages of conventional and traditional approaches will become apparent to one of skill in the art, through comparison of such systems with some aspects of the present invention as set forth in the remainder of the present application with reference to the drawings.
A system and/or method for subspace beamforming for near capacity multiple input multiple output (MIMO) performance, substantially as shown in and/or described in connection with at least one of the figures, as set forth more completely in the claims.
These and other advantages, aspects and novel features of the present invention, as well as details of an illustrated embodiment thereof, will be more fully understood from the following description and drawings.
Certain embodiments of the invention relate to a method and system for subspace beamforming for near capacity multiple input multiple output (MIMO) performance. Subspace beamforming enables a MIMO transmitter to generate a vector of beamformed signals (xi) such that received signals (yi) may be processed at a MIMO receiver (using, for example, a filter) to generate signals (ri).
In one aspect of the invention, the beamformed signals (xi) may be generated based on Givens rotation angles (θf, where f is an index value), where the rotation angle θf is computed at the MIMO transmitter to maximize the Euclidean distance between the symbol values for signal pairs xj and xk (selected from the plurality of signals xi) within a given constellation map. Increasing the Euclidean distance between signal pairs xj and xk may increase the data-carrying capacity of RF channels (as measured in transmitted bits per second) in a MIMO communication system by increasing the probability that a ML detector in a MIMO receiver will decode filtered signals ri and generate estimated symbol values {circumflex over (x)}j and {circumflex over (x)}j such that {circumflex over (x)}j=xj and {circumflex over (x)}k=xk. The MIMO transmitter may communicate the computed rotation angle θf to the MIMO receiver.
In another aspect of the invention, the rotation angle θf may be computed at the MIMO transmitter to minimize a bit error rate (BER) for signals (yi) received at the MIMO receiver. The rotation angle may be computed as a function of the channel estimate matrix (H), the constellation type selected to generate symbol values for xj and xk and based on the noise power of the channel noise (N0). A singular value decomposition method may be utilized to compute a set of eigenvalues (si) based the matrix H. The ratio of eigenvalues sj and sk (which correspond to a pair of signals xj and xk) may enable computation of a condition number. The eigenvalues sj and sk and the noise power value N0 may enable the computation of a signal to noise ratio (SNR). In various embodiments of the invention, the rotation angle θf may be computed as a function of computed condition number and SNR values. The MIMO transmitter may communicate the computed rotation angle θf to the MIMO receiver.
The exemplary wireless transceiver station 302 comprises a processor 312, a memory 314, an encoder 313 a modulator 315 a transmitter 316, a demodulator 317, a decoder 319, a receiver 318, a transmit and receive (T/R) switch 320 and an antenna matrix 322. The antenna matrix 322 may enable selection of one or more of the antennas 332a . . . 332n for transmitting and/or receiving signals at the wireless transceiver station 302. The T/R switch 320 may enable the antenna matrix 322 to be communicatively coupled to the transmitter 316 or receiver 318.
The transmitter 316 may enable the generation of signals, which may be transmitted via the selected antennas 332a . . . 332n. The encoder 313 may receive uncoded (or raw) data from the processor and/or memory and encode the data (for example, using binary convolutional coding (bcc)). The modulator 315 may receive encoded data from the encoder 313 and convert binary data to a data symbol representation based on one or more selected modulation types. The modulator 315 may generate one or more spatial streams to transmit the data symbols to the transmitter 316.
The receiver 318 may enable the processing of signals received via the selected antennas 332a . . . 332n. The demodulator 317 may receive data symbols from the receiver 318 and generate a binary representation of the received symbols based on one or more selected modulation types. The binary data may be sent to a decoder 319, which may decode the binary data to generate uncoded data. The uncoded binary data may be sent from the decoder 319 to the processor 312 and/or memory 314.
The beamforming block 108 may receive a plurality of Nss spatial streams, x1, x2, . . . , and xNss and output a plurality of Ntx transmit chain signals tx1, tx2, . . . , and txNtx. Each of the spatial streams may be generated by a modulator block 315 shown in
The antennas 126a, 126b, . . . , and 126n may receive signals, y1, t2, . . . , and yNrx, respectively, which propagate via the communication medium 104. The transmitted signal vector XT may be altered as it propagates through the communication medium 104. The altered signals may be received at the MIMO receiver as a received signal vector Y. The alteration of the transmitted signals may be represented by channel estimates h[i,j]. As shown in
The signal, tx1, which is transmitted by antenna 112a and received at antenna 126b may be altered based on a channel estimate h[2,1]. The signal, tx2, which is transmitted by antenna 112b and received at antenna 126b may be altered based on a channel estimate h[2,2]. The signal, txNtx, which is transmitted by antenna 112n and received at antenna 126b may be altered based on a channel estimate h[2,Ntx].
The signal tx1 which is transmitted by antenna 112a and received at antenna 126n may be altered based on a channel estimate h[Nrx,1]. The signal tx2 which is transmitted by antenna 112b and received at antenna 126n may be altered based on a channel estimate h[Nrx,2]. The signal txNtx which is transmitted by antenna 112n and received at antenna 126n may be altered based on a channel estimate h[Nrx,Ntx].
At the MIMO receiver 106, a plurality of signals, y1, y2, . . . , and yNrx, may be received by antennas 126a, 126b, . . . , and 126n. The signals received at each antenna may be represented by the following system of equations:
y
1
=h[1,1]·tx1+h[1,2]·tx2+ . . . +h [1,Ntx]·txNtx+n1
y
2
=h[2,1]·tx1+h[2,2]·tx2+ . . . +h[2,Ntx]·txNtx+n2
y
Ntx
=h[Nrx, 1]·tx1+h[Nrx,2]·tx2+ . . . +h[Nrx,Ntx]·txNtx+nNrx [3]
The received signals may be represented by a column vector Y.
The filter block 124 may process the received signals y1, y2, . . . , and yNrx and generate filtered signals r1, r2, . . . , and rNrx. The decoder block may enable the MIMO receiver 106 to generate a plurality of estimated signal values {circumflex over (x)}1, {circumflex over (x)}2, and {circumflex over (x)}Nss based on the filtered signals r1, r2, . . . , and rNrx. Each of the estimated symbol values {circumflex over (x)}i may be represented by one or more bits b1, b2, . . . , and bsym(i), wherein each binary bit value may be determined by the detector and decoder block 122.
The decoder 106 may comprise functionality not shown in
In various embodiments of the invention, the transmitter 102 shown in
The receiver 106 shown in
In various embodiments of the invention, an SVD representation of the channel estimate matrix may be generated as follows:
H=U S V1H [4]
where S is a diagonal singular matrix of eigenvalues of H, U a matrix of “output” basis vectors of H and V1 is a matrix of “input” basis vectors of H. V1H represents a complex conjugate transform version of the matrix V1. In an exemplary 4×4 MIMO communication system, in which Ntx=4 at the MIMO transmitter and Nrx=4 at the MIMO receiver, the matrix S may comprise a set of four (4) eigenvalues: s1, s2, s3 and s4 (where si≧sj for i<j). An eigenvalue si may be located at the ith row in the matrix S.
In various embodiments of the invention, the eigenvalues may be rearranged in the matrix S such that eigenvalues s1 and s4 are located at adjacent rows in the matrix S and s2 and s3 located at adjacent rows in S. The rearranged matrix may be referred to as SR. Furthermore, the matrix SR may be represented as a block diagonal matrix, which comprises two (2) matrices s1 and s2 as shown below:
where:
In various embodiments of the invention, a beamforming block 108 may generate transmitted signals tx1, tx2, . . . , and txNtx by utilizing Givens rotation. Givens rotation enables rotation of the constellation maps utilized for generating symbol values x1, x2, . . . , and xNss. In various embodiments of the invention, one or more rotation angles (θf) may be computed at a MIMO transmitter that increase the probability that xi={circumflex over (x)}i at a MIMO receiver.
In an exemplary embodiment of the invention, the beamforming block 108 may generate transmitted signals (txi) based on spatial stream signals (xi) as shown below:
X
T
=V
1
G(θ)X [7]
where XT represents the vector of transmitted signals txi, X represents the vector of spatial stream signals xi and G(θ) represents a Givens rotation matrix. The Givens rotation matrix is defined as a function of the rotation angle θ. The signal vector received signal vector at the MIMO receiver may be represented as follows:
Y=H X
T
+N [8]
Using the definition of XT from equation [7], equation [8] may be represented as follows:
Y=H V
1
G(θ)X+N [9]
Using an SVD representation of H, equation [9] may be represented as follows:
Y=U S
R
V
1
H
V
1
G(θ)X+N [10]
where SR represents a rotated version of S (as presented in equation [5]). Based on the unitary property of V1, V1H=V1−1. Consequently, equation [10] may be represented as follows:
Y=U S
R
G(θ)X+N [11]
The MIMO receiver may utilize the filter block 124 to filter the received signal vector Y. The filtered signal vector (R) may be represented as follows:
R=U
H
Y=U
H U SR G(θ)X+UH N [12]
where the filtering function of the filter block 124 may be represented by the matrix UH. Based on the unitary property of H, equation [12] may be represented as follows:
R=S
R
G(θ)X+UH N [13]
The matrix G(θ) can be represented as a block diagonal matrix as follows:
where:
Based on equations [6] and [14], equation [13] may be represented as follows:
In one aspect of the invention, the rotation angle θf may be computed such to maximize the minimum Euclidean distance between pairs of symbol values xj and xk as represented in the following equation:
Based on equation [18], rotation angles θ1 and θ2 may be computed as represented in the following equations:
θ1=max min ∥S1 G(θ1)(x1−x2)∥ [20a]
θ2=max min ∥S2 G(θ2)(x3−x4)∥ [20b]
where ∥X∥represents the Frobenius norm of X.
The rotation angle θf as represented in equations [20a] and [20b] may be computed as a function of the eigenvalues si in the matrix Si. The eigenvalues si may be determined based on the channel estimate matrix H. In this regard, the rotation angle θf may be computed as a function of H. The computed value of the rotation angle θf may also be influenced by the constellation size. For example, increasing the constellation size typically results in each constellation point being closer to adjacent constellation points. The changing proximity of constellation points in the constellation maps of different modulation types may result in adjustments to the computed rotation angle θf as computed in equations [20a] and [20b].
In another aspect of the invention, the rotation angle may be computed to minimize the uncoded BER for uncoded bits represented by pairs of symbol values xj and xk. The rotation angle θf may be computed as a function of a condition number for matrix Sf and an SNRf. Rotation angles θ1 and θ2 may be computed as represented in the following equations:
where the condition number is represented by the ratio of eigenvalues
and the SNR is represented by the ratio
and N0 represents noise power for channel noise (represented by the vector N in equation [16]). The eigenvalues si may be determined based on the channel estimate matrix H. In this regard, the rotation angle θf is computed as a function of H.
The value for the rotation angle θf computed in equations [21a] and [21b] may also be influenced by the constellation size of the modulation type utilized for generating symbol values xj and xk. For example, increasing constellation size typically corresponds to an increasing number of uncoded bits that are represented in each symbol, which in turn may increase the BER. Consequently, the value of the rotation angle θf may be adjusted to minimize the expected BER at the MIMO receiver.
In various embodiments of the invention, rotation angle values may be computed by a processor 312 for a range of condition number values and/or modulation types and stored as lookup tables (LUT) in memory 314.
In instances when j=N_mod, step 714 may determine that the current modulation type is the last modulation type for which rotation angle values is to be computed for the LUT, in which case the rotation angle computation may end. In instance where j≠N_mod at step 714, in step 716, the modulation index value may be incremented. Step 708 may follow step 716 where the next modulation type may be selected.
In instances when j=N_mod, step 818 may determine that the current modulation type is the last modulation type for which rotation angle values is to be computed for the LUT, in which case the rotation angle computation may end. In instance where j≠N_mod at step 818, in step 820, the modulation index value may be incremented. Step 808 may follow step 820 where the next modulation type may be selected.
In various embodiments of the invention, subspace beamforming for near capacity MIMO performance is not limited to MIMO systems, which utilize singular value decomposition (SVD). Various embodiments of the invention may also be practiced in MIMO systems, which utilize other matrix decomposition methods such as geometric mean decomposition (GMD), for example.
Aspects of a system for subspace beamforming for near capacity MIMO performance may include a MIMO transmitter 102 that computes one or more rotation angle values (θf) based on a channel estimate matrix (H). In instances when each rotation angle is computed based on a Euclidean distance criterion, each value θf may also be computed based on a computed Euclidean distance. Alternatively, in instances when each rotation angle is computed based on a bit error rate (BER) criterion, each value θf may also be computed based on a signal noise power level (N0). A plurality of spatial stream signals (xi) may be generated utilizing one or more constellation types. The constellation map for each constellation type may be rotated based on a corresponding value θf. A plurality of transmit chain signals (txi) may be generated based on the signals xi and transmitted via a communication medium characterized by the matrix H. A plurality of eigenvalues (sj) may be computed based on the matrix H. Pairs of eigenvalues (sj and sk) may be grouped such that the multiplicative product for each eigenvalue pair is approximately equal.
When each rotation angle value is computed based on a Euclidean distance criterion, a pair of spatial stream signals (xi and xl), corresponding to each eigenvalue pair, may be identified. The Euclidean distance value may be computed based on the constellation map for the identified pair of spatial streams signals xi and xl.
When each rotation angle value is computed based on a BER criterion, each rotation angle may be computed based on the ratio
(from which a condition number may be computed) and on the ratio
(from which a signal to noise ratio (SNR) may be computed). A value for N0 may be estimated based on the communication medium. Each value θf may be determined based on an estimated BER for reception at a MIMO receiver 106 of the transmitted signals txi. Each of the received signals may be represented by yi. The estimated BER may be computed based on maximum likelihood (ML) detection at the MIMO receiver 106.
The computed values θf may be retrieved from a lookup table (LUT). The address at which a selected value θf is located may be determined based on a modulation type utilized for generating one or more spatial stream signals xi. When each value θf is computed based on a Euclidean distance criterion, the LUT address may also be determined based on a condition number. The condition number may be computed based on the eigenvalues that correspond to an identified pair of spatial stream signals. When each value θf is computed based on a BER criterion, the LUT address may be determined based on the condition number and on an SNR value. The SNR value may be computed based on the eigenvalues and on N0.
Another embodiment of the invention may provide a machine and/or computer readable storage and/or medium, having stored thereon, a machine code and/or a computer program having at least one code section executable by a machine and/or a computer, thereby causing the machine and/or computer to perform the steps as described herein for subspace beamforming for near capacity multiple input multiple output (MIMO) performance
Accordingly, the present invention may be realized in hardware, software, or a combination of hardware and software. The present invention may be realized in a centralized fashion in at least one computer system, or in a distributed fashion where different elements are spread across several interconnected computer systems. Any kind of computer system or other apparatus adapted for carrying out the methods described herein is suited. A typical combination of hardware and software may be a general-purpose computer system with a computer program that, when being loaded and executed, controls the computer system such that it carries out the methods described herein.
The present invention may also be embedded in a computer program product, which comprises all the features enabling the implementation of the methods described herein, and which when loaded in a computer system is able to carry out these methods. Computer program in the present context means any expression, in any language, code or notation, of a set of instructions intended to cause a system having an information processing capability to perform a particular function either directly or after either or both of the following: a) conversion to another language, code or notation; b) reproduction in a different material form.
While the present invention has been described with reference to certain embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the present invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the present invention without departing from its scope. Therefore, it is intended that the present invention not be limited to the particular embodiment disclosed, but that the present invention will include all embodiments falling within the scope of the appended claims.
This application makes reference, claims priority to, and claims the benefit of U.S. Application Ser. No. 61/023,732 filed Jan. 25, 2008 and U.S. Application Ser. No. 61/096,405 filed Sep. 12, 2008, which is hereby incorporated herein by reference in its entirety. This application makes reference to U.S. application Ser. No. 11/494,962 filed on Jul. 28, 2006, which is hereby incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61023732 | Jan 2008 | US | |
61096405 | Sep 2008 | US |