CQI AND RANK PREDICTION FOR LIST SPHERE DECODING AND ML
MIMO RECEIVERS
CROSS-REFERENCE
[0001] This application is a continuation-in-part of U.S. Patent Application entitled "CQI AND RANK PREDICTION FOR LIST SPHERE DECODING AND MIMO ML RECEIVERS," filed on May 25, 2006, having Attorney Docket No. 050695, which claims the benefit of U.S. Provisional Application Serial No. 60/686,646 entitled "CQI AND RANK PREDICTION IN LIST SPHERE DECODING," filed on June 1, 2005, and U.S. Provisional Application Serial No. 60/691,722 entitled "METHOD OF LIST SPHERE DECODING FOR MIMO RECEIVERS," filed on June 16, 2005. The entireties of these applications are incorporated herein by reference.
BACKGROUND
I. Field
[0002] The following description relates generally to wireless communications, and more particularly to performing rank calculation in a non-linear receiver employed in a wireless communication environment.
II. Background
[0003] Wireless communication systems have become a prevalent means by which a majority of people worldwide has come to communicate. Wireless communication devices have become smaller and more powerful in order to meet consumer needs and to improve portability and convenience. The increase in processing power in mobile devices such as cellular telephones has lead to an increase in demands on wireless network transmission systems. Such systems typically are not as easily updated as the cellular devices that communicate there over. As mobile device capabilities expand, it can be difficult to maintain an older wireless network system in a manner that facilitates fully exploiting new and improved wireless device capabilities. [0004] More particularly, frequency division based techniques typically separate the spectrum into distinct channels by splitting it into uniform chunks of bandwidth, for example, division of the frequency band allocated for wireless communication can be split into 30 channels, each of which can carry a voice conversation or, with digital service, carry digital data. Each channel can be assigned to only one user at a time.
One known variant is an orthogonal frequency division technique that effectively partitions the overall system bandwidth into multiple orthogonal subbands. These subbands are also referred to as tones, carriers, subcarriers, bins, and/or frequency channels. Each subband is associated with a subcarrier that can be modulated with data. With time division based techniques, a band is split time-wise into sequential time slices or time slots. Each user of a channel is provided with a time slice for transmitting and receiving information in a round-robin manner. For example, at any given time t, a user is provided access to the channel for a short burst. Then, access switches to another user who is provided with a short burst of time for transmitting and receiving information. The cycle of "taking turns" continues, and eventually each user is provided with multiple transmission and reception bursts.
[0005] Code division based techniques typically transmit data over a number of frequencies available at any time in a range. In general, data is digitized and spread over available bandwidth, wherein multiple users can be overlaid on the channel and respective users can be assigned a unique sequence code. Users can transmit in the same wide-band chunk of spectrum, wherein each user's signal is spread over the entire bandwidth by its respective unique spreading code. This technique can provide for sharing, wherein one or more users can concurrently transmit and receive. Such sharing can be achieved through spread spectrum digital modulation, wherein a user's stream of bits is encoded and spread across a very wide channel in a pseudo-random fashion. The receiver is designed to recognize the associated unique sequence code and undo the randomization in order to collect the bits for a particular user in a coherent manner. [0006] A typical wireless communication network (e.g., employing frequency, time, and code division techniques) includes one or more base stations that provide a coverage area and one or more mobile (e.g., wireless) terminals that can transmit and receive data within the coverage area. A typical base station can simultaneously transmit multiple data streams for broadcast, multicast, and/or unicast services, wherein a data stream is a stream of data that can be of independent reception interest to a mobile terminal. A mobile terminal within the coverage area of that base station can be interested in receiving one, more than one or all the data streams carried by the composite stream. Likewise, a mobile terminal can transmit data to the base station or another mobile terminal. Such communication between base station and mobile terminal or between mobile terminals can be degraded due to channel variations and/or interference power variations.
[0007] Conventional wireless systems do not provide support adaptive communication techniques in non-linear receivers due to computational complexity, processing overhead, and the like. Thus, there exists a need in the art for a system and/or methodology of improving throughput in such wireless network systems.
SUMMARY
[0008] The following presents a simplified summary of one or more embodiments in order to provide a basic understanding of such embodiments. This summary is not an extensive overview of all contemplated embodiments, and is intended to neither identify key or critical elements of all embodiments nor delineate the scope of any or all embodiments. Its sole purpose is to present some concepts of one or more embodiments in a simplified form as a prelude to the more detailed description that is presented later.
[0009] In accordance with one or more embodiments and corresponding disclosure thereof, various aspects are described in connection with performing rank selection and CQI computation for a non-linear receiver, such as an ML-MMSE receiver, in a MEMO wireless communication environment. According to one aspect, a method of calculating rank in a non-linear receiver in a user device in a wireless communication environment can comprise receiving a transmission signal at a nonlinear receiver, receiving a transmission signal at a non-linear receiver, generating submatrices from a transmission channel over which the transmission signal is received, performing a Q-R decomposition on the submatrices and deriving respective upper triangle matrices, determining an effective SNR for one or more possible transmission ranks, determining a channel capacity metric for all possible ranks of the transmission signal, and selecting a rank that maximizes channel capacity for transmissions. The non-linear receiver can be a maximum likelihood (ML) minimum mean-squared error (MMSE) non-linear receiver, and the wireless communication environment can be a multiple input-multiple output (MIMO) single code word (SCW) wireless communication environment.
[0010] Another aspect relates to a wireless communication apparatus that facilitates calculating rank in a non-linear receiver in a user device in a wireless communication environment can comprise a non-linear receiver that receives a signal with multiple layers, a memory that stores information related to rank calculation algorithms, and a processor coupled to the memory that employs a rank calculation
algorithm to determine an optimum rank for the received signal, generates submatrices from a transmission channel over which the transmission signal is received, performs a Q-R decomposition on the submatrices, derives respective upper triangle matrices, and determines an effective SNR for one or more possible transmission ranks. The nonlinear receiver can utilize a list-sphere decoding protocol to decode the received signal. The apparatus can further comprise a capacity mapping component that evaluates transmission capacity for at least one submatrix of at least one received layer, and a rank evaluation component that identifies an optimal rank having a highest average transmission capacity. Additionally, the processor can generate a CQI report for transmission over a reverse link control channel and can append a 2-bit optimal rank identifier thereto.
[0011] Yet another aspect relates to a wireless communication apparatus, comprising: means for performing a non-linear decoding protocol on a received multiple-layer signal at a user device, means for generating submatrices from a transmission channel over which the transmission signal is received; means for performing a Q-R decomposition on the submatrices and deriving respective upper triangle matrices; means for determining an effective SNR for one or more possible transmission ranks; means for determining a channel capacity metric for each possible rank of the received signal; and means for transmitting information related to an optimal rank with CQI information over a reverse link control channel. . The apparatus can additionally comprise means for performing a list-sphere decoding protocol to decode the received signal, means for capacity mapping the submatrices, and means for determining an effective signal-to-noise ratio (SNR) for each submatrix. Moreover, the apparatus can comprise means for generating CQI information related to the received signal based at least in part on the effective SNR associated with the optimal rank. The means for transmitting can transmit CQI and rank information over the reverse link control channel approximately every 5 ms.
[0012] Still another aspect relates to a computer-readable medium having stored thereon computer-executable instructions for employing a non-linear decoding protocol in a user device to decode a received multiple-layer signal, generating submatrices from a transmission channel over which the transmission signal is received, performing a Q- R decomposition on the submatrices and deriving respective upper triangle matrices, determining an effective SNR for one or more possible transmission ranks, determining
a channel capacity metric for all possible ranks of the transmission signal, and selecting a rank that maximizes channel capacity for transmissions.
[0013] A further aspect provides for a processor that executes instructions for employing a non-linear decoding protocol in a user device to decode a received multiple-layer signal, generating submatrices from a transmission channel over which the transmission signal is received, performing a Q-R decomposition on the submatrices and deriving respective upper triangle matrices, determining an effective SNR for one or more possible transmission ranks, determining a channel capacity metric for all possible ranks of the transmission signal, and selecting a rank that maximizes channel capacity for transmissions.
[0014] To the accomplishment of the foregoing and related ends, the one or more embodiments comprise the features hereinafter fully described and particularly pointed out in the claims. The following description and the annexed drawings set forth in detail certain illustrative aspects of the one or more embodiments. These aspects are indicative, however, of but a few of the various ways in which the principles of various embodiments may be employed and the described embodiments are intended to include all such aspects and their equivalents.
BRIEF DESCRIPTION OF THE DRAWINGS
[0015] FIG. 1 illustrates a wireless network communication system in accordance with various embodiments presented herein.
[0016] FIG. 2 is an illustration of a multiple access wireless communication system according to one or more embodiments.
[0017] FIG. 3 is an illustration of a system that facilitates performing rank prediction with an SWC transmitter in a wireless device, in accordance with one or more aspects.
[0018] FIGS. 4-6 illustrate a trellis representation of a list-sphere decoding protocol and optimization thereof, in accordance with one or more aspects described herein.
[0019] FIG. 7 illustrates a methodology for performing capacity-based rank selection in a non-linear receiver in an access terminal, in accordance with one or more aspects.
[0020] FIG. 8 is an illustration of a methodology for performing maximum rank selection in conjunction with a single code word communication design in a non-linear receiver in an access terminal, in accordance with various aspects set forth herein. [0021] FIG. 9 is an illustration of a methodology for determining rank in a minimum mean-squared error (MMSE)-based non-linear receiver in an access terminal, in accordance with one or more aspects set forth herein.
[0022] FIG. 10 is an illustration of a user device that facilitates calculating rank of a received transmission layer in a non-linear receiver employed in a wireless communication environment, in accordance with one or more aspects set forth herein. [0023] FIG. 11 is an illustration of a system that facilitates updating a rank for a user device that employs a non-linear receiver in a wireless communication environment in accordance with various aspects.
[0024] FIG. 12 is an illustration of a wireless network environment that can be employed in conjunction with the various systems and methods described herein. [0025] FIG. 13 is an illustration of an apparatus that facilitates performing rank prediction in a non-linear receiver of an access terminal, in accordance with one or more aspects.
DETAILED DESCRIPTION
[0026] Various embodiments are now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of one or more embodiments. It may be evident, however, that such embodiment(s) may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate describing one or more embodiments. [0027] As used in this application, the terms "component," "system," and the like are intended to refer to a computer-related entity, either hardware, software, software in execution, firmware, middle ware, microcode, and/or any combination thereof. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers. Also, these components can execute from
various computer readable media having various data structures stored thereon. The components may communicate by way of local and/or remote processes such as in accordance with a signal having one or more data packets (e.g., data from one component interacting with another component in a local system, distributed system, and/or across a network such as the Internet with other systems by way of the signal). Additionally, components of systems described herein may be rearranged and/or complimented by additional components in order to facilitate achieving the various aspects, goals, advantages, etc., described with regard thereto, and are not limited to the precise configurations set forth in a given figure, as will be appreciated by one skilled in the art.
[0028] Furthermore, various embodiments are described herein in connection with a subscriber station. A subscriber station can also be called a system, a subscriber unit, mobile station, mobile, remote station, access point, remote terminal, access terminal, user terminal, user agent, a user device, or user equipment. A subscriber station may be a cellular telephone, a cordless telephone, a Session Initiation Protocol (SIP) phone, a wireless local loop (WLL) station, a personal digital assistant (PDA), a handheld device having wireless connection capability, or other processing device connected to a wireless modem.
[0029] Moreover, various aspects or features described herein may be implemented as a method, apparatus, or article of manufacture using standard programming and/or engineering techniques. The term "article of manufacture" as used herein is intended to encompass a computer program accessible from any computer- readable device, carrier, or media. For example, computer-readable media can include but are not limited to magnetic storage devices (e.g., hard disk, floppy disk, magnetic strips...), optical disks (e.g., compact disk (CD), digital versatile disk (DVD)...), smart cards, and flash memory devices (e.g., card, stick, key drive...). Additionally, various storage media described herein can represent one or more devices and/or other machine- readable media for storing information. The term machine-readable medium" can include, without being limited to, wireless channels and various other media capable of storing, containing, and/or carrying instruction(s) and/or data.
[0030] Referring now to Fig. 1, a wireless network communication system 100 is illustrated in accordance with various embodiments presented herein. Network 100 can comprise one or more base stations 102 in one or more sectors that receive, transmit, repeat, etc., wireless communication signals to each other and/or to one or
more mobile devices 104. Each base station 102 can comprise a transmitter chain and a receiver chain, each of which can in turn comprise a plurality of components associated with signal transmission and reception (e.g., processors, modulators, multiplexers, demodulators, demultiplexers, antennas, etc.), as will be appreciated by one skilled in the art. Mobile devices 104 can be, for example, cellular phones, smart phones, laptops, handheld communication devices, handheld computing devices, satellite radios, global positioning systems, PDAs, and/or any other suitable device for communicating over wireless network 100.
[0031] According to various aspects described herein, when employing a
MIMO-MMSE receiver (e.g., in a base station 102 and/or a user device 104), the rank prediction and CQI computation (e.g., for a given rank) can be performed with relative ease. However, when utilizing a list-sphere decoder technique, rank prediction and CQI computation can be more challenging due to the non-linearity of the receiver. Conventional systems and/or methodologies cannot support integration of a list-sphere decoder design in a MIMO system, and thus cannot exploit the performance benefits of a list-sphere decoder design. Various aspects presented herein describe systems and/or methods that can facilitate implementing a list-sphere decoder in a MEvIO system to improve system performance. For example, MIMO channel capacity can be utilized as a metric for CQI and rank prediction, based at least in part on an assumption of a sphere decoder gap to capacity, as described in greater detail below. [0032] Referring now to Fig. 2, a multiple access wireless communication system 200 according to one or more embodiments is illustrated. System 200 is presented for illustrative purposes and can be utilized in conjunction with various aspects set forth below. A 3-sector base station 202 includes multiple antenna groups: one including antennas 204 and 206, another including antennas 208 and 210, and a third including antennas 212 and 214. According to the figure, only two antennas are shown for each antenna group, however, more or fewer antennas may be utilized for each antenna group. Mobile device 216 is in communication with antennas 212 and 214, where antennas 212 and 214 transmit information to mobile device 216 over forward link 220 and receive information from mobile device 216 over reverse link 218. Mobile device 222 is in communication with antennas 204 and 206, where antennas 204 and 206 transmit information to mobile device 222 over forward link 226 and receive information from mobile device 222 over reverse link 224.
[0033] Each group of antennas and/or the area in which they are designated to communicate is often referred to as a sector of base station 202. In one embodiment, antenna groups each are designed to communicate to mobile devices in a sector of the areas covered by base station 202. In communication over forward links 220 and 226, the transmitting antennas of base station 202 can utilize beam-forming techniques in order to improve the signal-to-noise ratio of forward links for the different mobile devices 216 and 222. Additionally, a base station using beam-forming to transmit to mobile devices scattered randomly through its coverage area causes less interference to mobile devices in neighboring cells/sectors than a base station transmitting through a single antenna to all mobile devices in its coverage area. A base station may be a fixed station used for communicating with the terminals and may also be referred to as an access point, a Node B, or some other terminology. A mobile device may also be called a mobile station, user equipment (UE), a wireless communication device, terminal, access terminal, user device, or some other terminology.
[0034] According to one or more aspects, user devices 216 and 222, as well as base station 202, can utilize a single code word (SCW) design with rank prediction in conjunction with a MIMO-MMSE receiver. The utilization of such receivers with a SCW design can facilitate closing a performance gap between an SCW design and a multiple code word (MCW) capacity-achieving design. For instance, a list sphere decoding technique for an SCW design can achieve up to 1.5 dB gain for signal-to-noise ratios (SNRs) lower than 15 dB, and can provide up to 3.5 dB gain for SNRs greater than 20 dB.
[0035] A MEVIO receiver design can have two modes of operation: single code word (SCW) and multiple-code word (MCW). The MCW mode can be capacity- achieving because the transmitter can encode data transmitted on each spatial layer independently, potentially with different rates. The receiver employs a successive interference cancellation (SIC) algorithm which works as follows: decode a 1st layer; subtract its contribution from the received signal after re-encoding; multiply the encoded 1st layer with the "estimated channel"; decode the 2nd layer and so on. This "onion-peeling" approach means that each successively decoded layer sees increasing SNR and therefore can support higher transmission rates. In the absence of error- propagation, the MCW design with SIC can achieve capacity. However, such a design requires careful management of the rates of each spatial layer due to increased CQI feedback (one CQI for each layer), increased ACK/NACK messaging (one for each
layer), complications in hybrid automatic request (HARQ) protocols since each layer can terminate at different transmissions, performance sensitivity of SIC with Doppler and CQI erasures, increased decoding latency requirements since each successive layer cannot be decoded until prior layers are decoded, increased memory requirements at the AT with HARQ since all channels and received signals have to be stored for multiple transmissions, etc., in order to perform interference-cancellation, etc. [0036] Accordingly, a SCW mode design, wherein a transmitter encodes data transmitted on each spatial layer with substantially similar and/or identical data rates, can be a desirable alternative to an MCW design. A number of spatial layers {e.g., rank) is adapted on a packet-by-packet basis, depending on a channel scenario and SNR, to perform rank-prediction. A receiver can employ a low complexity linear receiver such as MMSE for each of a plurality of received tones. The SCW design can thus mitigate the above-mentioned implementation complexities of the MCW design. For instance, since 90% of the users in a WAN environment typically have SNRs < 15 dB, the SCW design can be a desirable alternative to an MCW design.
[0037] Fig. 3 is an illustration of a system 300 that facilitates performing rank prediction with an SCW transmitter in a wireless device, in accordance with one or more aspects. System 300 comprises a turbo encoder 302, a QAM mapping component 304, and a rate prediction component 306 that manipulate received inputs and provide an encoded, mapped signal to a demultiplexer 308. Coded symbols are then demultiplexed by demultiplexer 308 to generate M streams, or layers, such that 1 < M ≤ min(Mr ,M R ) , where M is a 2-bit piece of rank information specified in a reverse-link CQI control channel approximately every 5 ms by a receiver 318 via feedback, in addition to a 5-bit CQI feedback signal. The M streams are then spatially mapped by spatial mapping component 310 to M1- antennas, after which the rest of the transmission processing is similar to the SISO design. A plurality of respective OFDM modulators 312, 314, and 316, can then modulate the MT streams for transmission by the MT antennas.
[0038] Spatial mapping component 310 (e.g., a precoder) can generate an
MT xM matrix P(k) that maps M symbols on to M7 antennas, for each OFDM tone, k. Spatial mapping component 310 can employ a plurality of options when mapping symbols to antennas. According to an example, an MR xMT MBVIO channel H(k) can be considered. Precoder matrices can be chosen so that an equivalent channel
matrix H(k)P(k) has improved frequency selectivity compared to H(k) . Increased frequency selectivity can be exploited by a decoder to obtain frequency diversity gains. [0039] Fig. 3 further illustrates a number of receive antennas, 1 through MR, each of which is connected to a respective OFDM demodulator 320, 322, and 324, which in turn are coupled to a list-sphere decoder (LSD) 326. LSD 326 can be implemented on a tone-by-tone basis, where for each tone, MR received signals are processed to generate the log likelihood ratio (LLR) for M symbols, where M is the rank. For example, LSD 326 can provide information to a CQI and rank computation component 328 to facilitate generating a 5-bit CQI report and a 2-bit rank indicator approximately every 5 ms. LSD 326 can additionally provide 1 through M streams of data to a multiplexer 330, which multiplexes the data streams and provides a single signal to an LLR component 332. LLR component 332 then provides a signal with LLR information to a turbo decoder 334, which decodes the data signal. [0040] An MMSE receiver typically used for SCW design is a linear receiver, which decouples a MEVIO channel into a number of SISO channels, where the number of SISO channels is equivalent to the rank of the MEVIO transmission. In comparison, LSD 326 can utilize a sphere decoding technique that is a low complexity approximation to a maximum likelihood (ML) MEVIO decoder (non-linear), and can therefore achieve superior performance compared to a linear MMSE receiver. For an orthogonal channel, the performance of an MMSE receiver and the described LSD 326 can be substantially similar and/or identical to one another. For example, if MR is the number of receive antennas and M is the rank of a given MEVIO transmission, then the system equation for a given tone can be defined as:
x — Hs + n
where H is the MEVIO channel per tone (MR X M), X is the received signal vector per tone (MR X 1), s is the transmit symbol vector per tone (M x I=O1 S2 ... SM], and where n is the noise vector per tone (MRXV). [0041] The ML MEVIO solution is given as:
5 = argmax || x-Hs
If implemented directly, the complexity is exponential with the number of MEMO layers (M), and the symbol constellation order. However, LSD 326 can approximate the performance of an ML solution, and thus reduce computational complexity. According to an example, the QR decomposition can be defined as: H = QR , where Q is an
MR X M matrix and R is an upper triangular M xM matrix. The zero-forcing solution can be defined as: S = [H* Hj H*x Then:
SN^ = argmin || x - Hs sεA
= argmin [(s - s)* H *H» - S) + **(/ - H (H ^H)-1H*)*] sεA
< arg min (s — $Y H* H (s - s) = r2 (r = sphere radius) sεA
= arg min (s — s) R R(s - s) sεA
Thus, by equation (1), LSD 326 avoids an exhaustive ML search by only looking at the points inside a sphere of radius "r".
[0042] LSD component 326 can perform an algorithm as follows. A value / can be set such that i - M . The LΗS of equation (1) becomes RU % M || su - su ||2 , where sM € ΛM , which is the constellation used for Mth layer. Candidate constellation points can be searched and a candidate constellation point JM can be selected such that
RMM Il ^M ~ ^M Il 2— r2 • The value i can then be reset such that i = M -I . The LΗS of equation (1) now becomes
R M-Ϊ.M /-
ΛM-1,M-1 SM-\ SM-\ + R (s M + RM M2MM \ I\l ύ SM1. - S M \ where s^ e Λ,.,,
M -1,M-I which is the constellation used for the (M-l)th layer. For the SCW design, the constellation used for all layers can be the same (e.g., A1n = A, Vm = 1,2,...M ). For a given point JM , one constellation point, S^-1 , can be selected, such that
is available for the choice of s
M , then i can be reset to equal M and another J
M can be selected. For a given pair I
M _
j , J
M , z can be set such that i = M — 2 and a point J
M_
2 can be selected that falls inside the radius "r". Such acts can be reiterated until one solution vector point [ I
M , J
M_
: , J
M_
2 ,...., J
1 ] is obtained.
[0043] The LHS of equation (1) can then be re-computed assuming the above obtained vector point, to obtain a new radius rupdate . Then, r can be redefined such that r <— rupdate , and the foregoing can be reiterated with the new radius r until the ML solution is obtained. It will be appreciated that the sphere radius shrinks with each iteration, and thus only a subset of candidate points need to be evaluated before obtaining an ML solution, thereby providing a faster, more efficient solution than can be obtained using conventional techniques.
[0044] LSD 326 can be a MEMO-MAP decoder that generates soft-information for the turbo-decoder, and is based on sphere decoder principles. As in the sphere- decoder technique described above, a sphere radius "r" can be selected, and similar acts can be performed to select a candidate solution vector [ IM ', ?M_X , JM_2 ,...., J1 ] and
compute the associated cost given by —7- || x - Hs ||2 . A function [candidate, cost] can σ" then be added to the "candidate list". This process can be reiterated until
Ncand candidate solutions are obtained in the "candidate list". The remaining candidate solution vectors within the radius "r" can be added to the candidate list by replacing the candidate solution vectors with highest costs in the candidate list.
[0045] For example, let Mc be the modulation order and let M be the rank of a
MIMO transmission. A total of MMC bits can thus be transmitted in each tone. The soft extrinsic information {e.g., LLR) for each bit bk V k = 1,2..MM c is approximated as:
m
ax --Zi-Il *-^-
* Il +KyL
Aχk] (2
) b
k=-l I
σ J
where: s
<b =1> = [,S
1 S
2 s
M ]
<b =1> includes all the candidate solution vectors with b
k = 1 ; σ
2 is the noise-variance; b
m = [b
λ ... ^
-1 Z^
+1 ...] is a sub-vector of bits obtained by excluding b
k ; L
A m - [L
A m ... L
Ai[Λ_
n £
A)[*
+i
] —J is a vector of a- priori LLR information on all bits corresponding present in the vector b
[k] , and where max
*(α,fc) = ln(e
β + e
6) .
[0046] Figs. 4-6 illustrate a trellis representation of a list-sphere decoder and optimization thereof, in accordance with one or more aspects described herein. With respect to Fig. 4, a trellis representation 400 is illustrated with M stages, corresponding to the rank of the MIMO transmission, and Mc states, corresponding to the number of constellation points. According to an example, for a 16 QAM constellation and Rank 4 transmission, M=4 and Mc=4. The optimization parameter that describes a relationship between complexity and performance is Ncand . To further this example, Ncand = 2 can be defined. A cost function /?MAf || sM - sM \\2 can be evaluated for all constellation points, and Ncmd points that represent a minimum cost can be preserved. If
Ncand > 2Mc » tnen 2Mc points can be preserved, as indicated by the shaded circles in Fig.
4. For each of the selected points, the cost for Mc candidate constellation points for the (M-I)111 rank (layer) can be computed as
R,
R ■M-l.M-l SM-l SM-1 + ÷ (sM -sM ) + R MM Il S M ~ $ M f ■ Several candidate
R -M-I1M-I pairs [sM , sM_j ] can be generated, as indicated by the dotted lines in the trellis diagram 400. Note that the term R^M || ,sM —sM ||2 is already computed and can be re-used at this
Tf point. Furthermore, — M~XM (sM -sM) is computed only Ncand times and can be re-
-^M-I1M-I used for the remaining computations. These observations reduce overall complexity of the list sphere-decoding algorithm.
[0047] Now turning to Fig. 5, a trellis diagram 500 is illustrated that depicts further path selection in accordance with various aspects and in conjunction with Fig. 4. Of the several dotted paths in Fig. 4, only Ncmd paths have been preserved, as well as the associated constellation points from layers M and M-I, which give the minimum cost as indicated by solid lines in the trellis diagram 500. Such acts can be repeated for
all subsequent layers until a final last stage of the trellis (corresponding to layer 1) is reached, each time preserving only Ncand paths and the associated constellation points from all previous layers. Ncmd paths and candidate solution vectors can be selected in this manner, as shown in the final trellis diagram 600 of Fig. 6. Once the candidate solutions and the corresponding cost are obtained, equation (2) can be utilized to obtain the LLR for each bit. The optimization parameter Ncmd can be varied depending on the constellation size. Furthermore, Ncand can be varied across stages.
[0048] Referring to Figs. 7-9, methodologies relating to calculating a transmission rank using a non-linear receiver in an access terminal are illustrated. For example, methodologies can relate to calculating a transmission rank using a non-linear receiver with an SCW protocol in an FDMA environment, an OFDMA environment, a CDMA environment, a WCDMA environment, a TDMA environment, an SDMA environment, or any other suitable wireless environment. While, for purposes of simplicity of explanation, the methodologies are shown and described as a series of acts, it is to be understood and appreciated that the methodologies are not limited by the order of acts, as some acts may, in accordance with one or more embodiments, occur in different orders and/or concurrently with other acts from that shown and described herein. For example, those skilled in the art will understand and appreciate that a methodology could alternatively be represented as a series of interrelated states or events, such as in a state diagram. Moreover, not all illustrated acts may be required to implement a methodology in accordance with one or more embodiments. [0049] Fig. 7 illustrates a methodology 700 for performing Q-R decomposition- based rank selection in a non-linear receiver in a user device, in accordance with one or more aspects. Method 700 is described using a 4-layer transmission, although more or fewer layers may be utilized in conjunction with the systems and methods described herein as will be appreciated by those skilled in the art. From the estimated 4x4 MDVIO channel, 4x1, 4x2, 4x3 and 4x4 channel sub-matrices can be derived, denoted as
H(I) = H4xl,H(2) = H4x2,H(3) = H4x3,H(4) = H4x4, at 702, and can be evaluated.
Matrix evaluation can comprise performing respective Q-R matrix decompositions at 704 to derive upper triangular matrices R(I), R(2), ...R(4) as follows:
R(X) = QR[HM],R(2) = βi?[H4x2],i?(3) = QR[Hm],R(4) = QR[HM]
Method 700 may be performed by a QRM/list-sphere decoder, such as a MAP/ML decoder, which performs joint processing of all layers and estimates symbols from all layers. Assuming that the symbol estimates from all layers are accurately estimated, an effective SNR calculation may be performed at 706, and expressed as:
effSNR[M
poss k = l,2,-,M
poss
where Mposs = 1,2,..,4 and indicates the possible transmission ranks, where sigmaΛ2 is the noise variance, and where R1^ (M poss ) is the (k,k)-th element of the matrix
R(M poss ) . The effective SNR computed from the above equation may be averaged over several tones and symbols in a current Frame, using, for example, a 64-QAM constrained capacity mapping, to give an averaged effective SNR number, denoted as efflSNR[M poss ] . At 708, the rank that maximizes capacity may be chosen as the optimum rank, e.g.,
Mopt = arg maX jx capM[eJfSNR[j]] . j=l,2,...min (MR1MT)
The spectral efficiency/layer for the MEVIO-SCW design may be given as:
C = capM[effSNR[Mopt]] .
The CQI (assuming the above rank) for the MIMO-SCW transmission may be quantized, at 710, to the required number of bits as: CQI = Q[effSNR[Mopt ]] . The
CQI and rank may then be fed-back using the RL-CTRL channel, at 712.
[0050] Fig. 8 is an illustration of a methodology 800 for performing maximum rank selection in conjunction with a single code word communication design in a non-
linear receiver in a wireless terminal, in accordance with various aspects set forth herein. According the method 800, maximum rank is selected for a MBVIO transmission, and code-rate and QAM may be varied to achieve a desired spectral efficiency. At 802, the spectral efficiency for the SCW design is calculated from the MIMO channel as:
C = — logdet 1 + Es - HH* bps/Hz M MTσ2
where M is MDVIO-SCW transmission rank, Es is total transmit power across all antennas, T represents the gap to capacity (e.g., turbo decoder gap, sphere decoder gap, channel estimation loss, ...), and σ2 is the noise variance per receive antenna. At 804, the spectral efficiency can be averaged across all tones and multiple OFDM symbols in a frame to generate an average spectral efficiency C . At 806, CQI (e.g., assuming rank 4 in a 4-layer scenario, as described with regard to Fig. 7) for the MIMO-SCW transmission can be calculated by computing the AWGN effective SNR, such that effSNR
C = log 1 + - r and quantizing it to the required bits such that CQI = Q[effSNR] .
It will be appreciated that higher code-rates can be enabled for 4-QAM and 16-QAM systems as opposed to, for instance, a 64-QAM system.
[0051] Fig. 9 is an illustration of a methodology 900 for determining rank in an access terminal having a minimum mean-squared error (MMSE)-based non-linear receiver, in accordance with one or more aspects set forth herein. At 902, submatiices for each of a plurality of transmission layers can be generated, as described above. At 904, successive interference cancellation (SIC) capacity for each matrix can be determined. Each layer can be capacity-mapped and an effective SNR can be determined there for at 906. According to an example, it may be determined that rank 2 is optimal in a particular scenario. In such a case, diagonal elements in a matrix for a layer corresponding to rank 2 can be evaluated and averaged. Additionally, an element of a matrix corresponding to a layer of rank 1 can be evaluated, and the capacity there for can be summed with the average of the capacities for the elements of the rank-2 layer (e.g., because such layers are successive). Thus, such capacities can be added at 908, such that total capacity for rank 2 can be equal to the average capacity for all layers of rank 2 plus the capacity of the rank-1 layer. At 910, the method can be repeated for
all ranks. At 912, a rank exhibiting the highest overall capacity can be selected. The selected rank can then be returned along with a CQI report approximately every 5 ms as described above.
[0052] It will be appreciated that, in accordance with one or more aspects described herein, inferences can be made regarding rank evaluation in a non-linear receiver, when to employ an algorithm associated therewith, whether to employ a nonlinear receiver protocol, etc. As used herein, the term to "infer" or "inference" refers generally to the process of reasoning about or inferring states of the system, environment, and/or user from a set of observations as captured via events and/or data. Inference can be employed to identify a specific context or action, or can generate a probability distribution over states, for example. The inference can be probabilistic-that is, the computation of a probability distribution over states of interest based on a consideration of data and events. Inference can also refer to techniques employed for composing higher-level events from a set of events and/or data. Such inference results in the construction of new events or actions from a set of observed events and/or stored event data, whether or not the events are correlated in close temporal proximity, and whether the events and data come from one or several event and data sources. [0053] According to an example, one or methods presented above can include making inferences regarding whether to employ a non-linear decoder as described above in a system comprising dual-decoding capabilities, etc. For instance, in a user device that has both a linear decoder and a non-linear decoder, inferences can be made regarding resource availability, computational overhead associated with employing either decoder, signal strength for a received transmission, and/or any other suitable information related to making a determination of whether a linear decoder protocol will suffice to achieve a desired outcome or whether a non-linear decoding scheme is preferable. In such cases, inferences can be made to facilitate preserving system resources, improving a user's communication experience, etc. For example, if battery life is in issue, it may be desirable to forego rank-related protocols in conjunction with a non-linear receiver in order to reduce computational overhead and preserve battery life as long as possible. Conversely, in a case where battery life is not in issue, it can be inferred that utilization of the non-linear receiver is desirable to enhance a communication experience even in the event that greater processing power may be required. It will be appreciated that the foregoing example is illustrative in nature and is not intended to limit the number of inferences that can be made or the manner in which
such inferences are made in conjunction with the various embodiments and/or methods described herein.
[0054] Fig. 10 is an illustration of a user device 1000 that facilitates calculating rank of a received transmission layer in a non-linear receiver employed in a wireless communication environment, in accordance with one or more aspects set forth herein. User device 1000 comprises a receiver 1002 that receives a signal from, for instance, a receive antenna (not shown), and performs typical actions thereon (e.g., filters, amplifies, downconverts, etc.) the received signal and digitizes the conditioned signal to obtain samples. Receiver 1002 can be a non-linear receiver, such as a maximum likelihood (ML)-MMSE receiver or the like. A demodulator 1004 can demodulate and provide received pilot symbols to a processor 1006 for channel estimation. Processor 1006 can be a processor dedicated to analyzing information received by receiver 1002 and/or generating information for transmission by a transmitter 1016, a processor that controls one or more components of user device 1000, and/or a processor that both analyzes information received by receiver 1002, generates information for transmission by transmitter 1016, and controls one or more components of user device 1000. [0055] User device 1000 can additionally comprise memory 1008 that is operatively coupled to processor 1006 and that stores information related to calculated ranks for user device 1000, a rank calculation protocol, lookup table(s) comprising information related thereto, and any other suitable information for supporting list-sphere decoding to calculate rank in a non-linear receiver in a wireless communication system as described herein. Memory 1008 can additionally store protocols associated rank calculation, matrix generation, etc., such that user device 1000 can employ stored protocols and/or algorithms to achieve rank determination in a non-linear receiver as described herein.
[0056] It will be appreciated that the data store (e.g., memories) components described herein can be either volatile memory or nonvolatile memory, or can include both volatile and nonvolatile memory. By way of illustration, and not limitation, nonvolatile memory can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable ROM (EEPROM), or flash memory. Volatile memory can include random access memory (RAM), which acts as external cache memory. By way of illustration and not limitation, RAM is available in many forms such as synchronous RAM (SRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM
(DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM). The memory 1008 of the subject systems and methods is intended to comprise, without being limited to, these and any other suitable types of memory.
[0057] Processor 1006 is further coupled to a capacity-mapping component
1010 that can facilitate mapping a capacity for one or more received layers in order to facilitate rank determination there for. User device can furthermore comprise rank evaluator 1012 that assesses a rank for each received layer as described here with regard to the preceding systems and methods. For instance, rank evaluator 1012 can utilize a capacity-based rank selection algorithm, a maximum rank selection algorithm, or any other suitable rank selection protocol to evaluate rank for a received layer in a nonlinear receiver. User device 1000 still further comprises a symbol modulator 1014 and a transmitter 1016 that transmits the modulated signal.
[0058] Fig. 11 is an illustration of a system 1100 that facilitates updating a rank for a user device that employs a non-linear receiver in a wireless communication environment in accordance with various aspects. System 1100 comprises a base station 1102 with a receiver 1110 that receives signal(s) from one or more user devices 1104 through a plurality of receive antennas 1106, and a transmitter 1124 that transmits to the one or more user devices 1104 through a transmit antenna 1108. Receiver 1110 can receive information from receive antennas 1106 and is operatively associated with a demodulator 1112 that demodulates received information. Demodulated symbols are analyzed by a processor 1114 that is similar to the processor described above with regard to Fig. 10, and which is coupled to a memory 1116 that stores information related to user ranks, lookup tables related thereto, and/or any other suitable information related to performing the various actions and functions set forth herein. Processor 1114 is further coupled to a rank adjuster 1118 that facilitates updating rank information associated with one or more respective user devices 1104 based on information received with a CQI report. Such information can be received from one or more user devices 1104 approximately every 5 ms, as is standard interval for CQI report transmissions. [0059] A modulator 1122 can multiplex a signal for transmission by a transmitter 1124 through transmit antenna 1108 to user devices 1104. Rank adjuster 1118 can append information to a signal related to an updated optimum rank for a given transmission stream for communication with a user device 1104, which can be transmitted to user device 1104 to provide an indication that a new optimum channel
has been identified and acknowledged. In this manner, base station 1102 can interact with a user device 1104 that provides rank update information and employs a list-sphere decoding protocol in conjunction with a non-linear receiver, such as an ML-MIMO receiver, etc., as described above with regard to the preceding figures. [0060] Fig. 12 shows an exemplary wireless communication system 1200. The wireless communication system 1200 depicts one base station and one terminal for sake of brevity. However, it is to be appreciated that the system can include more than one base station and/or more than one terminal, wherein additional base stations and/or terminals can be substantially similar or different for the exemplary base station and terminal described below. In addition, it is to be appreciated that the base station and/or the terminal can employ the systems (Figs. 1-6 and 10-11) and/or methods (Figs. 7-9) described herein to facilitate wireless communication there between. [0061] Referring now to Fig. 12, on a downlink, at access point 1205, a transmit
(TX) data processor 1210 receives, formats, codes, interleaves, and modulates (or symbol maps) traffic data and provides modulation symbols ("data symbols"). A symbol modulator 1215 receives and processes the data symbols and pilot symbols and provides a stream of symbols. A symbol modulator 1220 multiplexes data and pilot symbols and provides them to a transmitter unit (TMTR) 1220. Each transmit symbol may be a data symbol, a pilot symbol, or a signal value of zero. The pilot symbols may be sent continuously in each symbol period. The pilot symbols can be frequency division multiplexed (EDM), orthogonal frequency division multiplexed (OEDM), time division multiplexed (TDM), frequency division multiplexed (EDM), or code division multiplexed (CDM).
[0062] TMTR 1220 receives and converts the stream of symbols into one or more analog signals and further conditions {e.g., amplifies, filters, and frequency upconverts) the analog signals to generate a downlink signal suitable for transmission over the wireless channel. The downlink signal is then transmitted through an antenna 1225 to the terminals. At terminal 1230, an antenna 1235 receives the downlink signal and provides a received signal to a receiver unit (RCVR) 1240. Receiver unit 1240 conditions {e.g., filters, amplifies, and frequency downconverts) the received signal and digitizes the conditioned signal to obtain samples. A symbol demodulator 1245 demodulates and provides received pilot symbols to a processor 1250 for channel estimation. Symbol demodulator 1245 further receives a frequency response estimate for the downlink from processor 1250, performs data demodulation on the received data
symbols to obtain data symbol estimates (which are estimates of the transmitted data symbols), and provides the data symbol estimates to an RX data processor 1255, which demodulates {i.e., symbol demaps), deinterleaves, and decodes the data symbol estimates to recover the transmitted traffic data. The processing by symbol demodulator 1245 and RX data processor 1255 is complementary to the processing by symbol modulator 1215 and TX data processor 1210, respectively, at access point 1205. [0063] On the uplink, a TX data processor 1260 processes traffic data and provides data symbols. A symbol modulator 1265 receives and multiplexes the data symbols with pilot symbols, performs modulation, and provides a stream of symbols. A transmitter unit 1270 then receives and processes the stream of symbols to generate an uplink signal, which is transmitted by the antenna 1235 to the access point 1205. [0064] At access point 1205, the uplink signal from terminal 1230 is received by the antenna 1225 and processed by a receiver unit 1275 to obtain samples. A symbol demodulator 1280 then processes the samples and provides received pilot symbols and data symbol estimates for the uplink. An RX data processor 1285 processes the data symbol estimates to recover the traffic data transmitted by terminal 1230. A processor 1290 performs channel estimation for each active terminal transmitting on the uplink. Multiple terminals may transmit pilot concurrently on the uplink on their respective assigned sets of pilot subbands, where the pilot subband sets may be interlaced. [0065] Processors 1290 and 1250 direct (e.g., control, coordinate, manage, etc.) operation at access point 1205 and terminal 1230, respectively. Respective processors 1290 and 1250 can be associated with memory units (not shown) that store program codes and data. Processors 1290 and 1250 can also perform computations to derive frequency and impulse response estimates for the uplink and downlink, respectively. [0066] For a multiple-access system (e.g. , FDMA, OFDMA, CDMA, TDMA, etc.), multiple terminals can transmit concurrently on the uplink. For such a system, the pilot subbands may be shared among different terminals. The channel estimation techniques may be used in cases where the pilot subbands for each terminal span the entire operating band (possibly except for the band edges). Such a pilot subband structure would be desirable to obtain frequency diversity for each terminal. The techniques described herein may be implemented by various means. For example, these techniques may be implemented in hardware, software, or a combination thereof. For a hardware implementation, the processing units used for channel estimation may be implemented within one or more application specific integrated circuits (ASICs), digital
signal processors (DSPs), digital signal processing devices (DSPDs), programmable logic devices (PLDs), field programmable gate arrays (FPGAs), processors, controllers, micro-controllers, microprocessors, other electronic units designed to perform the functions described herein, or a combination thereof. With software, implementation can be through modules (e.g., procedures, functions, and so on) that perform the functions described herein. The software codes may be stored in memory unit and executed by the processors 1290 and 1250.
[0067] Fig. 13 is an illustration of an apparatus 1300 that facilitates performing rank prediction in a non-linear receiver of an access terminal, in accordance with one or more aspects. Apparatus 1300 is represented as a series of interrelated functional blocks, or "modules," which can represent functions implemented by a processor, software, or combination thereof (e.g., firmware). For example, apparatus 1300 may provide modules for performing various acts such as are described above with regard to the preceding figures. Apparatus 1300 comprises a logical module for generating anD evaluating Channel submatrices 1302, which is operatively coupled to a logical module for performing QR matrix decomposition 1304. Apparatus 1300 further comprises a logical module for calculating effective SNR(s) 1306, and a logical module for selecting an optimum rank 1308. Apparatus 1300 still further comprises a logical module for quantizing CQI information 1310 (e.g., quantizing an effective SNR for a selected optimum rank to generate CQI information there for), and a logical module for feeding back CQI and rank information 1312 from the access terminal to an access point, over a reverse link control channel. It is to be understood that apparatus 1300 and the various modules comprised thereby may carryout the methods described above and/or may impart any necessary functionality to the various systems described herein. [0068] For a software implementation, the techniques described herein may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein. The software codes may be stored in memory units and executed by processors. The memory unit may be implemented within the processor or external to the processor, in which case it can be communicatively coupled to the processor via various means as is known in the art.
[0069] What has been described above includes examples of one or more embodiments. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the aforementioned embodiments, but one of ordinary skill in the art may recognize that many further
combinations and permutations of various embodiments are possible. Accordingly, the described embodiments are intended to embrace all such alterations, modifications and variations that fall within the spirit and scope of the appended claims. Furthermore, to the extent that the term "includes" is used in either the detailed description or the claims, such term is intended to be inclusive in a manner similar to the term "comprising" as "comprising" is interpreted when employed as a transitional word in a claim.