With an ever growing need for higher data communication rate over wireless medium, users are demanding high rate data transmission. One area in which the aforementioned considerations have arisen is in UMTS Terrestrial Radio Access Network (UTRAN) and Evolved-UTRA, which call for higher user data rates and improved quality of service. A number of proposals have discussed and concluded the need for multiple-antenna systems to achieve the target spectral efficiency, throughput, and reliability of EUTRA. These proposals have considered different modes of operation applicable to different scenarios. The basic assumptions that vary among proposals include (i) using single stream versus multiple streams, (ii) scheduling one user at a time versus multiple users, (iii) having multiple streams per user versus a single stream per user, and (iv) coding across multiple streams versus using independent streams. A common factor among various downlink physical layer multiple-input-multiple-output (MIMO) proposals, however, is a feedback strategy to control the transmission rate and possibly vary the transmission strategy.
MIMO antenna systems can be effective in fading environment by providing significant performance improvements and achievable data rates in comparison to single antenna systems. Closed loop MIMO systems typically transmit channel state information from a receiver to a transmitter. Transmitting the channel state information consumes bandwidth that might otherwise be available for data traffic. The performance gain achieved by multiple antenna system increases when the knowledge of the channel state information (CSI) at each end, either the receiver or transmitter, is increased. Although perfect CSI is desirable, practical systems are usually built only on estimating the CSI at the receiver, and possibly feeding back the CSI to the transmitter through a feedback link with a very limited capacity. Using CSI at the transmitter, the transmission strategy is adapted over space (multiple antennas) and over time (over multiple blocks).
Conventional DL MIMO transmission strategy includes quantized precoding schemes, antenna selection, antenna cycling (with or without rank control), and different space-time coding and spatial multiplexing transmission scheme. The quantized precoding schemes are used whenever a feedback link from the receiver to the transmitter is present. The performance of quantized precoding scheme depends on the codebook design and the complexity and memory requirement are further functions of the precoding algorithm. Hence, codebook design is one of the main aspects of the quantized precoding schemes. The conventional design criterion is based on SNR maximization which is not necessarily the capacity-optimal design strategy. Moreover, the precoder size is assumed to be fixed which means the number of transmitted data streams, i.e., precoding rank, is fixed and is usually taken to be the minimum of the number of transmit and receive antennas.
In one aspect, a static codebook design provides a successive codebook structure and the precoding matrices are obtained from a set of precoding vector codebooks. This design addresses the problem of optimized vector codebook design, i.e., the set of vector codebooks which result in the optimal precoding matrix codebook.
In another aspect, a different code-book design problem. When the channel is correlated in time (or in frequency, e.g., across different tones in OFDM systems), the correlation can be used to considerably reduce the feedback requirement without loss in performance. The idea of differential codebook is to feedback only the variation in the channel, since typically quantizing the channel variations requires a smaller codebook than quantizing the channel itself.
Advantages of preferred embodiments of the above aspects may include one or more of the following. The design jointly optimizes the vector codebooks such that the resulting precoder matrices are optimized. By employing the differential codebook and optimized vector codebook, the performance of quantized precoding schemes is improved and higher throughput will be achievable. In comparison to the other competitive schemes on codebook based precoding which use the CQI-metric based precoder selection, the codebook requires less memory to store and has lower computational complexity. The optimal codebook is channel specific and is finely tuned to the channel statistics. The vector codebooks can be used with successive or Householder structured codebook. Simulation results show the superiority of the designed codebooks over the conventional codebooks.
An exemplary multiple-antenna communication system 100 with static and differential precoding codebook is schematically shown in
For a multiple-antenna system with r receive and t transmit antennas the baseband channel model can be expressed as follows: Y=HX+W, (1) where Y is the rx1 received column vector, H is the rxt channel matrix, X is the tx1 transmit column vector, and W is the rx1 noise column vector. The input is subject to an average power constraint P, i.e, tr(Q)≦P, where Q=E[XXH], E[.] denotes the expected value and tr(.) represents the trace of a matrix.
In an exemplary multi-rank beamforming scheme in accordance with the present invention, channel state information (CSI) is available to the transmitter (CSIT) as well as the receiver (CSIR). Where perfect CSIT and CSIR are assumed, the capacity of the multiple-antenna fading channel 130 can be achieved through power adaptation over time (one average power for each channel state) and water-filling power control over multiple eigenvectors of the channel for each block of transmission.
In systems that employ beamforming such as the MIMO systems, the beamforming matrix (referred to herein as a codeword) generated in response to perceived channel conditions is computed and quantized at the receiver first, and then is provided to the source transmitter (e.g., via feedback). A conventional approach to reduce the overhead associated with this feedback is to provide matrix codebook(s) at each of the transmitter and the receiver, each of the codebook(s) comprising a plurality, or set, of potential beamforming matrixes that may be used depending on the channel conditions perceived at the receiver. When the receiver has identified the appropriate matrix codebook(s), the receiver will typically feed back only an index (instead of the actual matrix entries) that points to the appropriate codeword in the codebook(s) stored at the transmitter.
Turning now to
In the MIMO system of
y=Hx+w, (1)
where x is the tx1 transmitted signal vector, H is the r×t channel matrix, w:Nc(0,I) is a circularly symmetric complex additive white Gaussian noise vector, and y is the r×1 received signal vector. A block fading channel model is used in which the channel remains constant during the transmission of each packet (or codeword of length T) and it changes independently from one block to another, where the distribution of the channel state is known a priori. The average power constraint is given by E[XHX]≦P.
In maximizing the throughput in single user (SU-) MIMO systems (or sum-rate throughput for multiple user (MU-) MIMO systems) which is usually the primary goal in downlink transmissions, the following assumptions can be used: (1) the user feeds back the quantized channel state via a limited feedback link; (2) based on the feedback information, the base station performs a linear precoding (and only linear precoding is allowed) of the transmitted streams.
Let UDV* be the singular value decomposition (SVD) of the channel matrix H. With B bits of feedback, the user quantizes the first n column of V (where n≦min(r, t)) is a fixed number predetermined by the base station) using a quantization codebook Q={Q1, Q2, . . . , Q2
where d(·,·) is some distance metric. The codebook design problem and the appropriate choice of the distance metric have been considered in prior art. The columns of the quantized precoding matrix V(1:n) correspond to possible different streams for this user.
The transmitted signal x from the base station then consists of L data streams, u1, U2, . . . , u, sent through column vectors g1,g2, . . . , gL of a linear precoder G. We have
In SU-MIMO systems, we have L=n while in MU-MIMO systems we have L≧n where one or more than one streams may be intended for each user.
Next, a codebook design will be discussed which is static and predesigned and does not adopt to the changes in the average channel condition. The first design considers rank specific codebook design where for each transmission rank a separate codebook is designed. The second design is based on transformation which generates the codebooks for all ranks based on a set of vector codebook.
Design Criterion
For a given transmission rank n and B bits of PMI feedback, the codebook design problem is formulated as finding the set Q={Q1, Q2, . . . , Q2
Let UDV* be the partial SVD of H obtained by retaining only the n right singular vectors that correspond to the n largest singular values of H. For a given H the optimal (t×n) precoder that maximizes the instantaneous mutual information is V, thus, for large enough codebook size:
The approximation in (5) is based on the observation that a well designed large enough codebook can closely sample the set of all possible V.
Next, an approximate upper bound on C is determined by considering channel realizations whose norms are bounded, i.e., H such that ∥H∥F2=tr[H*H]=tr[D*D]≦β. For such channels:
Considering the low SNR approximation of the bound in (6), i.e., letting P→0,
The inner maximization in the bound in (7) is equivalent to minimizing the chordal distance between the dominant right eigenvectors of the channel and the corresponding quantized vectors, where the chordal distance is defined as
On the other hand, considering the high SNR approximation of (6), i.e., P→∞:
The inner maximization in the bound in (9) is equivalent to minimizing the Fubini-Study (FS) distance between the dominant right eigenvectors of the channel and the corresponding quantized vectors, where the FS distance is defined as
d
FS(Q,V)=arc cos(det(V*Q)). (10)
This is so because log(.) is a monotonically increasing function and arc cos(.) is a monotonically decreasing function.
For finite SNRs, since the transmitted signals are the linear combination of the columns of the precoder Q, the precoding codebook design used here relies on a metric that measures the distance between the subspaces spanned by different precoders. While there is no known distance metric directly associated with the capacity expression (5), the inner maximization in the bound in (6) is equivalent to minimizing the following p-metric with
between the subspaces defined by V and Q on the Grassmanian manifold G(NT,r) which in turn is the space of all r dimensional subspaces of an NT dimensional vector space. The design based on the p-metric depends on the SNR level. The choice of β is discussed next. p-metric is in fact a valid distance metric in the Grassmanian manifold. Moreover, it can be readily verified that if p→0, the p-metric is equivalent to the chordal distance; and if p→∞, the p-metric is equivalent to the Fubini-Study distance. Therefore, the codebook design based on the p-metric bridges the gap between the design for low SNR and that for high SNR.
Rank Specific Codebook Design
In this section, the design of an independent codebook for each rank r is discussed. The design algorithm is based on the generalized Lloyd-Max algorithm that is a widely used for solving a variety of vector quantization problems. Given the quantization codebook Q={Q1, Q2, . . . , Q2
V
k
={VεC
txn
:d
p(V,Qk)≦dp(V,Qj),∀j≠k}. (12)
To satisfy the centroid condition, the following problem is solved for the kth partition
Since an analytical solution for the above optimal centroid problem does not exist, this is solved numerically. To employ the gradient-descent search algorithm, the real representation of the matrix Q denoted by Q is defined as
The real representation
The derivative of the objective function (15) with respect to φk is given by
with
The expression
can be found using standard techniques. The gradient-descent search algorithm can be used with the following update formula
Φ(l+1)=Φ(l)−μl∇ΦJ(
where μl is the sequence of the step sizes. Upon convergence, Φ is used to find the corresponding unitary matrix Q(Φ).
In sum, as shown in
Nested Vector Codebook Design
In this embodiment, the system imposes a structure on the codebook which facilitates implementation of the precoding scheme in a practical system by reducing the computational complexity as well as the memory requirement. Denote
Note that by applying a series of successive rotations, any semi-unitary matrix QεCtxn can be expressed as
where γk:Ct−k+1→C(t−k+1)×(t−k+1) is a mapping that for any unit-norm vector q(k)εCt−k+1 returns a rotation matrix γk(q(k)) such that γk(q(k))q(k)=et−k+1. Therefore, instead of designing the codebook of precoding matrices Q, the vector codebooks contains all the vectors q(k).
Consider NT−1 sets of unit-norm vectors in Q(1)={qi(1)}t=1k
can be used and let
To have a valid Householder transformation in the complex domain, the first element of the vector x has to be real valued. The codebook of rank r consists of the set of πi=1rKi precoding matrices of size t x n generated using the vector codebooks defined above. The size of the vector sets, i.e., K1, K2, . . . , Kt−1, are the design parameters and are usually chosen such that K1≧K2≧ . . . ≧Kt−1. For example, to design a set of 12 precoders of rank 2, K1=4 and K2=3. By choosing the indices i1, i2, . . . , ir, ijε{1,2, . . . , Kj} of the vectors from Q(1), Q(2), . . . , Q(r), any precoder of rank r, r=1,2, . . . , t−1, is generated as
The optimization is performed over the vector codebooks Q(1), Q(2), . . . , Q(t−1). The partitioning and centroid steps for the first vector codebook are given by
Partitioning: Given the quantization codebook Q(1)={q1(1),q2(1), . . . , qk
V
k
(1)
={vεC
tx1
:d
p(v,qk(1))≦dp(v,qj(1)), ∀j≠k} (23)
Centroid: The centroid for the kth partition is given by
where the expectation is taken over the dominant singular vector v.
For the second codebook, a set of doubly indexed partitions can be used, where each partition is identified by two vectors in the first and the second vector codebooks Q(1) and Q(2). The partitioning and centroid steps are then as follows.
Partitioning: Given the quantization codebooks Q(1)={q1(1), q2(1), . . . , qk
Centroid: The centroid corresponding to index i2 is given by
where the expectation is over the first two dominant eigenvectors, i.e., V(2) and I(.) denotes the indicator function.
In general, in finding the partitioning for the rth vector codebook Q(r), a set of r-tuple indexed partitions is defined and the partitioning and centroid conditions follows the same structure as above. A design procedure similar to Algorithm of
Differential Codebook Design
When the channel is correlated in time (or in frequency, e.g., across different tones in OFDM systems), the correlation can be used to considerably reduce the feedback requirement without loss in performance. The idea of differential codebook is to feedback only the variation in the channel, since typically quantizing the channel variations requires a smaller codebook than quantizing the channel itself.
Let V(s) denote the quantized version of the first N right eigenvectors of the channel matrix H(s)=U(s)D(s)V*(s) at time s using the static quantized codebook design previously discussed. For time s+1, we then find V(s+1)=OV(s+1) by using a t×t unitary transformation matrix O. With B bits of feedback, the differential codebook design is formulated as finding the set of O={O1,O2, . . . , O2
ε=E[∥O(V(s), V(s+1))V(s)−V(s+1)∥F2] (27)
is minimized where O(V(s),V(s+1)) denotes the transformation as a function of the right eigenvectors of the channel for two consecutive time slots.
In order to employ the Lloyed-Max algorithm, the system finds the optimal partitioning and the centroid for each partition. The optimal partitioning for the quantizer O(V(s),V(s+1)) satisfies
V
k={({circumflex over (V)}, V)εCtxr×Ctxr: ∥Ok{circumflex over (V)}−V∥F2≦∥Oj{circumflex over (V)}−V∥F2∀j≠k}, (28)
where {circumflex over (V)} and V denote the quantized and the actual right eigenvectors of the channel for two consecutive time slots, respectively. To satisfy the centroid condition, the following problem for the kth partition is solved:
Since ∥O{circumflex over (V)}−V∥F2=V∥F2−2etr{V{circumflex over (V)}*O*}+∥{circumflex over (V)}∥F2, the following is maximized
where ΣΦ*=SVD(E└V{circumflex over (V)}*∥({circumflex over (V)},V)εVk┘)and T=[sij]=Φ*O* is a unitary matrix. Thus, (30) is maximized when all sii=1, i.e., when O=Φ*. It should be noted that since the final solution depends only on Φ*, it can be obtained directly through the polar decomposition of E└VV*({circumflex over (V)},V)εVk┘ instead of the SVD.
The idea behind differential quantization is to use B1 bits for the main quantizer and B2<B1 bits for the differential quantizer. For example, in OFDM systems, when the precoder is used for a chunk of adjacent OFDM tones, the precoding is usually much more effective if the chunk size is smaller. Hence, if B bits are available for precoding across a large chunk of adjacent OFDM tones, the chunk is usually broken into several smaller, e.g., 3 sub-chunks of the same sizes where the precoder for each sub-chunk is specified with B/3 bits. However, considering the correlation between the adjacent sub-chunks, we can use a main quantizer with B1>B/3 bits for quantizing the center sub-chunk and use a differential codebook with B2<B/3 bits for quantizing of each of the other two sub-chunks, where B=B1+2B2, and B2<B1. Depending on the correlation structure we can usually pick B2<B1 such that the precoding performance of all three sub-chunks is almost similar.
The invention may be implemented in hardware, firmware or software, or a combination of the three. Preferably the invention is implemented in a computer program executed on a programmable computer having a processor, a data storage system, volatile and non-volatile memory and/or storage elements, at least one input device and at least one output device.
Each computer program is tangibly stored in a machine-readable storage media or device (e.g., program memory or magnetic disk) readable by a general or special purpose programmable computer, for configuring and controlling operation of a computer when the storage media or device is read by the computer to perform the procedures described herein. The inventive system may also be considered to be embodied in a computer-readable storage medium, configured with a computer program, where the storage medium so configured causes a computer to operate in a specific and predefined manner to perform the functions described herein.
The invention has been described herein in considerable detail in order to comply with the patent Statutes and to provide those skilled in the art with the information needed to apply the novel principles and to construct and use such specialized components as are required. However, it is to be understood that the invention can be carried out by specifically different equipment and devices, and that various modifications, both as to the equipment details and operating procedures, can be accomplished without departing from the scope of the invention itself.
The present application claims priority to U.S. Provisional Application Ser. No. 60/895,904, filed Mar. 20, 2007, the content of which is incorporated by reference. The present invention relates to the codebooks used in wireless communications.
Number | Date | Country | |
---|---|---|---|
60895904 | Mar 2007 | US |